#ifndef SEEN_CONTEXTMENU_H #define SEEN_CONTEXTMENU_H /* * Context menu * * Authors: * Lauris Kaplinski * Frank Felfe * Abhishek Sharma * Kris De Gussem * * Copyright (C) 2012 Kris De Gussem * Copyright (C) 1999-2002 authors * Copyright (C) 2001-2002 Ximian, Inc. * * Released under GNU GPL, read the file 'COPYING' for more information */ #include class SPDesktop; class SPItem; class SPObject; namespace Gtk { class SeparatorMenuItem; } namespace Inkscape { class Verb; } /** * 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: /** * 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; // 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; 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); /** * 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); void LockSelected(void); void HideSelected(void); void UnLockBelow(std::vector items); void UnHideBelow(std::vector items); ////////////////////////////////////////// //callbacks for the context menu entries of an SP_TYPE_ITEM object void ItemProperties(void); void ItemSelectThis(void); void ItemMoveTo(void); void SelectSameFillStroke(void); void SelectSameFillColor(void); void SelectSameStrokeColor(void); void SelectSameStrokeStyle(void); void SelectSameObjectType(void); void ItemCreateLink(void); void CreateGroupClip(void); void SetMask(void); void ReleaseMask(void); void SetClip(void); void ReleaseClip(void); ////////////////////////////////////////// /** * callback, is executed on clicking the anchor "Group" and "Ungroup" menu entry */ void ActivateUngroupPopSelection(void); void ActivateUngroup(void); void ActivateGroup(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 "Trace Bitmap" menu entry */ void ImageTraceBitmap(void); /** * callback, is executed on clicking the "Trace Pixel Art" menu entry */ void ImageTracePixelArt(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); }; #endif // SEEN_CONTEXT_MENU_H /* Local Variables: mode:c++ c-file-style:"stroustrup" c-file-offsets:((innamespace . 0)(inline-open . 0)(case-label . +)) indent-tabs-mode:nil fill-column:99 End: */ // vim: filetype=cpp:expandtab:shiftwidth=4:tabstop=8:softtabstop=4:fileencoding=utf-8:textwidth=99 :