#include "edlsession.h"
#include "keys.h"
#include "language.h"
+#include "mainerror.h"
#include "mwindow.h"
+#include "mwindowgui.h"
#include "plugin.h"
#include "pluginserver.h"
#include "theme.h"
int w1 = italic->get_w();
add_tool(bold = new TitleBold(client, this, x, y + 50));
if( bold->get_w() > w1 ) w1 = bold->get_w();
+
add_tool(drag = new TitleDrag(client, this, x, y + 80));
if( drag->get_w() > w1 ) w1 = drag->get_w();
- if( client->config.drag )
- grab(client->server->mwindow->cwindow->gui);
+ if( client->config.drag ) {
+ if( !grab(client->server->mwindow->cwindow->gui) )
+ eprintf("drag enabled, but compositor already grabbed\n");
+ }
x += w1 + margin;
add_tool(justify_title = new BC_Title(x, y, _("Justify:")));
int TitleWindow::grab_event(XEvent *event)
{
+ switch( event->type ) {
+ case ButtonPress: break;
+ case ButtonRelease: break;
+ case MotionNotify: break;
+ default: return 0;
+ }
+
+ MWindow *mwindow = client->server->mwindow;
+ CWindowGUI *cwindow_gui = mwindow->cwindow->gui;
+ CWindowCanvas *canvas = cwindow_gui->canvas;
+ int cx, cy; cwindow_gui->get_relative_cursor(cx, cy);
+ cx -= mwindow->theme->ccanvas_x;
+ cy -= mwindow->theme->ccanvas_y;
+
+ if( !dragging ) {
+ if( cx < 0 || cx >= mwindow->theme->ccanvas_w ) return 0;
+ if( cy < 0 || cy >= mwindow->theme->ccanvas_h ) return 0;
+ }
+
switch( event->type ) {
case ButtonPress:
if( !dragging ) break;
dragging = 0;
return 1;
case MotionNotify:
- if( dragging ) break;
+ if( !dragging ) return 0;
+ break;
default:
return 0;
}
- MWindow *mwindow = client->server->mwindow;
- CWindowGUI *cwindow_gui = mwindow->cwindow->gui;
- CWindowCanvas *canvas = cwindow_gui->canvas;
- float cursor_x = canvas->get_canvas()->get_relative_cursor_x();
- float cursor_y = canvas->get_canvas()->get_relative_cursor_y();
+
+ float cursor_x = cx, cursor_y = cy;
canvas->canvas_to_output(mwindow->edl, 0, cursor_x, cursor_y);
int64_t position = client->get_source_position();
float projector_x, projector_y, projector_z;
int y0 = title_y, y1 = title_y+(title_h+1)/2, y2 = title_y+title_h;
int drag_dx = 0, drag_dy = 0;
if( !dragging ) { // clockwise
- if( abs(drag_dx = cursor_x-x0) < r && // x0,y0
+ if( abs(drag_dx = cursor_x-x0) < r && // x0,y0
abs(drag_dy = cursor_y-y0) < r ) dragging = 1;
else if( abs(drag_dx = cursor_x-x1) < r && // x1,y0
abs(drag_dy = cursor_y-y0) < r ) dragging = 2;
if( text_len >= avail ) { // back off last utf8 char
char text[2*sizeof(client->config.wtext)];
strcpy(text, get_text());
- text_len = avail;
- while( text_len > 0 && (text[text_len-1] & 0xc0) == 0x80 )
- text[--text_len] = 0;
- if( text_len > 0 )
- text[--text_len] = 0;
+ text_len = avail;
+ while( text_len > 0 && (text[text_len-1] & 0xc0) == 0x80 )
+ text[--text_len] = 0;
+ if( text_len > 0 )
+ text[--text_len] = 0;
update(text);
}
int len = sizeof(client->config.wtext) / sizeof(wchar_t);
int TitleDrag::handle_event()
{
int value = get_value();
- client->config.drag = value;
- if( value )
- window->grab(client->server->mwindow->cwindow->gui);
+ CWindowGUI *cwindow_gui = client->server->mwindow->cwindow->gui;
+ if( value ) {
+ if( !window->grab(cwindow_gui) ) {
+ update(value = 0);
+ flicker(10,50);
+ }
+ }
else
- window->ungrab(client->server->mwindow->cwindow->gui);
+ window->ungrab(cwindow_gui);
+ client->config.drag = value;
client->send_configure_change();
return 1;
}
switch( popup_type ) {
case POPUP_FONT: {
int px, py;
- window->get_pop_cursor_xy(px ,py);
+ window->get_pop_cursor(px ,py);
window->fonts_popup->activate(px, py, 300,200);
return 1; }
case POPUP_COLOR: {
BC_Window *TitlePngPopup::new_gui()
{
- BC_DisplayInfo display_info;
- int x = display_info.get_abs_cursor_x();
- int y = display_info.get_abs_cursor_y();
+ MWindow *mwindow = client->server->mwindow;
+ int x, y; mwindow->gui->get_abs_cursor(x, y);
- BC_Window *gui = new BrowseButtonWindow(client->server->mwindow->theme,
+ BC_Window *gui = new BrowseButtonWindow(mwindow->theme,
x-25, y-100, window, "", _("Png file"), _("Png path"), 0);
- gui->create_objects();
+ gui->create_objects();
return gui;
}