mirror of
git://projects.qi-hardware.com/vido.git
synced 2025-01-03 15:50:15 +02:00
add motion event
Signed-off-by: Mirko Lindner <mirko@sharism.cc>
This commit is contained in:
parent
7a95279f5e
commit
12b07510fb
@ -28,6 +28,12 @@
|
||||
#include "vido.hh"
|
||||
#include <cxxtools/log.h>
|
||||
|
||||
// extern "C" {
|
||||
// #include <directfb/directfb.h>
|
||||
// #include <gtk-2.0/gdk/gdkdisplay-directfb.h>
|
||||
// #include <gtk-2.0/gdk/gdkdirectfb.h>
|
||||
// }
|
||||
|
||||
log_define("vido.main_window");
|
||||
|
||||
main_window::main_window()
|
||||
@ -39,14 +45,19 @@ main_window::main_window()
|
||||
|
||||
void main_window::connect_all()
|
||||
{
|
||||
(*this).add_events( Gdk::BUTTON_PRESS_MASK ) ;
|
||||
// (*this).add_events( Gdk::BUTTON_PRESS_MASK ) ;
|
||||
log_debug("connecting all");
|
||||
// (*this).press_id = signal_key_press_event().connect(sigc::mem_fun(*this,&main_window::on_my_key_press_event));
|
||||
// (*this).release_id = signal_key_release_event().connect(sigc::mem_fun(*this,&main_window::on_my_key_release_event));
|
||||
// (*this).press_id =
|
||||
|
||||
(*this).add_events (Gdk::ALL_EVENTS_MASK);
|
||||
|
||||
(*this).press_id = (*this).signal_key_press_event().connect_notify(sigc::mem_fun(*this,&main_window::on_notify_key_press_event));
|
||||
(*this).release_id = (*this).signal_key_press_event().connect_notify(sigc::mem_fun(*this,&main_window::on_notify_key_release_event));
|
||||
(*this).release_id = (*this).signal_key_release_event().connect_notify(sigc::mem_fun(*this,&main_window::on_notify_key_release_event));
|
||||
// (*this).motion_id = (*this).signal_event().connect_notify(sigc::mem_fun(*this,&main_window::on_notify_motion_notify_event));
|
||||
log_debug((*this).press_id << " " << (*this).release_id);
|
||||
log_debug("event mask " << (*this).get_events());
|
||||
}
|
||||
|
||||
void main_window::disconnect_all()
|
||||
@ -57,6 +68,138 @@ void main_window::disconnect_all()
|
||||
log_debug((*this).press_id << " " << (*this).release_id);
|
||||
}
|
||||
|
||||
void main_window::on_notify_motion_notify_event ( GdkEvent *event)
|
||||
{
|
||||
// gdouble x, y;
|
||||
// gdouble pressure;
|
||||
// GdkModifierType state;
|
||||
//
|
||||
// if (event->is_hint)
|
||||
// gdk_input_window_get_pointer (event->window, event->deviceid,
|
||||
// &x, &y, &pressure, NULL, NULL, &state);
|
||||
// else
|
||||
// {
|
||||
// x = event->x;
|
||||
// y = event->y;
|
||||
// pressure = event->pressure;
|
||||
// state = event->state;
|
||||
// }
|
||||
//
|
||||
// if (state & GDK_BUTTON1_MASK && pixmap != NULL)
|
||||
// draw_brush (widget, event->source, x, y, pressure);
|
||||
//
|
||||
log_debug("event here " << event->type);
|
||||
// return TRUE;
|
||||
}
|
||||
|
||||
|
||||
void main_window::move_cursor(int direction){
|
||||
|
||||
int x=0, y=0, xadd=0, yadd=0;
|
||||
Glib::RefPtr<Gdk::Display> display;
|
||||
display = display->get_default();
|
||||
Glib::RefPtr<Gdk::Screen> screen = display->get_default_screen();
|
||||
// screen = display->get_default_screen();
|
||||
log_debug("display: " << display);
|
||||
log_debug("screen: " << screen);
|
||||
/* check for up/down/left/right arrow key press */
|
||||
log_debug("moving " << direction);
|
||||
switch (direction)
|
||||
{
|
||||
case 65361:
|
||||
xadd -= 5;
|
||||
break;
|
||||
case 65363:
|
||||
xadd += 5;
|
||||
break;
|
||||
case 65362:
|
||||
yadd -= 5;
|
||||
break;
|
||||
case 65364:
|
||||
yadd += 5;
|
||||
break;
|
||||
default:
|
||||
log_debug("unknown direction");
|
||||
break;
|
||||
// return FALSE; /* propogate event */
|
||||
}
|
||||
|
||||
/* get default display and screen */
|
||||
// display = Gdk::Display::get_default();
|
||||
// screen =Gdk::Display::get_default_screen();
|
||||
// screen = gdk_display_get_default_screen (display);
|
||||
|
||||
/* get cursor position */
|
||||
// GdkWindow* ;
|
||||
// IDirectFBWindow *gdk_directfb_window_lookup(gtk_widget_get_root_window(scrolled_window2));
|
||||
// GdkDisplay gdk_display_open((const gchar) display->get_name());
|
||||
Gdk::ModifierType mask;
|
||||
// display->get_pointer(x, y, mask);
|
||||
// log_debug("unknown direction 2");
|
||||
|
||||
/* set new cusor position */
|
||||
// x += xadd;
|
||||
// y += yadd;
|
||||
// IDirectFB *directfb;
|
||||
// log_debug("unknown direction 3");
|
||||
|
||||
|
||||
// GType _gdk_display = g_object_new (GDK_TYPE_DISPLAY_DFB, NULL);
|
||||
// display->directfb = directfb;
|
||||
|
||||
// IDirectFBDisplayLayer *layer;
|
||||
// int ret = directfb->GetDisplayLayer (directfb, DLID_PRIMARY, &layer);
|
||||
// log_debug("unknown direction 4");
|
||||
|
||||
// int ret = directfb->GetDisplayLayer (directfb, DLID_PRIMARY, &layer);
|
||||
|
||||
|
||||
// DFBResult result;
|
||||
// log_debug("unknown direction 5");
|
||||
//
|
||||
// result = layer->WarpCursor(layer, x, y);
|
||||
// log_debug("unknown direction 6");
|
||||
|
||||
// Gdk::ModifierType mask;
|
||||
display->get_pointer(x, y, mask);
|
||||
// log_debug("pointer x: " << x << "pointer y: " << display->pointer_hooks);
|
||||
|
||||
// display->warp_pointer( screen, x, y);
|
||||
|
||||
// Gdk::Event event();
|
||||
|
||||
// Gdk::Event event(gdk_event_new(GDK_MOTION_NOTIFY),true);
|
||||
//
|
||||
// // get_window_and_coordinates(event->button.window, event->button.x, event->button.y, event->button.x_root, event->button.y_root);
|
||||
// event.send_event = TRUE;
|
||||
// event.time = GDK_CURRENT_TIME;
|
||||
// event.axes = 0;
|
||||
// event.state = 0;
|
||||
// event.motion.x = x;
|
||||
// event.motion.y = y;
|
||||
// /* set new cusor position */
|
||||
x += xadd;
|
||||
y += yadd;
|
||||
// event.motion.x_root = x;
|
||||
// event.motion.y_root = y;
|
||||
// // event->button.button = Button;
|
||||
// // event->button.device = gdk_device_get_core_pointer();
|
||||
//
|
||||
// // g_object_ref(event->screen.window);
|
||||
// event.put();
|
||||
// handle_pending_events();
|
||||
// gdk_event_free(event);
|
||||
Glib::RefPtr<Gdk::Device> pointer = display->get_core_pointer();
|
||||
log_debug("type cursor: " << pointer->get_source());
|
||||
log_debug("pointer xadd: " << xadd << "pointer yadd: " << yadd );
|
||||
if ((screen != 0) && (display!= 0)){
|
||||
display->warp_pointer( screen, x, y);
|
||||
// this->signal_motion_notify_event();
|
||||
// g_signal_emit (G_OBJECT(display->gobj()), GDK_MOTION_NOTIFY, NULL, x= x, y = y);
|
||||
|
||||
}
|
||||
}
|
||||
|
||||
bool main_window::actions(int key)
|
||||
{
|
||||
// log_debug("in actions" << (*this).press_id << " " << (*this).release_id);
|
||||
@ -68,10 +211,10 @@ bool main_window::actions(int key)
|
||||
static int key_s = 115;
|
||||
static int key_t = 116;
|
||||
static int key_f1 = 65470;
|
||||
static int left = 65361;
|
||||
static int top = 65362;
|
||||
static int right = 65363;
|
||||
static int bottom = 65364;
|
||||
static int key_left = 65361;
|
||||
static int key_up = 65362;
|
||||
static int key_right = 65363;
|
||||
static int key_down = 65364;
|
||||
|
||||
|
||||
// key commands only available if ctrl pressed
|
||||
@ -81,7 +224,7 @@ bool main_window::actions(int key)
|
||||
if (key == key_q)
|
||||
{
|
||||
// log_debug("quit requested");
|
||||
quit();
|
||||
(*this).quit();
|
||||
}
|
||||
else if(key == key_r)
|
||||
{
|
||||
@ -100,7 +243,8 @@ bool main_window::actions(int key)
|
||||
history_jump(1);
|
||||
}else if(key == key_b){
|
||||
history_jump(-1);
|
||||
}else{
|
||||
}
|
||||
else{
|
||||
(*this).connect_all();
|
||||
// log_debug("key pressed: " << key);
|
||||
}
|
||||
@ -109,8 +253,18 @@ bool main_window::actions(int key)
|
||||
if(key == key_f1){
|
||||
(*this).disconnect_all();
|
||||
show_help();
|
||||
}else if(key == 65361){
|
||||
log_debug("key is left");
|
||||
(*this).move_cursor(key);
|
||||
}else if(key == key_right){
|
||||
(*this).move_cursor(key);
|
||||
}else if(key == key_up){
|
||||
(*this).move_cursor(key);
|
||||
}else if(key == key_down){
|
||||
(*this).move_cursor(key);
|
||||
}
|
||||
}
|
||||
|
||||
return true;
|
||||
|
||||
}
|
||||
@ -164,6 +318,6 @@ void main_window::on_notify_key_release_event(GdkEventKey *Key)
|
||||
|
||||
bool main_window::quit()
|
||||
{
|
||||
hide();
|
||||
(*this).destroy_();
|
||||
return false;
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user