summaryrefslogtreecommitdiff
path: root/gtk2_ardour/dsp_load_indicator.cc
diff options
context:
space:
mode:
Diffstat (limited to 'gtk2_ardour/dsp_load_indicator.cc')
-rw-r--r--gtk2_ardour/dsp_load_indicator.cc119
1 files changed, 29 insertions, 90 deletions
diff --git a/gtk2_ardour/dsp_load_indicator.cc b/gtk2_ardour/dsp_load_indicator.cc
index bf033b7b32..f5b5afdadb 100644
--- a/gtk2_ardour/dsp_load_indicator.cc
+++ b/gtk2_ardour/dsp_load_indicator.cc
@@ -16,40 +16,18 @@
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
*/
-#include "gtkmm2ext/utils.h"
-#include "widgets/tooltips.h"
-
#include "ardour_ui.h"
#include "dsp_load_indicator.h"
-#include "ui_config.h"
#include "pbd/i18n.h"
#define PADDING 3
DspLoadIndicator::DspLoadIndicator ()
- : _dsp_load (0)
+ : ArdourGauge ("00.0%")
+ , _dsp_load (0)
, _xrun_count (0)
{
- _layout = Pango::Layout::create (get_pango_context ());
- _layout->set_text ("99.9%");
-}
-
-DspLoadIndicator::~DspLoadIndicator ()
-{
-}
-
-void
-DspLoadIndicator::on_size_request (Gtk::Requisition* req)
-{
- req->width = req->height = 0;
- CairoWidget::on_size_request (req);
-
- int w, h;
- _layout->get_pixel_size (w, h);
-
- req->width = std::max (req->width, std::max (12, h + PADDING));
- req->height = std::max (req->height, 20 /*std::max (20, w + PADDING) */);
}
void
@@ -59,8 +37,7 @@ DspLoadIndicator::set_xrun_count (const unsigned int xruns)
return;
}
_xrun_count = xruns;
- queue_draw ();
- update_tooltip ();
+ update ();
}
void
@@ -73,82 +50,44 @@ DspLoadIndicator::set_dsp_load (const double load)
char buf[64];
snprintf (buf, sizeof (buf), "%.1f%%", _dsp_load);
- _layout->set_text (buf);
+ update (std::string (buf));
+}
- queue_draw ();
- update_tooltip ();
+float
+DspLoadIndicator::level () const {
+ return _dsp_load / 100.f;
}
-void
-DspLoadIndicator::update_tooltip ()
+bool
+DspLoadIndicator::alert () const
{
- char buf[64];
- if (_xrun_count == UINT_MAX) {
- snprintf (buf, sizeof (buf), _("DSP: %.1f%% X: ?"), _dsp_load);
- } else if (_xrun_count > 9999) {
- snprintf (buf, sizeof (buf), _("DSP: %.1f%% X: >10k"), _dsp_load);
- } else {
- snprintf (buf, sizeof (buf), _("DSP: %.1f%% X: %u"), _dsp_load, _xrun_count);
- }
- ArdourWidgets::set_tooltip (*this, buf);
+ return _xrun_count > 0;
}
-void
-DspLoadIndicator::render (Cairo::RefPtr<Cairo::Context> const& ctx, cairo_rectangle_t*)
+ArdourGauge::Status
+DspLoadIndicator::indicator () const
{
- cairo_t* cr = ctx->cobj ();
- Gtkmm2ext::Color base = UIConfiguration::instance ().color ("ruler base");
- Gtkmm2ext::Color text = UIConfiguration::instance ().color ("ruler text");
-
- const int width = get_width ();
- const int height = get_height ();
-
- Gtkmm2ext::rounded_rectangle (cr, 0, 0, width, height, PADDING + 1);
- Gtkmm2ext::set_source_rgba (cr, base);
- cairo_fill (cr);
-
- if (_xrun_count > 0) {
- Gtkmm2ext::rounded_rectangle (cr, 1, 1, width - 2, height - 2, PADDING + 1);
- cairo_set_source_rgba (cr, 0.5, 0, 0, 1.0);
- cairo_fill (cr);
- }
-
- Gtkmm2ext::rounded_rectangle (cr, PADDING, PADDING, width - PADDING - PADDING, height - PADDING - PADDING, PADDING + 1);
- cairo_clip (cr);
-
- int bh = (height - PADDING - PADDING) * _dsp_load / 100.f;
- cairo_rectangle (cr, PADDING, height - PADDING - bh, width - PADDING, bh);
-
if (_dsp_load > 90) {
- cairo_set_source_rgba (cr, .9, 0, 0, 1.0);
+ return ArdourGauge::Level_OK;
} else if (_dsp_load > 80) {
- cairo_set_source_rgba (cr, .7, .6, 0, 1.0);
+ return ArdourGauge::Level_WARN;
} else {
- cairo_set_source_rgba (cr, 0, .5, 0, 1.0);
+ return ArdourGauge::Level_CRIT;
}
- cairo_fill (cr);
-
- int w, h;
- _layout->get_pixel_size (w, h);
-
- cairo_save (cr);
- cairo_new_path (cr);
- cairo_translate (cr, width * .5, height * .5);
- cairo_rotate (cr, M_PI * -.5);
-
- cairo_move_to (cr, w * -.5, h * -.5);
- pango_cairo_update_layout (cr, _layout->gobj());
- Gtkmm2ext::set_source_rgb_a (cr, base, 0.5);
- pango_cairo_layout_path (cr, _layout->gobj());
- cairo_set_line_width (cr, 1.5);
- cairo_stroke (cr);
-
- cairo_move_to (cr, w * -.5, h * -.5);
- pango_cairo_update_layout (cr, _layout->gobj());
- Gtkmm2ext::set_source_rgba (cr, text);
- pango_cairo_show_layout (cr, _layout->gobj());
+}
- cairo_restore (cr);
+std::string
+DspLoadIndicator::tooltip_text ()
+{
+ char buf[64];
+ if (_xrun_count == UINT_MAX) {
+ snprintf (buf, sizeof (buf), _("DSP: %.1f%% X: ?"), _dsp_load);
+ } else if (_xrun_count > 9999) {
+ snprintf (buf, sizeof (buf), _("DSP: %.1f%% X: >10k"), _dsp_load);
+ } else {
+ snprintf (buf, sizeof (buf), _("DSP: %.1f%% X: %u"), _dsp_load, _xrun_count);
+ }
+ return buf;
}
bool