#include <list>
#include "pbd/error.h"
+#include "pbd/convert.h"
#include <gtkmm2ext/utils.h>
#include <gtkmm2ext/selector.h>
#include <gtkmm2ext/gtk_ui.h>
-#include "ardour/session.h"
-#include "ardour/utils.h"
-
#include "public_editor.h"
+#include "ardour_ui.h"
+#include "gui_object.h"
#include "axis_view.h"
+#include "utils.h"
#include "i18n.h"
using namespace std;
using namespace Gtk;
using namespace Gtkmm2ext;
using namespace ARDOUR;
+using namespace ARDOUR_UI_UTILS;
list<Gdk::Color> AxisView::used_colors;
-AxisView::AxisView (ARDOUR::Session* sess)
+AxisView::AxisView (ARDOUR::Session* sess)
: SessionHandlePtr (sess)
{
_selected = false;
- _marked_for_display = false;
}
AxisView::~AxisView()
Gdk::Color
AxisView::unique_random_color()
{
- Gdk::Color newcolor;
-
- while (1) {
-
- /* avoid neon/glowing tones by limiting them to the
- "inner section" (paler) of a color wheel/circle.
- */
-
- const int32_t max_saturation = 48000; // 65535 would open up the whole color wheel
-
- newcolor.set_red (random() % max_saturation);
- newcolor.set_blue (random() % max_saturation);
- newcolor.set_green (random() % max_saturation);
-
- if (used_colors.size() == 0) {
- used_colors.push_back (newcolor);
- return newcolor;
- }
-
- for (list<Gdk::Color>::iterator i = used_colors.begin(); i != used_colors.end(); ++i) {
- Gdk::Color c = *i;
- float rdelta, bdelta, gdelta;
+ return ::unique_random_color (used_colors);
+}
- rdelta = newcolor.get_red() - c.get_red();
- bdelta = newcolor.get_blue() - c.get_blue();
- gdelta = newcolor.get_green() - c.get_green();
+string
+AxisView::gui_property (const string& property_name) const
+{
+ if (property_hashtable.count(property_name)) {
+ return property_hashtable[property_name];
+ } else {
+ string rv = gui_object_state().get_string (state_id(), property_name);
+ property_hashtable.erase(property_name);
+ property_hashtable.emplace(property_name, rv);
+ return rv;
+ }
+}
- if (sqrt (rdelta*rdelta + bdelta*bdelta + gdelta*gdelta) > 25.0) {
- used_colors.push_back (newcolor);
- return newcolor;
- }
- }
+bool
+AxisView::marked_for_display () const
+{
+ string const v = gui_property ("visible");
+ return (v == "" || PBD::string_is_affirmative (v));
+}
- /* XXX need throttle here to make sure we don't spin for ever */
+bool
+AxisView::set_marked_for_display (bool yn)
+{
+ string const v = gui_property ("visible");
+ if (v == "" || yn != PBD::string_is_affirmative (v)) {
+ set_gui_property ("visible", yn);
+ return true; // things changed
}
+ return false;
+}
+
+GUIObjectState&
+AxisView::gui_object_state()
+{
+ return *ARDOUR_UI::instance()->gui_object_state;
}