X-Git-Url: https://git.sesse.net/?a=blobdiff_plain;f=futatabi%2Fmidi_mapper.h;h=84ff404b1f0b956830a475f4cf18318680a5e461;hb=f9024d141398e69e7b4011becd3ebbe37eaa1776;hp=2240e70ce7e55854028b40d885201388935f9bb2;hpb=fcae09355c1a00a68015b3d727339aebd2e52aa4;p=nageru diff --git a/futatabi/midi_mapper.h b/futatabi/midi_mapper.h index 2240e70..84ff404 100644 --- a/futatabi/midi_mapper.h +++ b/futatabi/midi_mapper.h @@ -31,6 +31,7 @@ public: virtual void preview() = 0; virtual void queue() = 0; virtual void play() = 0; + virtual void next() = 0; virtual void toggle_lock() = 0; virtual void jog(int delta) = 0; virtual void switch_camera(unsigned camera_idx) = 0; @@ -63,7 +64,7 @@ public: void refresh_lights(); - void set_preview_enabled(bool enabled) { + void set_preview_enabled(LightState enabled) { preview_enabled_light = enabled; refresh_lights(); } @@ -75,6 +76,10 @@ public: play_enabled_light = enabled; refresh_lights(); } + void set_next_ready(LightState enabled) { + next_ready_light = enabled; + refresh_lights(); + } void set_locked(LightState locked) { locked_light = locked; refresh_lights(); @@ -83,6 +88,10 @@ public: current_highlighted_camera = stream_idx; refresh_lights(); } + void set_speed_light(float speed) { // Goes from 0.0 to 2.0. + current_speed = speed; + refresh_lights(); + } // MIDIReceiver. void controller_received(int controller, int value) override; @@ -98,7 +107,6 @@ private: void update_lights_lock_held(); std::atomic should_quit{false}; - int should_quit_fd; mutable std::mutex mu; ControllerReceiver *receiver; // Under . @@ -106,11 +114,13 @@ private: int num_controller_banks; // Under . std::atomic current_controller_bank{0}; - std::atomic preview_enabled_light{false}; + std::atomic preview_enabled_light{Off}; std::atomic queue_enabled_light{false}; std::atomic play_enabled_light{Off}; + std::atomic next_ready_light{Off}; std::atomic locked_light{On}; std::atomic current_highlighted_camera{-1}; + std::atomic current_speed{1.0f}; MIDIDevice midi_device; };