X-Git-Url: https://main.carlh.net/gitweb/?a=blobdiff_plain;ds=sidebyside;f=gtk2_ardour%2Ftempo_dialog.h;h=38c14e8b273d2ed30f9c98f6c620eb42ea928fa8;hb=ba82e673fd4435065ae9689411d7ed0d232b8cde;hp=89f93016a2500e38c5b2eb08cceebeb9e1ecdcff;hpb=7898435d3f94355fa0996dc9f85b3bc1ef173585;p=ardour.git diff --git a/gtk2_ardour/tempo_dialog.h b/gtk2_ardour/tempo_dialog.h index 89f93016a2..38c14e8b27 100644 --- a/gtk2_ardour/tempo_dialog.h +++ b/gtk2_ardour/tempo_dialog.h @@ -39,15 +39,16 @@ class TempoDialog : public ArdourDialog { public: TempoDialog (ARDOUR::TempoMap&, framepos_t, const std::string & action); - TempoDialog (ARDOUR::TempoSection&, const std::string & action); + TempoDialog (ARDOUR::TempoMap&, ARDOUR::TempoSection&, const std::string & action); double get_bpm (); double get_note_type (); bool get_bbt_time (Timecode::BBT_Time&); ARDOUR::TempoSection::Type get_tempo_type (); + ARDOUR::PositionLockStyle get_lock_style (); private: - void init (const Timecode::BBT_Time& start, double, double, bool); + void init (const Timecode::BBT_Time& start, double bpm , double note_type, ARDOUR::TempoSection::Type type, bool movable, ARDOUR::PositionLockStyle style); bool is_user_input_valid() const; void bpm_changed (); bool bpm_button_press (GdkEventButton* ); @@ -55,6 +56,7 @@ private: bool entry_key_release (GdkEventKey* ); void pulse_change (); void tempo_type_change (); + void lock_style_change (); bool tap_tempo_button_press (GdkEventButton* ); bool tap_tempo_focus_out (GdkEventFocus* ); @@ -64,12 +66,18 @@ private: typedef std::map TempoTypes; TempoTypes tempo_types; + typedef std::map LockStyles; + LockStyles lock_styles; + bool tapped; // whether the tap-tempo button has been clicked double sum_x, sum_xx, sum_xy, sum_y; double tap_count; double last_t; gint64 first_t; + ARDOUR::TempoMap* _map; + ARDOUR::TempoSection* _section; + Gtk::ComboBoxText pulse_selector; Gtk::Adjustment bpm_adjustment; Gtk::SpinButton bpm_spinner; @@ -80,7 +88,7 @@ private: Gtk::Label pulse_selector_label; Gtk::Button tap_tempo_button; Gtk::ComboBoxText tempo_type; - + Gtk::ComboBoxText lock_style; }; class MeterDialog : public ArdourDialog @@ -88,24 +96,30 @@ class MeterDialog : public ArdourDialog public: MeterDialog (ARDOUR::TempoMap&, framepos_t, const std::string & action); - MeterDialog (ARDOUR::MeterSection&, const std::string & action); + MeterDialog (ARDOUR::TempoMap&, ARDOUR::MeterSection&, const std::string & action); double get_bpb (); double get_note_type (); + ARDOUR::PositionLockStyle get_lock_style (); bool get_bbt_time (Timecode::BBT_Time&); private: - void init (const Timecode::BBT_Time&, double, double, bool); + void init (const Timecode::BBT_Time&, double, double, bool, ARDOUR::PositionLockStyle style); bool is_user_input_valid() const; bool entry_key_press (GdkEventKey* ); bool entry_key_release (GdkEventKey* ); void note_type_change (); + void lock_style_change (); typedef std::map NoteTypes; NoteTypes note_types; + typedef std::map LockStyles; + LockStyles lock_styles; + Gtk::Entry bpb_entry; Gtk::ComboBoxText note_type; + Gtk::ComboBoxText lock_style; std::vector strings; Gtk::Button ok_button; Gtk::Button cancel_button;