page and item selection

This commit is contained in:
2025-09-29 22:00:51 +02:00
parent afb9fb9d13
commit 2138da7d4d
9 changed files with 106 additions and 41 deletions
+13
View File
@@ -0,0 +1,13 @@
#include "arr.h"
unsigned int arr_uint_index_of(UintArray array, unsigned int value) {
unsigned int i;
for (i = 0; i < array.length; i++) {
if (array.values[i] == value) {
return i;
}
}
return ARRAY_NOT_FOUND;
}
+8
View File
@@ -0,0 +1,8 @@
#include "types.h"
#ifndef ARR_H
#define ARR_H
unsigned int arr_uint_index_of(UintArray array, unsigned int value);
#endif /* ARR_H */
+4
View File
@@ -25,4 +25,8 @@
#define ARRAY_SIZE 1024
#endif
#ifndef ARRAY_NOT_FOUND
#define ARRAY_NOT_FOUND ARRAY_SIZE + 1
#endif
#endif /* CONFIG_H */
+10 -12
View File
@@ -64,7 +64,7 @@ static void init_context(Parameters params, unsigned int in_count,
memset(context->state, 0, sizeof(context->state));
if (params.demo) {
state_randomize(context, state_config, frag_count);
state_randomize(context, state_config);
}
memset(context->active, 0, sizeof(context->active));
@@ -200,7 +200,7 @@ static void key_callback(Window *window, int key,
window_close(window);
} else if (window_char_key(key, action, 82)) {
// R: randomize
state_randomize(context, state_config, program.frag_count);
state_randomize(context, state_config);
} else if (window_char_key(key, action, 68)) {
// D: demo on/off
context->demo = !context->demo;
@@ -208,8 +208,7 @@ static void key_callback(Window *window, int key,
}
static void midi_callback(unsigned char code, float value) {
state_apply_event(context, state_config, program.frag_count, midi, code,
value);
state_apply_event(context, state_config, midi, code, value);
}
static void loop(bool hr) {
@@ -288,10 +287,9 @@ void forge_run(Parameters params) {
window_use(window_output, context);
program = shaders_init(
fragment_shaders, config, context, inputs, params.video_in_count,
state_config.select_page_count * state_config.select_item_count,
state_config.src_count, NULL);
program = shaders_init(fragment_shaders, config, context, inputs,
params.video_in_count, state_config.state_max,
state_config.src_count, NULL);
} else {
window_output = NULL;
}
@@ -303,10 +301,10 @@ void forge_run(Parameters params) {
window_use(window_monitor, context);
program = shaders_init(
fragment_shaders, config, context, inputs, params.video_in_count,
state_config.select_page_count * state_config.select_item_count,
state_config.src_count, window_output != NULL ? &program : NULL);
program = shaders_init(fragment_shaders, config, context, inputs,
params.video_in_count, state_config.state_max,
state_config.src_count,
window_output != NULL ? &program : NULL);
} else {
window_monitor = NULL;
}
+1 -1
View File
@@ -493,7 +493,7 @@ static void use_program(ShaderProgram program, int i, bool output,
write_uniform_1i(program.ifps_locations[i], context->fps);
write_uniform_1i(program.idemo_locations[i], context->demo ? 1 : 0);
write_uniform_1i(program.ipage_locations[i], context->page);
write_uniform_1i(program.iselected_locations[i], context->page);
write_uniform_1i(program.iselected_locations[i], context->selected);
write_uniform_2f(program.ires_locations[i], &resolution);
write_uniform_2f(program.itexres_locations[i], &tex_resolution);
+56 -17
View File
@@ -1,5 +1,6 @@
#include <log.h>
#include "arr.h"
#include "config.h"
#include "config_file.h"
#include "midi.h"
@@ -12,32 +13,37 @@ StateConfig state_parse_config(ConfigFile config) {
StateConfig state_config;
char name[256];
state_config.select_page_count =
state_config.select_page_codes.length =
config_file_get_int(config, "SELECT_PAGE_COUNT", 0);
for (i = 0; i < state_config.select_page_count; i++) {
for (i = 0; i < state_config.select_page_codes.length; i++) {
sprintf(name, "SELECT_PAGE_%d", i + 1);
state_config.select_page_codes[i] =
state_config.select_page_codes.values[i] =
config_file_get_int(config, name, UNSET_MIDI_CODE);
}
state_config.select_item_count =
state_config.select_item_codes.length =
config_file_get_int(config, "SELECT_ITEM_COUNT", 0);
for (i = 0; i < state_config.select_item_count; i++) {
for (i = 0; i < state_config.select_item_codes.length; i++) {
sprintf(name, "SELECT_ITEM_%d", i + 1);
state_config.select_item_codes[i] =
state_config.select_item_codes.values[i] =
config_file_get_int(config, name, UNSET_MIDI_CODE);
}
frag_count = config_file_get_int(config, "FRAG_COUNT", 1);
state_config.state_max = state_config.select_page_codes.length *
state_config.select_item_codes.length;
for (i = 0; i < frag_count; i++) {
state_config.select_frag_codes.length =
config_file_get_int(config, "FRAG_COUNT", 1);
for (i = 0; i < state_config.select_frag_codes.length; i++) {
sprintf(name, "SELECT_FRAG_%d", i + 1);
state_config.select_frag_codes[i] =
state_config.select_frag_codes.values[i] =
config_file_get_int(config, name, UNSET_MIDI_CODE);
}
// TODO uint arrays
state_config.src_count = config_file_get_int(config, "SRC_COUNT", 0);
total = 0;
@@ -96,9 +102,44 @@ StateConfig state_parse_config(ConfigFile config) {
}
void state_apply_event(SharedContext *context, StateConfig state_config,
unsigned int state_count, MidiDevice midi,
unsigned char code, float value) {
log_debug("midi: %d %.2f", code, value);
MidiDevice midi, unsigned char code, float value) {
unsigned int index;
bool found;
found = false;
if (value > 0) {
index =
arr_uint_index_of(state_config.select_page_codes, (unsigned int)code);
// PAGE CHANGE
if (index != ARRAY_NOT_FOUND) {
context->page = index;
found = true;
}
index = arr_uint_index_of(state_config.select_frag_codes, code);
// TARGET CHANGE
if (index != ARRAY_NOT_FOUND) {
context->selected = index + 1;
found = true;
}
index = arr_uint_index_of(state_config.select_item_codes, code);
// ITEM CHANGE
if (index != ARRAY_NOT_FOUND) {
context->state[context->selected - 1] =
context->page * state_config.select_item_codes.length + index;
found = true;
}
}
if (!found) {
log_debug("unknown midi: %d %.2f", code, value);
}
midi_write(midi, code, value);
// TODO
}
@@ -127,12 +168,10 @@ bool state_background_midi_write(SharedContext *context,
return false;
}
void state_randomize(SharedContext *context, StateConfig state_config,
unsigned int state_count) {
void state_randomize(SharedContext *context, StateConfig state_config) {
unsigned int i;
for (i = 0; i < state_count; i++) {
context->state[i] = rand_uint(state_config.select_page_count *
state_config.select_item_count);
for (i = 0; i < state_config.select_frag_codes.length; i++) {
context->state[i] = rand_uint(state_config.state_max);
}
}
+2 -4
View File
@@ -6,13 +6,11 @@
StateConfig state_parse_config(ConfigFile config);
void state_apply_event(SharedContext *context, StateConfig state_config,
unsigned int state_count, MidiDevice midi,
unsigned char code, float value);
MidiDevice midi, unsigned char code, float value);
bool state_background_midi_write(SharedContext *context,
StateConfig state_config, MidiDevice midi);
void state_randomize(SharedContext *context, StateConfig state_config,
unsigned int state_count);
void state_randomize(SharedContext *context, StateConfig state_config);
#endif /* STATE_H */
+10 -5
View File
@@ -14,6 +14,11 @@
#ifndef TYPES_H
#define TYPES_H
typedef struct UintArray {
unsigned int values[ARRAY_SIZE];
unsigned int length;
} UintArray;
typedef struct Parameters {
bool hot_reload;
bool output;
@@ -135,14 +140,14 @@ typedef struct SharedContext {
} SharedContext;
typedef struct StateConfig {
unsigned int select_page_count;
unsigned int select_page_codes[ARRAY_SIZE];
unsigned int state_max;
unsigned int select_item_count;
unsigned int select_item_codes[ARRAY_SIZE];
UintArray select_page_codes;
UintArray select_item_codes;
unsigned int select_frag_codes[ARRAY_SIZE];
UintArray select_frag_codes;
// TODO Uint arrays
unsigned int src_count;
unsigned int src_active_counts[ARRAY_SIZE];
unsigned int src_active_offsets[ARRAY_SIZE];