mirror of
git://projects.qi-hardware.com/vido.git
synced 2024-12-23 01:43:19 +02:00
rest of development stuff
Signed-off-by: Mirko Lindner <mirko@sharism.cc>
This commit is contained in:
parent
12b07510fb
commit
d1a53711e7
@ -35,7 +35,8 @@
|
|||||||
// }
|
// }
|
||||||
|
|
||||||
log_define("vido.main_window");
|
log_define("vido.main_window");
|
||||||
|
int x=-1, y=-1;
|
||||||
|
int ctrl_state;
|
||||||
main_window::main_window()
|
main_window::main_window()
|
||||||
{
|
{
|
||||||
sigc::connection press_id;
|
sigc::connection press_id;
|
||||||
@ -45,19 +46,15 @@ main_window::main_window()
|
|||||||
|
|
||||||
void main_window::connect_all()
|
void main_window::connect_all()
|
||||||
{
|
{
|
||||||
// (*this).add_events( Gdk::BUTTON_PRESS_MASK ) ;
|
(*this).add_events( Gdk::ALL_EVENTS_MASK ) ;
|
||||||
log_debug("connecting all");
|
log_debug("connecting all");
|
||||||
// (*this).press_id = signal_key_press_event().connect(sigc::mem_fun(*this,&main_window::on_my_key_press_event));
|
// (*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).release_id = signal_key_release_event().connect(sigc::mem_fun(*this,&main_window::on_my_key_release_event));
|
||||||
// (*this).press_id =
|
// (*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).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_release_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));
|
(*this).motion_id = (*this).signal_event().connect_notify(sigc::mem_fun(*this,&main_window::motion_notify_event));
|
||||||
log_debug((*this).press_id << " " << (*this).release_id);
|
log_debug((*this).press_id << " " << (*this).release_id);
|
||||||
log_debug("event mask " << (*this).get_events());
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void main_window::disconnect_all()
|
void main_window::disconnect_all()
|
||||||
@ -68,7 +65,7 @@ void main_window::disconnect_all()
|
|||||||
log_debug((*this).press_id << " " << (*this).release_id);
|
log_debug((*this).press_id << " " << (*this).release_id);
|
||||||
}
|
}
|
||||||
|
|
||||||
void main_window::on_notify_motion_notify_event ( GdkEvent *event)
|
void main_window::motion_notify_event ( GdkEvent *event)
|
||||||
{
|
{
|
||||||
// gdouble x, y;
|
// gdouble x, y;
|
||||||
// gdouble pressure;
|
// gdouble pressure;
|
||||||
@ -95,11 +92,11 @@ void main_window::on_notify_motion_notify_event ( GdkEvent *event)
|
|||||||
|
|
||||||
void main_window::move_cursor(int direction){
|
void main_window::move_cursor(int direction){
|
||||||
|
|
||||||
int x=0, y=0, xadd=0, yadd=0;
|
int xadd=0, yadd=0;
|
||||||
Glib::RefPtr<Gdk::Display> display;
|
Glib::RefPtr<Gdk::Display> display;
|
||||||
display = display->get_default();
|
// display = display->get_default();
|
||||||
Glib::RefPtr<Gdk::Screen> screen = display->get_default_screen();
|
Glib::RefPtr<Gdk::Screen> screen = this->get_screen();
|
||||||
// screen = display->get_default_screen();
|
display = screen->get_display();
|
||||||
log_debug("display: " << display);
|
log_debug("display: " << display);
|
||||||
log_debug("screen: " << screen);
|
log_debug("screen: " << screen);
|
||||||
/* check for up/down/left/right arrow key press */
|
/* check for up/down/left/right arrow key press */
|
||||||
@ -161,27 +158,44 @@ void main_window::move_cursor(int direction){
|
|||||||
// log_debug("unknown direction 6");
|
// log_debug("unknown direction 6");
|
||||||
|
|
||||||
// Gdk::ModifierType mask;
|
// Gdk::ModifierType mask;
|
||||||
|
// if ((x==-1) && (y==-1)){
|
||||||
display->get_pointer(x, y, mask);
|
display->get_pointer(x, y, mask);
|
||||||
// log_debug("pointer x: " << x << "pointer y: " << display->pointer_hooks);
|
// }
|
||||||
|
|
||||||
|
log_debug("pointer x: " << x << "pointer y: " << y );
|
||||||
|
|
||||||
// display->warp_pointer( screen, x, y);
|
// display->warp_pointer( screen, x, y);
|
||||||
|
|
||||||
// Gdk::Event event();
|
GdkEvent *event1 = display->peek_event();
|
||||||
|
if (event1 != NULL){
|
||||||
|
log_debug("event type: " << event1->type);
|
||||||
|
}else{
|
||||||
|
log_debug("no 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);
|
// // 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;
|
// GdkEventType type;
|
||||||
// event.time = GDK_CURRENT_TIME;
|
// GdkWindow *window;
|
||||||
// event.axes = 0;
|
// gint8 send_event;
|
||||||
// event.state = 0;
|
// guint32 time;
|
||||||
// event.motion.x = x;
|
// gdouble x;
|
||||||
// event.motion.y = y;
|
// gdouble y;
|
||||||
|
// gdouble *axes;
|
||||||
|
// guint state;
|
||||||
|
// gint16 is_hint;
|
||||||
|
// GdkDevice *device;
|
||||||
|
// gdouble x_root, y_root;
|
||||||
|
|
||||||
|
// event->type = Gdk::MOTION_NOTIFY;
|
||||||
|
|
||||||
|
|
||||||
|
// event.y = y;
|
||||||
// /* set new cusor position */
|
// /* set new cusor position */
|
||||||
|
|
||||||
|
|
||||||
x += xadd;
|
x += xadd;
|
||||||
y += yadd;
|
y += yadd;
|
||||||
// event.motion.x_root = x;
|
|
||||||
// event.motion.y_root = y;
|
|
||||||
// // event->button.button = Button;
|
// // event->button.button = Button;
|
||||||
// // event->button.device = gdk_device_get_core_pointer();
|
// // event->button.device = gdk_device_get_core_pointer();
|
||||||
//
|
//
|
||||||
@ -189,20 +203,33 @@ void main_window::move_cursor(int direction){
|
|||||||
// event.put();
|
// event.put();
|
||||||
// handle_pending_events();
|
// handle_pending_events();
|
||||||
// gdk_event_free(event);
|
// gdk_event_free(event);
|
||||||
Glib::RefPtr<Gdk::Device> pointer = display->get_core_pointer();
|
// Glib::RefPtr<Gdk::Device> pointer = display->get_core_pointer();
|
||||||
log_debug("type cursor: " << pointer->get_source());
|
// log_debug("type cursor: " << pointer->type);
|
||||||
log_debug("pointer xadd: " << xadd << "pointer yadd: " << yadd );
|
log_debug("pointer xadd: " << xadd << "pointer yadd: " << yadd );
|
||||||
if ((screen != 0) && (display!= 0)){
|
if ((screen != 0) && (display!= 0)){
|
||||||
display->warp_pointer( screen, x, y);
|
display->warp_pointer( screen, x, y);
|
||||||
|
// GdkEvent *event = gdk_event_new(GDK_MOTION_NOTIFY);
|
||||||
|
// Glib::RefPtr<Gdk::Window> window = display->get_window_at_pointer(x, y);
|
||||||
|
// Glib::RefPtr<Gdk::Device> pointer = display->get_core_pointer ();
|
||||||
|
// event->motion.window = window->gobj();
|
||||||
|
// event->motion.send_event = 1;
|
||||||
|
// event->motion.time = GDK_CURRENT_TIME;
|
||||||
|
// event->motion.x = xadd;
|
||||||
|
// event->motion.y = yadd;
|
||||||
|
// event->motion.axes = 0;
|
||||||
|
// event->motion.state = 0;
|
||||||
|
// event->motion.is_hint = 0;
|
||||||
|
// event->motion.device = pointer->gobj();
|
||||||
|
// event->motion.x_root = xadd;
|
||||||
|
// event->motion.y_root = yadd;
|
||||||
|
// display->put_event(event);
|
||||||
// this->signal_motion_notify_event();
|
// 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)
|
bool main_window::actions(int key)
|
||||||
{
|
{
|
||||||
// log_debug("in actions" << (*this).press_id << " " << (*this).release_id);
|
log_debug("in actions " << (*this).press_id << " " << (*this).release_id << "control state " << ctrl_state);
|
||||||
static int key_b = 98;
|
static int key_b = 98;
|
||||||
static int key_f = 102;
|
static int key_f = 102;
|
||||||
static int key_h = 104;
|
static int key_h = 104;
|
||||||
@ -228,7 +255,7 @@ bool main_window::actions(int key)
|
|||||||
}
|
}
|
||||||
else if(key == key_r)
|
else if(key == key_r)
|
||||||
{
|
{
|
||||||
// log_debug("random");
|
log_debug("random");
|
||||||
show_random();
|
show_random();
|
||||||
}
|
}
|
||||||
else if(key == key_s)
|
else if(key == key_s)
|
||||||
@ -272,21 +299,23 @@ bool main_window::actions(int key)
|
|||||||
void main_window::on_notify_key_press_event(GdkEventKey *Key)
|
void main_window::on_notify_key_press_event(GdkEventKey *Key)
|
||||||
{
|
{
|
||||||
|
|
||||||
if (Key->keyval == gdk_keyval_from_name("Control_R"))
|
if (Key->keyval == 65508)
|
||||||
{
|
{
|
||||||
|
log_debug("setting ctrl state 1");
|
||||||
ctrl_state = 1;
|
ctrl_state = 1;
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
actions(Key->keyval);
|
(*this).actions(Key->keyval);
|
||||||
}
|
}
|
||||||
log_debug("Key Presssed is " << Key->keyval);
|
log_debug("Key Presssed is " << Key->keyval);
|
||||||
}
|
}
|
||||||
|
|
||||||
void main_window::on_notify_key_release_event(GdkEventKey *Key)
|
void main_window::on_notify_key_release_event(GdkEventKey *Key)
|
||||||
{
|
{
|
||||||
if (Key->keyval == gdk_keyval_from_name("Control_R"))
|
if (Key->keyval == 65508)
|
||||||
{
|
{
|
||||||
|
log_debug("setting ctrl state 0");
|
||||||
ctrl_state = 0;
|
ctrl_state = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -29,15 +29,18 @@ class main_window : public Gtk::Window
|
|||||||
main_window();
|
main_window();
|
||||||
sigc::connection press_id;
|
sigc::connection press_id;
|
||||||
sigc::connection release_id;
|
sigc::connection release_id;
|
||||||
|
sigc::connection motion_id;
|
||||||
void connect_all();
|
void connect_all();
|
||||||
void disconnect_all();
|
void disconnect_all();
|
||||||
|
|
||||||
private:
|
private:
|
||||||
bool actions(int);
|
bool actions(int);
|
||||||
int ctrl_state;
|
int ctrl_state;
|
||||||
|
void move_cursor(int direction);
|
||||||
// bool on_my_key_press_event(GdkEventKey *event);
|
// bool on_my_key_press_event(GdkEventKey *event);
|
||||||
void on_notify_key_press_event(GdkEventKey *event);
|
void on_notify_key_press_event(GdkEventKey *event);
|
||||||
void on_notify_key_release_event(GdkEventKey *event);
|
void on_notify_key_release_event(GdkEventKey *event);
|
||||||
|
void motion_notify_event(GdkEvent *event);
|
||||||
// bool on_my_key_release_event(GdkEventKey *event);
|
// bool on_my_key_release_event(GdkEventKey *event);
|
||||||
bool quit();
|
bool quit();
|
||||||
};
|
};
|
||||||
|
10
src/vido.cc
10
src/vido.cc
@ -438,6 +438,11 @@ bool on_link_clicked(GtkHTML *html, const gchar *url)
|
|||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void motion( GdkEventMotion *event)
|
||||||
|
{
|
||||||
|
log_debug("motion");
|
||||||
|
}
|
||||||
|
|
||||||
bool scrolled(GtkHTML *cb_html, GtkOrientation orientation, GtkScrollType scroll_type, gfloat position)
|
bool scrolled(GtkHTML *cb_html, GtkOrientation orientation, GtkScrollType scroll_type, gfloat position)
|
||||||
{
|
{
|
||||||
log_debug("scrolled");
|
log_debug("scrolled");
|
||||||
@ -461,6 +466,7 @@ int main(int argc, char **argv)
|
|||||||
Gtk::Main kit(argc, argv);
|
Gtk::Main kit(argc, argv);
|
||||||
|
|
||||||
main_window window;
|
main_window window;
|
||||||
|
window.add_modal_grab();
|
||||||
window.set_title("Vido");
|
window.set_title("Vido");
|
||||||
// window.set_border_width(0);
|
// window.set_border_width(0);
|
||||||
window.set_default_size(220, 240);
|
window.set_default_size(220, 240);
|
||||||
@ -473,8 +479,12 @@ int main(int argc, char **argv)
|
|||||||
g_signal_connect( G_OBJECT( html_wg ), "scroll", G_CALLBACK( scrolled ), NULL );
|
g_signal_connect( G_OBJECT( html_wg ), "scroll", G_CALLBACK( scrolled ), NULL );
|
||||||
gtk_html_set_caret_mode(GTK_HTML(html_wg),false);
|
gtk_html_set_caret_mode(GTK_HTML(html_wg),false);
|
||||||
// gtk_html_adjust_cursor_position(GTK_HTML(html_wg));
|
// gtk_html_adjust_cursor_position(GTK_HTML(html_wg));
|
||||||
|
gtk_widget_set_events(html_wg, 0x3FFFFE);
|
||||||
|
gtk_signal_connect (GTK_OBJECT (html_wg), "motion_notify_event",
|
||||||
|
GTK_SIGNAL_FUNC (motion), NULL);
|
||||||
Gtk::ScrolledWindow scrolled_window;
|
Gtk::ScrolledWindow scrolled_window;
|
||||||
scrolled_window2 = &scrolled_window;
|
scrolled_window2 = &scrolled_window;
|
||||||
|
scrolled_window.set_resize_mode(Gtk::RESIZE_PARENT);
|
||||||
scrolled_window.add(*html);
|
scrolled_window.add(*html);
|
||||||
scrolled_window.set_policy(Gtk::POLICY_NEVER, Gtk::POLICY_AUTOMATIC);
|
scrolled_window.set_policy(Gtk::POLICY_NEVER, Gtk::POLICY_AUTOMATIC);
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user