///Destructor
virtual ~CItem();
+
+ virtual void on_realize();
+
///Dibuja el item cada vez que este evento es llamado por la ventana que lo contiene.
virtual bool on_expose_event(GdkEventExpose* event);
///Numero "unico" que identifica al item.
int ID;
+ Glib::RefPtr<Gdk::GC> gc;
+
///Nombre del item
Glib::ustring name;
///Puntero a la ventana de propiedades del item
ItemPtyWnd *property_wnd;
-
+
+ Gdk::Color blue, red;
+
///Posicion del item en el area de trabajo
int x, y;
};
///Destructor
virtual ~Pump();
///Funciones redefinidas de CItem
+ virtual bool on_expose_event(GdkEventExpose* event);
virtual bool on_button_press_event(GdkEventButton *event);
virtual void on_menu_popup_rotar();
virtual void on_menu_popup_propiedades();
int CItem::gate_id = -1;
-CItem::CItem(const char *filename):Gtk::DrawingArea()
+CItem::CItem(const char *filename)
{
image = Gdk::Pixbuf::create_from_file(filename);
set_size_request(image->get_width(), image->get_height());
+
+ add_events(Gdk::EXPOSURE_MASK);
}
CItem::CItem()
std::cout << "Item Die" << std::endl;
}
+void CItem::on_realize()
+{
+ Gtk::DrawingArea::on_realize();
+ Glib::RefPtr<Gdk::Window> window = get_window();
+ gc = Gdk::GC::create(window);
+
+ Glib::RefPtr<Gdk::Colormap> colormap = get_colormap();
+
+ red = Gdk::Color("red");
+ blue = Gdk::Color("blue");
+
+ colormap->alloc_color(red);
+ colormap->alloc_color(blue);
+}
+
bool CItem::on_expose_event(GdkEventExpose* event)
{
- image->render_to_drawable ( get_window(), get_style()->get_black_gc(), 0, 0, 0, 0, image->get_width() ,image->get_height() ,
+ get_window()->draw_pixbuf(gc, image, 0, 0, 0, 0, image->get_width() ,image->get_height(),
Gdk::RGB_DITHER_NONE, 0, 0);
// XXX Esto no deberia ser necesario! en todo caso devolves false en
connect_vec.push_back(temp);
}
+
Pump::~Pump()
{
}
out_y = y + 32;
}
}
+
+bool Pump::on_expose_event(GdkEventExpose* event)
+{
+ CItem::on_expose_event(event);
+ Glib::RefPtr<Gdk::Window> window = get_window();
+
+ gc->set_foreground(red);
+ gc->set_background(red);
+ window->draw_rectangle(gc, 1, image->get_width()-32, 0, 32, 16);
+ gc->set_foreground(blue);
+ gc->set_background(blue);
+ window->draw_rectangle(gc, 1, image->get_width()-32, 16, 32, 16);
+ return true;
+}