@ -17,7 +17,7 @@ A [jsui] replacement for the [preset] object in Cycling'74 Max.
- More look customization
- More look customization
- Dynamically adapts to resize both in Edit and Presentation mode
- Dynamically adapts to resize both in Edit and Presentation mode
- Select mode: simple click selects the slot, double click recalls it (allows for organizing presets without recalling them)
- Select mode: simple click selects the slot, double click recalls it (allows for organizing presets without recalling them)
- Color mode: various ways to colorize preset slots
- Color mode: ability to color sstored presets with 6 customizable colors (currently colors are only assigned automatically depending on slot number)
## How to install
## How to install
- [Download](https://github.com/Teufeuleu/tc.preset/archive/refs/heads/main.zip) this repository (and please consider donating on the [gumroad page](https://glucose47.gumroad.com/l/tc_preset) if you like this package)
- [Download](https://github.com/Teufeuleu/tc.preset/archive/refs/heads/main.zip) this repository (and please consider donating on the [gumroad page](https://glucose47.gumroad.com/l/tc_preset) if you like this package)
@ -73,7 +73,7 @@ var auto_writeagain = 0; // When enabled, will send a "writeagain" to pattrst
varmenu_number_only=0;// Populates the umenu connected to 2nd outlet with stored preset number only, instead of number and name
varmenu_number_only=0;// Populates the umenu connected to 2nd outlet with stored preset number only, instead of number and name
varscrollable=1;// Defines weither the object can be scrolled or not
varscrollable=1;// Defines weither the object can be scrolled or not
varmin_rows=50;// Minimum number of rows to display if scrollable is enabled
varmin_rows=50;// Minimum number of rows to display if scrollable is enabled
varcolor_mode=0;// Change the way the filled slots (stored presets) color is handeld. 0: stored_slot_color. 1: looping through color_1 to color_6. 2: Freely assign colors 1 to 6. 3: Set any color to any preset
varcolor_mode=0;// Change the way the filled slots (stored presets) color is handeld. 0: stored_slot_color. 1: looping through color_1 to color_6
varselect_mode=0;// 0: single click to select and recall the slot. 1: single click to select the slot, double click to recall it.
varselect_mode=0;// 0: single click to select and recall the slot. 1: single click to select the slot, double click to recall it.
// (WORK)
// (WORK)
@ -105,14 +105,6 @@ var shift_hold, option_hold = 0;
varis_interpolating=0;
varis_interpolating=0;
varis_dragging=0;// Drag flag
varis_dragging=0;// Drag flag
vardrag_slot=-1;// Stores the slot that's being dragged
vardrag_slot=-1;// Stores the slot that's being dragged
varis_writing=0;
// Keeping track of various variables for dealing with color modes
varrequested_slot=-1;// Which slot we're waiting a value for (used in get_all_preset_colors)
varcolor_mode_candidate=0;// Which color mode we're aiming
varis_listening_to_subscriptionlist=0;//Filters out received subscriptionlist messages when not updating slot color values
varis_listening_to_clientlist=0;//Filters out received clientlist messages when not updating slot color values
varcolor_pattr;
varhas_loaded=false;
varhas_loaded=false;
@ -121,42 +113,6 @@ if (jsarguments.length>1) { // Depreciated, use "pattrstorage" attribute instead
// Set src_slot as if we were interpolating from the last recalled preset different than 0
// Set src_slot as if we were interpolating from the last recalled preset different than 0
@ -806,8 +662,8 @@ function recall() {
}
}
varinterp=Math.min(1,Math.max(0,args[2]));
varinterp=Math.min(1,Math.max(0,args[2]));
if(interp==0.0){
if(interp==0.0){
slots[src_slot].interp=-1;
slots[src_slot][6]=-1;
slots[trg_slot].interp=-1;
slots[trg_slot][6]=-1;
is_interpolating=0;
is_interpolating=0;
if(previous_target!=active_slot){
if(previous_target!=active_slot){
previous_active_slot=active_slot;
previous_active_slot=active_slot;
@ -819,15 +675,15 @@ function recall() {
set_active_slot(src_slot);
set_active_slot(src_slot);
}elseif(interp==1.0){
}elseif(interp==1.0){
slots[src_slot].interp=-1;
slots[src_slot][6]=-1;
slots[trg_slot].interp=-1;
slots[trg_slot][6]=-1;
is_interpolating=0;
is_interpolating=0;
previous_target=trg_slot;
previous_target=trg_slot;
set_active_slot(trg_slot);
set_active_slot(trg_slot);
}else{
}else{
slots[src_slot].interp=1-interp;
slots[src_slot][6]=1-interp;
slots[trg_slot].interp=interp;
slots[trg_slot][6]=interp;
is_interpolating=1;
is_interpolating=1;
active_slot=0;
active_slot=0;
// set_active_slot(0);
// set_active_slot(0);
@ -835,10 +691,6 @@ function recall() {
outlet(0,"recall",src_slot,trg_slot,interp);
outlet(0,"recall",src_slot,trg_slot,interp);
}
}
}
// else {
// //typeof(args[0]) == 'string', so user just recalled a single parameter.
// }
}
}
@ -859,12 +711,12 @@ function recallmulti() {
for(vari=0;i<interp_slots.length;i++){
for(vari=0;i<interp_slots.length;i++){
varnb=interp_slots[i][0];
varnb=interp_slots[i][0];
if(slots[nb].name!=null){
if(slots[nb][4]!=null){
interp_slots[i][1]/=summed_weight;
interp_slots[i][1]/=summed_weight;
}else{
}else{
interp_slots[i][1]=-1;
interp_slots[i][1]=-1;
}
}
slots[nb].interp=interp_slots[i][1]
slots[nb][6]=interp_slots[i][1]
}
}
is_interpolating=1;
is_interpolating=1;
@ -877,16 +729,11 @@ function recallmulti() {
functionstore(v){
functionstore(v){
v=Math.floor(v);
v=Math.floor(v);
if(v>=0){
if(v>=0){
if(slots[v].lock>0){
if(slots[v][5]>0){
error('cannot overwrite locked slot '+v+'\n');
error('cannot overwrite locked slot '+v+'\n');
}else{
}else{
varrecalc_rows_flag=scrollable&&v>slots_highest;
varrecalc_rows_flag=scrollable&&v>slots_highest;
if(color_pattr){
//Initialize preset color to default for new preset
color_pattr.message(0);
}
to_pattrstorage("store",v);
to_pattrstorage("store",v);
to_pattrstorage("getslotlist");
to_pattrstorage("getslotlist");
@ -902,7 +749,6 @@ function store(v) {
outlet(0,"store",v);
outlet(0,"store",v);
if(v){
if(v){
// We writagain only if stored preset is > 0
trigger_writeagain();
trigger_writeagain();
}
}
}
}
@ -929,11 +775,11 @@ function lock() {
functionlockedslots(){
functionlockedslots(){
varlocked_slots=arrayfromargs(arguments);
varlocked_slots=arrayfromargs(arguments);
for(vari=1;i<slots.length;i++){
for(vari=1;i<slots.length;i++){
slots[i].lock=0;
slots[i][5]=0;
}
}
if(locked_slots.length){
if(locked_slots.length){
for(vari=0;i<locked_slots.length;i++){
for(vari=0;i<locked_slots.length;i++){
slots[locked_slots[i]].lock=1;
slots[locked_slots[i]][5]=1;
if(locked_slots[i]==selected_slot){
if(locked_slots[i]==selected_slot){
select(selected_slot);
select(selected_slot);
}
}
@ -942,8 +788,6 @@ function lockedslots() {
}
}
functionwrite(){
functionwrite(){
if(is_writing){
is_writing=0;
varargs=arrayfromargs(arguments);
varargs=arrayfromargs(arguments);
varfilename=args[0];
varfilename=args[0];
varstate=args[1];
varstate=args[1];
@ -952,10 +796,6 @@ function write() {
}else{
}else{
error(pattrstorage_name+': error while writing '+filename+'\n');
error(pattrstorage_name+': error while writing '+filename+'\n');
}
}
}else{
error("Send your write messages directly to the pattrstorage instead.\n");
}
}
}
functionread(){
functionread(){
@ -966,37 +806,6 @@ function read() {
}
}
}
}
functionsubscriptionlist(){
varclient=arrayfromargs(arguments)[0];
if(is_listening_to_subscriptionlist){
if(client=="preset_color"){
// [pattr preset_color] subscribed
// post("preset_color pattr object found and subscribed to bound pattrstorage. Switching to color mode", color_mode_candidate, '\n');
is_listening_to_subscriptionlist=0;
color_mode=color_mode_candidate;
paint_base();
}elseif(client=="done"){
error("A [pattr preset_color] object has been found but it isn't subscribed to your pattrstorage. Please add it to your subscribelist and try changing color mode again.\n")
is_listening_to_subscriptionlist=0;
}
}
}
functionclientlist(){
varclient=arrayfromargs(arguments)[0];
if(is_listening_to_clientlist){
if(client=="preset_color"){
// post("preset_color pattr object found and client to bound pattrstorage. Switching to color mode", color_mode_candidate, '\n');
is_listening_to_clientlist=0;
color_mode=color_mode_candidate;
paint_base();
}elseif(client=="done"){
error("A [pattr preset_color] object has been found but seems to be invisible to the pattrstorage.\n")
<description>Function depends on inlet</description>
<description>Function depends on inlet</description>
</method> -->
</method> -->
<methodname="color_wheel">
<methodname="color_wheel">
<digest>Define color wheel colors</digest>
<digest>Set the slot colors</digest>
<description>The message "color_wheel", followed by an integer and four float, defines one of the 6 available slot colors when color_mode is enabled.
<description>The message "color_wheel", followed by an integer and four float, defines one of the 6 available slot colors when color_mode is enabled.
The integer argument, between 1 and 6, defines which color in being modified, and next the four floats define the color in the RGBA format.
The message "color_wheel" without argument resets the six colors to their default values.
</description>
</method>
<methodname="setcolor">
<digest>Set the preset colors</digest>
<description>The message "setcolor" allows to set the color of a preset as shown when in color_mode 2 (select) or 3 (custom).
With 1 or 2 integer arguments, it allows to set a preset color as seen in color mode 2. With 4 float arguments or 1 integer followed by 4 floats, it allows to set a preset color for the color mode 3.
With 1 integer argument, the currently selected preset color wheel's color is set to the argument's value.
With two integer arguments, the preset number defined by first argument is set to color wheel's color defined by the second argument.
With 4 float arguments, the currently selected preset is set to a custom color defined by the four arguments (in RGBA format).
With 1 integer followed by 4 float arguments, the preset number defined by first argument is set to a custom color defined by the four arguments (in RGBA format).
The integer argument, between 1 and 6, defines which color in being modifier, and next the four floats define the color in the RGBA format.
The integer argument, between 1 and 6, defines which color in being modifier, and next the four floats define the color in the RGBA format.
The message "color_wheel" without argument resets the six colors to their default values.
<description>When set to 0, all preset slots have the same color (same as the preset object) defined by the stored_slot_color attribute.
<description>When set to 0, all preset slots have the same color (same as the preset object). When set to 1, stored preset slots are colored. See color_1 to color_6 as well as the color_wheel message.</description>
When set to 1, stored preset slots are colored according to one of the six colors of the color wheel, in a repeating pattern.
In mode 2, stored preset colors can be freely set to one of the six colors of the color wheel.
In mode 3, stored preset color can be set to any color in RGBA format.
To define colors of the color wheel for modes 1 and 2, see color_1 to color_6 as well as the color_wheel message.
To define preset color as in mode 2 or 3, see the setcolor message. Modes 2 and 3 require a pattr object named 'preset_color' to be at the same patcher level as the tc.preset object.