- if( highlighted != zwindow->highlighted ) {
- highlighted = zwindow->highlighted;
- cvs->set_color(WHITE);
- cvs->set_inverse();
- cvs->draw_rectangle(0, 0, cvs->get_w(), cvs->get_h());
- cvs->draw_rectangle(1, 1, cvs->get_w() - 2, cvs->get_h() - 2);
- cvs->set_opaque();
- }
+ set_highlighted(zwindow->highlighted);
+ if( !playable ) set_playable(-1);
+ return 1;
+}
+
+void ZWindowGUI::set_highlighted(int v)
+{
+ if( highlighted == v ) return;
+ highlighted = v;
+ BC_WindowBase *cvs = canvas->get_canvas();
+ cvs->set_color(WHITE);
+ cvs->set_inverse();
+ cvs->draw_rectangle(0, 0, cvs->get_w(), cvs->get_h());
+ cvs->draw_rectangle(1, 1, cvs->get_w() - 2, cvs->get_h() - 2);
+ cvs->set_opaque();
+}
+
+void ZWindowGUI::set_playable(int v)
+{
+ if( playable == v ) return;
+ playable = v>0 ? 1 : 0;
+ zwindow->playable = playable;
+ BC_WindowBase *cvs = canvas->get_canvas();
+ cvs->set_color(WHITE);
+ cvs->set_inverse();
+ int dx = cvs->get_w()/16+1, dy = cvs->get_h()/16+1;
+ int x = xS(5), y = yS(5), lw = (dx + dy)/16+1;
+ cvs->set_line_width(lw);
+ cvs->draw_line(x, y, x+dx, y+dy);
+ cvs->draw_line(x, y+dy, x+dx, y);
+ cvs->set_opaque();
+ cvs->set_line_width(1);
+}
+
+
+ZWindowCanvasTileMixers::ZWindowCanvasTileMixers(ZWindowCanvas *canvas)
+ : BC_MenuItem(_("Tile Mixers"))
+{
+ this->canvas = canvas;
+}
+int ZWindowCanvasTileMixers::handle_event()
+{
+ canvas->mwindow->tile_mixers();
+ return 1;
+}
+
+ZWindowCanvasPlayable::ZWindowCanvasPlayable(ZWindowCanvas *canvas)
+ : BC_MenuItem(_("Playable"))
+{
+ this->canvas = canvas;
+ set_checked(canvas->gui->zwindow->playable);
+}
+int ZWindowCanvasPlayable::handle_event()
+{
+ int v = !get_checked() ? 1 : 0;
+ set_checked(v);
+ canvas->gui->set_playable(v);
+ canvas->get_canvas()->flash(1);