diff --git a/src/sp-item-group.h b/src/sp-item-group.h
index ebf5c040272fe4b21a7490a8250e8b93e74db6d9..65a51055a79aab462eb760c4a9d1a7cff0dcce82 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))
+#define SP_IS_LAYER(obj) (SP_IS_GROUP(obj) && SP_GROUP(obj)->layerMode() == SPGroup::LAYER)
+
class CGroup;
-struct SPGroup : public SPItem {
- enum LayerMode { GROUP, LAYER };
+struct SPGroup : public SPLPEItem {
+ enum LayerMode { GROUP, LAYER };
- LayerMode _layer_mode;
- std::map<unsigned int, LayerMode> _display_modes;
+ LayerMode _layer_mode;
+ std::map<unsigned int, LayerMode> _display_modes;
- LayerMode layerMode() const { return _layer_mode; }
- void setLayerMode(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 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);
+ 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 void onChildRemoved(Inkscape::XML::Node *child);
virtual void onUpdate(SPCtx *ctx, unsigned int flags);
virtual void onModified(guint flags);
- virtual void calculateBBox(NRRect *bbox, NR::Matrix const &transform, unsigned const 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();
gint getItemCount();
protected:
- enum Action { ActionGeneral, ActionBBox, ActionUpdate, ActionShow };
- virtual GSList *_childList(bool add_ref, Action action = ActionGeneral);
virtual void _showChildren (NRArena *arena, NRArenaItem *ai, unsigned int key, unsigned int flags);
SPGroup *_group;
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 :