]> git.llucax.com Git - z.facultad/75.42/plaqui.git/commitdiff
agrego icono cuando se mueve un item en el workplace
authorRicardo Markiewicz <gazer.arg@gmail.com>
Tue, 14 Oct 2003 05:26:43 +0000 (05:26 +0000)
committerRicardo Markiewicz <gazer.arg@gmail.com>
Tue, 14 Oct 2003 05:26:43 +0000 (05:26 +0000)
tests/GUI/dndwindow.cc
tests/GUI/dndwindow.h
tests/GUI/item.h

index 47a18d4102670126af01fad1143780d98fd4e27a..9aaf567dcab7dd10baa381ecfa17a015e417cb8c 100644 (file)
@@ -19,8 +19,6 @@
 #include "dndwindow.h"
 #include <iostream>
 
-Glib::RefPtr<Gdk::Pixbuf> ico_canio, ico_y, ico_codo;
-
 DnDWindow::DnDWindow()
 : m_Button_Canio("Drag Canio\n"),
   m_Button_Y("Drop Y\n"),
@@ -145,23 +143,31 @@ void DnDWindow::on_label_drop_drag_data_received(const Glib::RefPtr<Gdk::DragCon
        // El Drag es desde la barra de tareas
   if ((selection_data->length >= 0) && (selection_data->format == 8))
   {
-       CItem *a = Gtk::manage( new CItem((const char *)selection_data->data) );
-       m_WorkPlace.put(*a, i*32, j*32);
-       // Seteo la lista de tipos de drags 
-       a->drag_source_set(listTargets);
-       // Conecto las señales
-       a->signal_drag_data_get().connect( SigC::slot(*this, &DnDWindow::on_item_drag_data_get));
-  a->signal_drag_begin().connect( SigC::slot(*this, &DnDWindow::on_item_drag_begin));
-       a->show();      
-       //listaItems.push_back(a);
+               CItem *a = Gtk::manage( new CItem((const char *)selection_data->data) );
+               m_WorkPlace.put(*a, i*32, j*32);
+               // Seteo la lista de tipos de drags 
+               a->drag_source_set(listTargets);
+               // Conecto las señales
+               a->signal_drag_data_get().connect( SigC::slot(*this, &DnDWindow::on_item_drag_data_get));
+
+               // Utilizo el SigC::bind para que el callback on_drag_begin acepte un
+               // parametro extra, en este caso un CItem *. Esto se hace para
+               // que cuando el usuario quiera mover un item, saber que item es
+               // y pedirle su ícono para mostrar cono icono durante la operacion,
+               // Esto va a permitir, que si un widget tiene una imagen rotara o algo
+               // raro se vea el widget tal cual.
+         a->signal_drag_begin().connect(SigC::bind( SigC::slot(*this, &DnDWindow::on_item_drag_begin), a));
+
+               a->show();      
+               listaItems.push_back(a);
   }
 
   context->drag_finish(false, false, time);
 }
 
-void DnDWindow::on_item_drag_begin(const Glib::RefPtr<Gdk::DragContext>& context)
+void DnDWindow::on_item_drag_begin(const Glib::RefPtr<Gdk::DragContext>& context, CItem *item)
 {
+       context->set_icon(item->get_image(), 5, 5);
 }
 
 void DnDWindow::on_item_drag_data_get(const Glib::RefPtr<Gdk::DragContext>& context, GtkSelectionData* selection_data, guint info, guint time)
@@ -170,5 +176,3 @@ void DnDWindow::on_item_drag_data_get(const Glib::RefPtr<Gdk::DragContext>& cont
        gtk_selection_data_set (selection_data, selection_data->target, 10, (const guchar*)"codo.png", 8);
 }
 
-
-
index beaec5ec4c1bcabedd3de5b520660280660758c9..2ab5843a9e5616047c06e6fe113fd82bc4a74ba7 100644 (file)
@@ -46,12 +46,17 @@ protected:
   virtual void on_y_drag_begin(const Glib::RefPtr<Gdk::DragContext>& context);
   virtual void on_codo_drag_begin(const Glib::RefPtr<Gdk::DragContext>& context);
 
-       virtual void on_item_drag_begin(const Glib::RefPtr<Gdk::DragContext>& context);
+       virtual void on_item_drag_begin(const Glib::RefPtr<Gdk::DragContext>& context, CItem *);
        virtual void on_item_drag_data_get(const Glib::RefPtr<Gdk::DragContext>& context, GtkSelectionData* selection_data, guint info, guint time);
 
        /* Lista de tipos de datos para el drag&drop */
        std::list<Gtk::TargetEntry> listTargets;
 
+       // Iconos para Drag&Drop desde la barra
+       Glib::RefPtr<Gdk::Pixbuf> ico_canio, ico_y, ico_codo;
+       // Icono para Drag&Drop de items
+       Glib::RefPtr<Gdk::Pixbuf> ico_last;
+
        void  on_item_button_down();
        //Member widgets:
   Gtk::HBox m_HBox;
index 616b942a99e0a431c86e7ca6f099058bed56d589..9880260f65ea51a7c331239c0a0432bd0ed542b8 100644 (file)
@@ -11,7 +11,8 @@ class CItem:public Gtk::DrawingArea {
 public:
        CItem(const char *filename);
        ~CItem();
-       bool on_expose_event(GdkEventExpose* event);
+       virtual bool on_expose_event(GdkEventExpose* event);
+       Glib::RefPtr<Gdk::Pixbuf> get_image() { return image; }
 private:
        Glib::RefPtr<Gdk::Pixbuf> image;
 };