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()
Glib::RefPtr<Gnome::Glade::Xml> ref;
ref = Gnome::Glade::Xml::create(PACKAGE_DATA_DIR"/plaqui-constructor/dialogs/constructor.glade", "item_pty_wnd");
ref->get_widget_derived("item_pty_wnd",property_wnd);
- caudal_max = 0.0;
+ caudal_max = 10.0;
is_union = true;
is_connected = false;
is_logic =false;
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
// vez de true para que siga llamando a los otros handlers :)
//Gtk::DrawingArea::on_expose_event(event);
+ if (CItem::logic_connect) {
+ draw_connectors();
+ }
return true;
}
Glib::ustring CItem::get_other_name(int _id)
{
std::list<CItem *>::iterator i = listaItems->begin();
+ std::cout << name << " " << _id << std::endl;
while ( i != listaItems->end() ) {
if ( (*i)->get_id() == _id )
return (*i)->get_name();
name = _name;
}
+void CItem::set_out_connected(bool _o)
+{
+}
+
+void CItem::set_in_connected(bool _o)
+{
+}
+
bool CItem::is_occupied_area(int _a, int _b)
{
if ( ( _a >= x ) && ( _a < x+image->get_width()) && (_b >= y) && (_b < y+image->get_height()) )
_b = y;
}
+bool CItem::get_out_logic_connect()
+{
+ return false;
+}
+
void CItem::update_logic_position()
{
}
+
+void CItem::draw_connectors()
+{
+ if ( in_x != -1 ) {
+ Glib::RefPtr<Gdk::Window> window = get_window();
+
+ gc->set_foreground(red);
+ gc->set_background(red);
+ window->draw_rectangle(gc, 1, in_x-5-x, in_y-y, 10, 10);
+ gc->set_foreground(blue);
+ gc->set_background(blue);
+ window->draw_rectangle(gc, 1, out_x-5-x, out_y-y-10, 10, 10);
+ queue_draw();
+ }
+}