# HG changeset patch # User ladanyi # Date 1124282143 0 # Node ID 3e58623c588dba964c8930655af2bdd84d08511a # Parent c38925cc6a4de7522de982e2cd09424c709ce576 Toolbar has custom icons now. Works only when installed. diff -r c38925cc6a4d -r 3e58623c588d Makefile.am --- a/Makefile.am Tue Aug 16 20:07:14 2005 +0000 +++ b/Makefile.am Wed Aug 17 12:35:43 2005 +0000 @@ -1,10 +1,6 @@ AM_CPPFLAGS = -I$(top_srcdir) LDADD = $(top_builddir)/lemon/libemon.la - -noinst_DATA = guipixbufs.h -CLEANFILES = $(noinst_DATA) - bin_PROGRAMS = gd gd_SOURCES = \ @@ -30,23 +26,15 @@ gd_CXXFLAGS = $(GTK_CFLAGS) gd_LDFLAGS = $(GTK_LIBS) +gd_CPPFLAGS = -DDATADIR=\"$(datadir)\" -IMAGES = addlink.png addnode.png delete.png \ - editlink.png editnode.png move.png newmap.png +pixmapdir = $(datadir)/pixmaps/gd -VARIABLES = \ - gui_icons_addlink $(srcdir)/addlink.png \ - gui_icons_addnode $(srcdir)/addnode.png \ - gui_icons_delete $(srcdir)/delete.png \ - gui_icons_editlink $(srcdir)/editlink.png \ - gui_icons_editnode $(srcdir)/editnode.png \ - gui_icons_move $(srcdir)/move.png \ - gui_icons_newmap $(srcdir)/newmap.png - - -guipixbufs.h: $(IMAGES) - gdk-pixbuf-csource \ - --raw --build-list $(VARIABLES) > guipixbufs.h || \ - ( rm -f guipixbufs.h && false ) - -EXTRA_DIST = $(IMAGES) guipixbufs.h +pixmap_DATA = + addlink.png \ + addnode.png \ + delete.png \ + editlink.png \ + editnode.png \ + move.png \ + newmap.png diff -r c38925cc6a4d -r 3e58623c588d main_win.cc --- a/main_win.cc Tue Aug 16 20:07:14 2005 +0000 +++ b/main_win.cc Wed Aug 17 12:35:43 2005 +0000 @@ -8,6 +8,75 @@ set_default_size(WIN_WIDTH,WIN_HEIGHT); add(vbox); + + // custom icons for the toolbar + + Glib::RefPtr p_icon_factory = Gtk::IconFactory::create(); + + std::vector icon_path; + icon_path.push_back(DATADIR); + icon_path.push_back("pixmaps"); + icon_path.push_back("gd"); + + std::vector move_icon_path(icon_path); + move_icon_path.push_back("move.png"); + Gtk::IconSource move_icon_source; + move_icon_source.set_filename(Glib::build_filename(move_icon_path)); + Gtk::IconSet move_icon_set; + move_icon_set.add_source(move_icon_source); + p_icon_factory->add(Gtk::StockID("gd-move"), move_icon_set); + + std::vector addnode_icon_path(icon_path); + addnode_icon_path.push_back("addnode.png"); + Gtk::IconSource addnode_icon_source; + addnode_icon_source.set_filename(Glib::build_filename(addnode_icon_path)); + Gtk::IconSet addnode_icon_set; + addnode_icon_set.add_source(addnode_icon_source); + p_icon_factory->add(Gtk::StockID("gd-addnode"), addnode_icon_set); + + std::vector addlink_icon_path(icon_path); + addlink_icon_path.push_back("addlink.png"); + Gtk::IconSource addlink_icon_source; + addlink_icon_source.set_filename(Glib::build_filename(addlink_icon_path)); + Gtk::IconSet addlink_icon_set; + addlink_icon_set.add_source(addlink_icon_source); + p_icon_factory->add(Gtk::StockID("gd-addlink"), addlink_icon_set); + + std::vector delete_icon_path(icon_path); + delete_icon_path.push_back("delete.png"); + Gtk::IconSource delete_icon_source; + delete_icon_source.set_filename(Glib::build_filename(delete_icon_path)); + Gtk::IconSet delete_icon_set; + delete_icon_set.add_source(delete_icon_source); + p_icon_factory->add(Gtk::StockID("gd-delete"), delete_icon_set); + + std::vector editlink_icon_path(icon_path); + editlink_icon_path.push_back("editlink.png"); + Gtk::IconSource editlink_icon_source; + editlink_icon_source.set_filename(Glib::build_filename(editlink_icon_path)); + Gtk::IconSet editlink_icon_set; + editlink_icon_set.add_source(editlink_icon_source); + p_icon_factory->add(Gtk::StockID("gd-editlink"), editlink_icon_set); + + std::vector editnode_icon_path(icon_path); + editnode_icon_path.push_back("editnode.png"); + Gtk::IconSource editnode_icon_source; + editnode_icon_source.set_filename(Glib::build_filename(editnode_icon_path)); + Gtk::IconSet editnode_icon_set; + editnode_icon_set.add_source(editnode_icon_source); + p_icon_factory->add(Gtk::StockID("gd-editnode"), editnode_icon_set); + + std::vector newmap_icon_path(icon_path); + newmap_icon_path.push_back("newmap.png"); + Gtk::IconSource newmap_icon_source; + newmap_icon_source.set_filename(Glib::build_filename(newmap_icon_path)); + Gtk::IconSet newmap_icon_set; + newmap_icon_set.add_source(newmap_icon_source); + p_icon_factory->add(Gtk::StockID("gd-newmap"), newmap_icon_set); + + p_icon_factory->add_default(); + + ag=Gtk::ActionGroup::create(); ag->add( Gtk::Action::create("FileMenu", "_File") ); @@ -39,19 +108,21 @@ sigc::mem_fun(this->mapwin, &MapWin::show)); Gtk::RadioAction::Group tool_group; - ag->add( Gtk::RadioAction::create(tool_group, "MoveItem", Gtk::Stock::CONVERT, "Move"), + ag->add( Gtk::RadioAction::create(tool_group, "MoveItem", Gtk::StockID("gd-move"), "Move"), sigc::bind( sigc::mem_fun ( this->gd_canvas, &GraphDisplayerCanvas::changeEditorialTool ), 0) ); - ag->add( Gtk::RadioAction::create(tool_group, "CreateNode", Gtk::Stock::NO, "Create node"), + ag->add( Gtk::RadioAction::create(tool_group, "CreateNode", Gtk::StockID("gd-addnode"), "Create node"), sigc::bind( sigc::mem_fun ( this->gd_canvas, &GraphDisplayerCanvas::changeEditorialTool ), 1) ); - ag->add( Gtk::RadioAction::create(tool_group, "CreateEdge", Gtk::Stock::REMOVE, "Create edge"), + ag->add( Gtk::RadioAction::create(tool_group, "CreateEdge", Gtk::StockID("gd-addlink"), "Create edge"), sigc::bind( sigc::mem_fun ( this->gd_canvas, &GraphDisplayerCanvas::changeEditorialTool ), 2) ); - ag->add( Gtk::RadioAction::create(tool_group, "EraseItem", Gtk::Stock::DELETE, "Delete"), + ag->add( Gtk::RadioAction::create(tool_group, "EraseItem", Gtk::StockID("gd-delete"), "Delete"), sigc::bind( sigc::mem_fun ( this->gd_canvas, &GraphDisplayerCanvas::changeEditorialTool ), 3) ); - ag->add( Gtk::Action::create("EditEdgeMap", Gtk::Stock::PROPERTIES), + + ag->add( Gtk::RadioAction::create(tool_group, "EditEdgeMap", Gtk::StockID("gd-editlink"), "Edit edge map"), sigc::bind( sigc::mem_fun ( this->gd_canvas, &GraphDisplayerCanvas::changeEditorialTool ), 4) ); - ag->add( Gtk::Action::create("EditNodeMap", Gtk::Stock::PREFERENCES), + ag->add( Gtk::RadioAction::create(tool_group, "EditNodeMap", Gtk::StockID("gd-editnode"), "Edit node map"), sigc::bind( sigc::mem_fun ( this->gd_canvas, &GraphDisplayerCanvas::changeEditorialTool ), 5) ); - ag->add( Gtk::Action::create("AddMap", Gtk::Stock::NEW), + + ag->add( Gtk::Action::create("AddMap", Gtk::StockID("gd-newmap")), sigc::mem_fun ( this->newmapwin, &NewMapWin::show ) ); uim=Gtk::UIManager::create(); @@ -99,6 +170,7 @@ " " " " " " + " " " " " " ""; diff -r c38925cc6a4d -r 3e58623c588d mapstorage.cc --- a/mapstorage.cc Tue Aug 16 20:07:14 2005 +0000 +++ b/mapstorage.cc Wed Aug 17 12:35:43 2005 +0000 @@ -1,4 +1,5 @@ #include "mapstorage.h" +#include MapStorage::MapStorage() : modified(false), file_name("") {