diff options
| author | Kris De Gussem <kris.degussem@gmail.com> | 2012-04-09 19:18:03 +0000 |
|---|---|---|
| committer | Kris <Kris.De.Gussem@hotmail.com> | 2012-04-09 19:18:03 +0000 |
| commit | d0dd1656c0c53026ea672a366e7405a6e9cfc637 (patch) | |
| tree | 2c95e3dfe50523da6aee97c78af6535792945403 /src/interface.h | |
| parent | ege-adjustment-action: Get rid of GtkHBox (diff) | |
| download | inkscape-d0dd1656c0c53026ea672a366e7405a6e9cfc637.tar.gz inkscape-d0dd1656c0c53026ea672a366e7405a6e9cfc637.zip | |
Documentation / dropping some pointer conversions in context menu
(bzr r11200)
Diffstat (limited to 'src/interface.h')
| -rw-r--r-- | src/interface.h | 145 |
1 files changed, 125 insertions, 20 deletions
diff --git a/src/interface.h b/src/interface.h index e21a0f752..0751171e2 100644 --- a/src/interface.h +++ b/src/interface.h @@ -41,35 +41,40 @@ class View; void sp_create_window (SPViewWidget *vw, gboolean editable); /** - * + * \param widget unused */ void sp_ui_close_view (GtkWidget *widget); +void sp_ui_new_view (void); + /** - * + * @todo TODO: not yet working. To be re-enabled (by adding to menu) once it works. */ -void sp_ui_new_view (void); void sp_ui_new_view_preview (void); /** + * This function is called to exit the program, and iterates through all + * open document view windows, attempting to close each in turn. If the + * view has unsaved information, the user will be prompted to save, + * discard, or cancel. * + * Returns FALSE if the user cancels the close_all operation, TRUE + * otherwise. */ unsigned int sp_ui_close_all (void); /** + * Build the main tool bar. + * + * Currently the main tool bar is built as a dynamic XML menu using + * \c sp_ui_build_dyn_menus. This function builds the bar, and then + * pass it to get items attached to it. * + * @param view View to build the bar for */ GtkWidget *sp_ui_main_menubar (Inkscape::UI::View::View *view); -/** - * - */ void sp_menu_append_recent_documents (GtkWidget *menu); - - -/** - * - */ void sp_ui_dialog_title_string (Inkscape::Verb * verb, gchar* c); @@ -79,34 +84,88 @@ void sp_ui_dialog_title_string (Inkscape::Verb * verb, gchar* c); void sp_ui_error_dialog (const gchar * message); bool sp_ui_overwrite_file (const gchar * filename); + +/** + * Implements the Inkscape context menu. + * + * For the context menu implementation, the ContextMenu class stores the object + * that was selected in a private data member. This should be farely safe to do + * and a pointer to the SPItem as well as SPObject class are kept. + * All callbacks of the context menu entries are implemented as private + * functions. + * + * @todo add callbacks to destroy the context menu when it is closed (=key or mouse button pressed out of the scope of the context menu) + */ class ContextMenu : public Gtk::Menu { public: - ContextMenu(Inkscape::UI::View::View *view, SPItem *item); + /** + * The ContextMenu constructor contains all code to create and show the + * menu entries (aka child widgets). + * + * @param desktop pointer to the desktop the user is currently working on. + * @param item SPItem pointer to the object selected at the time the ContextMenu is created. + */ + ContextMenu(SPDesktop *desktop, SPItem *item); ~ContextMenu(void); + private: - SPItem *_item; - SPObject *_object; - SPDesktop *_desktop; + SPItem *_item; // pointer to the object selected at the time the ContextMenu is created + SPObject *_object; // pointer to the object selected at the time the ContextMenu is created + SPDesktop *_desktop; //pointer to the desktop the user was currently working on at the time the ContextMenu is created int positionOfLastDialog; - std::vector<Gtk::SeparatorMenuItem*> separators; - Gtk::MenuItem MIGroup; - Gtk::MenuItem MIParent; + std::vector<Gtk::SeparatorMenuItem*> separators; //contains pointers to separators + Gtk::MenuItem MIGroup; //menu entry to enter a group + Gtk::MenuItem MIParent; //menu entry to leave a group + /** + * auxiliary function that adds a separator line in the context menu + */ Gtk::SeparatorMenuItem* AddSeparator(void); - void AppendItemFromVerb(Inkscape::Verb *verb, Inkscape::UI::View::View *view); - void MakeObjectMenu (void); + + /** + * c++ified version of sp_ui_menu_append_item. + * + * @see sp_ui_menu_append_item_from_verb and synchronize/drop that function when c++ifying other code in interface.cpp + */ + void AppendItemFromVerb(Inkscape::Verb *verb); + + /** + * main function which is responsible for creating the context sensitive menu items, + * calls subfunctions below to create the menu entry widgets. + */ + void MakeObjectMenu (void); + /** + * creates menu entries for an SP_TYPE_ITEM object + */ void MakeItemMenu (void); + /** + * creates menu entries for a grouped object + */ void MakeGroupMenu (void); + /** + * creates menu entries for an anchor object + */ void MakeAnchorMenu (void); + /** + * creates menu entries for a bitmap image object + */ void MakeImageMenu (void); + /** + * creates menu entries for a shape object + */ void MakeShapeMenu (void); + /** + * creates menu entries for a text object + */ void MakeTextMenu (void); void EnterGroup(Gtk::MenuItem* mi); void LeaveGroup(void); + ////////////////////////////////////////// + //callbacks for the context menu entries of an SP_TYPE_ITEM object void ItemProperties(void); void ItemSelectThis(void); void SelectSameFillStroke(void); @@ -115,22 +174,68 @@ class ContextMenu : public Gtk::Menu void ReleaseMask(void); void SetClip(void); void ReleaseClip(void); + ////////////////////////////////////////// + + /** + * callback, is executed on clicking the anchor "Ungroup" menu entry + */ void ActivateUngroup(void); + void AnchorLinkProperties(void); + /** + * placeholder for callback to be executed on clicking the anchor "Follow link" context menu entry + * @todo add code to follow link externally + */ void AnchorLinkFollow(void); + + /** + * callback, is executed on clicking the anchor "Link remove" menu entry + */ void AnchorLinkRemove(void); + + /** + * callback, opens the image properties dialog and is executed on clicking the context menu entry with similar name + */ void ImageProperties(void); + + /** + * callback, is executed on clicking the image "Edit Externally" menu entry + */ void ImageEdit(void); + + /** + * auxiliary function that loads the external image editor name from the settings. + */ Glib::ustring getImageEditorName(); + + /** + * callback, is executed on clicking the "Embed Image" menu entry + */ void ImageEmbed(void); + + /** + * callback, is executed on clicking the "Extract Image" menu entry + */ void ImageExtract(void); + + /** + * callback, is executed on clicking the "Fill and Stroke" menu entry + */ void FillSettings(void); + + /** + * callback, is executed on clicking the "Text and Font" menu entry + */ void TextSettings(void); + + /** + * callback, is executed on clicking the "Check spelling" menu entry + */ void SpellcheckSettings(void); }; |
