/* -*- c++ -*- * Copyright (C) 2006-2017 Andreas Persson * * This program is free software; you can redistribute it and/or * modify it under the terms of the GNU General Public License as * published by the Free Software Foundation; either version 2, or (at * your option) any later version. * * This program is distributed in the hope that it will be useful, but * WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU * General Public License for more details. * * You should have received a copy of the GNU General Public License * along with program; see the file COPYING. If not, write to the Free * Software Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA * 02110-1301 USA. */ #ifndef GIGEDIT_REGIONCHOOSER_H #define GIGEDIT_REGIONCHOOSER_H #include #include "compat.h" #include #include #include #include #if USE_GTKMM_BUILDER # include #else # include // deprecated in gtkmm >= 3.21.4 #endif #include "dimensionmanager.h" #include "paramedit.h" #include "compat.h" #ifdef LIBGIG_HEADER_FILE # include LIBGIG_HEADER_FILE(gig.h) #else # include #endif enum virt_keyboard_mode_t { VIRT_KEYBOARD_MODE_NORMAL, VIRT_KEYBOARD_MODE_CHORD }; class SortedRegions { private: std::vector regions; std::vector::iterator region_iterator; public: void update(gig::Instrument* instrument); gig::Region* first(); gig::Region* next(); bool operator() (gig::Region* x, gig::Region* y) const { return x->KeyRange.low < y->KeyRange.low; } }; class RegionChooser : public Gtk::DrawingArea { public: RegionChooser(); virtual ~RegionChooser(); void set_instrument(gig::Instrument* instrument); // ATM only used for painting auto selected regions with gray hatched pattern void setModifyAllRegions(bool b); sigc::signal& signal_region_selected(); sigc::signal& signal_instrument_changed(); sigc::signal& signal_instrument_struct_to_be_changed(); sigc::signal& signal_instrument_struct_changed(); sigc::signal& signal_region_to_be_changed(); sigc::signal& signal_region_changed_signal(); sigc::signal& signal_keyboard_key_hit(); sigc::signal& signal_keyboard_key_released(); gig::Region* get_region() { return region; } void set_region(gig::Region* region); void select_next_region(); void select_prev_region(); void on_note_on_event(int key, int velocity); void on_note_off_event(int key, int velocity); HBox m_VirtKeybPropsBox; protected: #if (GTKMM_MAJOR_VERSION == 2 && GTKMM_MINOR_VERSION < 90) || GTKMM_MAJOR_VERSION < 2 virtual bool on_expose_event(GdkEventExpose* e); #else virtual bool on_draw(const Cairo::RefPtr& cr); #endif virtual bool on_button_press_event(GdkEventButton* event); virtual bool on_button_release_event(GdkEventButton* event); virtual bool on_motion_notify_event(GdkEventMotion* event); gig::Region* get_region(int key); Gdk::RGBA activeKeyColor, blue, grey1, white, black; Glib::RefPtr blueHatchedPatternARGB; Cairo::RefPtr blueHatchedSurfacePattern; sigc::signal region_selected; sigc::signal instrument_changed; sigc::signal instrument_struct_to_be_changed_signal; sigc::signal instrument_struct_changed_signal; sigc::signal region_to_be_changed_signal; sigc::signal region_changed_signal; sigc::signal keyboard_key_hit_signal; sigc::signal keyboard_key_released_signal; gig::Instrument* instrument; gig::Region* region; SortedRegions regions; bool is_black_key(int key); void draw_keyboard(const Cairo::RefPtr& cr, int clip_low, int clip_high); void draw_regions(const Cairo::RefPtr& cr, int clip_low, int clip_high); void draw_key(const Cairo::RefPtr& cr, int key); void draw_digit(const Cairo::RefPtr& cr, int key); void motion_resize_region(int x, int y); void motion_move_region(int x, int y); void update_after_resize(); void update_after_move(int pos); void invalidate_key(int key); void on_show_tooltips_changed(); // returns the leftmost pixel of a key int key_to_x(double k, int w) const { return int(k * w / 128.0 + 0.5); } // returns the key given a pixel int x_to_key(double x, int w) const { return int(x / w * 128.0); } // returns the key given a pixel. If the pixel is the border // between two keys, the key to the ríght is always returned. int x_to_key_right(double x, int w) const { return int(ceil((x + 0.5) / w * 128.0)) - 1; } // information needed during a resize struct { bool active; enum { undecided, moving_high_limit, moving_low_limit } mode; int pos; int min; int max; gig::Region* region; gig::Region* prev_region; } resize; // information needed during a region move struct { bool active; int offset; } move; bool cursor_is_resize; bool is_in_resize_zone(double x, double y); int h1; // ATM only used for painting auto selected regions with gray hatched pattern bool modifyallregions; Gtk::Menu* popup_menu_inside_region; Gtk::Menu* popup_menu_outside_region; void show_region_properties(); void add_region(); void delete_region(); void manage_dimensions(); void on_dimension_manager_changed(); int new_region_pos; Glib::RefPtr actionGroup; #if USE_GTKMM_BUILDER Glib::RefPtr uiManager; #else Glib::RefPtr uiManager; #endif // properties of the virtual keyboard ChoiceEntry m_VirtKeybModeChoice; Gtk::Label m_VirtKeybVelocityLabelDescr; Gtk::Label m_VirtKeybVelocityLabel; Gtk::Label m_VirtKeybOffVelocityLabelDescr; Gtk::Label m_VirtKeybOffVelocityLabel; int currentActiveKey; bool key_pressed[128]; DimensionManager dimensionManager; }; #endif