diff --git a/src/sp-item-group.h b/src/sp-item-group.h
index 578454c9237e6591ad55fa7389c8168ab6cc8d47..932241a42f6b8eaae25ed798764c01dd45ef7e93 100644 (file)
--- a/src/sp-item-group.h
+++ b/src/sp-item-group.h
*/
#include <map>
-#include "sp-item.h"
+#include "sp-lpe-item.h"
#define SP_TYPE_GROUP (sp_group_get_type ())
#define SP_GROUP(obj) (G_TYPE_CHECK_INSTANCE_CAST ((obj), SP_TYPE_GROUP, SPGroup))
#define SP_IS_GROUP(obj) (G_TYPE_CHECK_INSTANCE_TYPE ((obj), SP_TYPE_GROUP))
#define SP_IS_GROUP_CLASS(klass) (G_TYPE_CHECK_CLASS_TYPE ((klass), SP_TYPE_GROUP))
-struct SPGroup : public SPItem {
- enum LayerMode { GROUP, LAYER };
+#define SP_IS_LAYER(obj) (SP_IS_GROUP(obj) && SP_GROUP(obj)->layerMode() == SPGroup::LAYER)
- LayerMode _layer_mode;
- std::map<unsigned int, LayerMode> _display_modes;
+class CGroup;
- LayerMode layerMode() const { return _layer_mode; }
- void setLayerMode(LayerMode mode);
+struct SPGroup : public SPLPEItem {
+ enum LayerMode { GROUP, LAYER, MASK_HELPER };
- LayerMode effectiveLayerMode(unsigned int display_key) const {
- if ( _layer_mode == LAYER ) {
- return LAYER;
- } else {
- return layerDisplayMode(display_key);
- }
- }
+ LayerMode _layer_mode;
+ std::map<unsigned int, LayerMode> _display_modes;
- LayerMode layerDisplayMode(unsigned int display_key) const;
- void setLayerDisplayMode(unsigned int display_key, LayerMode mode);
+ LayerMode layerMode() const { return _layer_mode; }
+ void setLayerMode(LayerMode mode);
+ LayerMode effectiveLayerMode(unsigned int display_key) const {
+ if ( _layer_mode == LAYER ) {
+ return LAYER;
+ } else {
+ return layerDisplayMode(display_key);
+ }
+ }
+
+ LayerMode layerDisplayMode(unsigned int display_key) const;
+ void setLayerDisplayMode(unsigned int display_key, LayerMode mode);
+ void translateChildItems(Geom::Translate const &tr);
+
+ CGroup *group;
+
private:
- void _updateLayerMode(unsigned int display_key=0);
+ void _updateLayerMode(unsigned int display_key=0);
};
struct SPGroupClass {
- SPItemClass parent_class;
+ SPLPEItemClass parent_class;
+};
+
+/*
+ * Virtual methods of SPGroup
+ */
+class CGroup {
+public:
+ CGroup(SPGroup *group);
+ virtual ~CGroup();
+
+ virtual void onChildAdded(Inkscape::XML::Node *child);
+ virtual void onChildRemoved(Inkscape::XML::Node *child);
+ virtual void onUpdate(SPCtx *ctx, unsigned int flags);
+ virtual void onModified(guint flags);
+ virtual void calculateBBox(NRRect *bbox, Geom::Matrix const &transform, unsigned const flags);
+ virtual void onPrint(SPPrintContext *ctx);
+ virtual void onOrderChanged(Inkscape::XML::Node *child, Inkscape::XML::Node *old_ref, Inkscape::XML::Node *new_ref);
+ virtual gchar *getDescription();
+ virtual NRArenaItem *show (NRArena *arena, unsigned int key, unsigned int flags);
+ virtual void hide (unsigned int key);
+
+ gint getItemCount();
+
+protected:
+ virtual void _showChildren (NRArena *arena, NRArenaItem *ai, unsigned int key, unsigned int flags);
+
+ SPGroup *_group;
};
GType sp_group_get_type (void);
SPObject *sp_item_group_get_child_by_name (SPGroup *group, SPObject *ref, const gchar *name);
#endif
+
+/*
+ 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 :