Krita Source Code Documentation
Loading...
Searching...
No Matches
KoPathShapeMarkerCommand Class Reference

The undo / redo command for setting the shape marker. More...

#include <KoPathShapeMarkerCommand.h>

+ Inheritance diagram for KoPathShapeMarkerCommand:

Public Member Functions

int id () const override
 
 KoPathShapeMarkerCommand (const QList< KoPathShape * > &shapes, KoMarker *marker, KoFlake::MarkerPosition position, KUndo2Command *parent=0)
 
bool mergeWith (const KUndo2Command *command) override
 
void redo () override
 
void undo () override
 
 ~KoPathShapeMarkerCommand () override
 
- Public Member Functions inherited from Private
 Private (KisCanvas2 *c)
 
- Public Member Functions inherited from KUndo2Command
QString actionText () const
 
virtual bool canAnnihilateWith (const KUndo2Command *other) const
 
const KUndo2Commandchild (int index) const
 
int childCount () const
 
virtual QTime endTime () const
 
KUndo2CommandExtraDataextraData () const
 
bool hasParent () const
 
virtual bool isMerged () const
 
 KUndo2Command (const KUndo2MagicString &text, KUndo2Command *parent=0)
 
 KUndo2Command (KUndo2Command *parent=0)
 
virtual QVector< KUndo2Command * > mergeCommandsVector () const
 
virtual void redoMergedCommands ()
 
void setEndTime ()
 
virtual void setEndTime (const QTime &time)
 
void setExtraData (KUndo2CommandExtraData *data)
 
void setText (const KUndo2MagicString &text)
 
void setTime ()
 
virtual void setTime (const QTime &time)
 
virtual void setTimedID (int timedID)
 
KUndo2MagicString text () const
 
virtual QTime time () const
 
virtual int timedId () const
 
virtual bool timedMergeWith (KUndo2Command *other)
 
virtual void undoMergedCommands ()
 
virtual ~KUndo2Command ()
 

Public Attributes

QExplicitlySharedDataPointer< KoMarkermarker
 the new marker to set
 
QList< bool > oldAutoFillMarkers
 
QList< QExplicitlySharedDataPointer< KoMarker > > oldMarkers
 the old markers, one for each shape
 
KoFlake::MarkerPosition position
 
QList< KoPathShape * > shapes
 the shapes to set marker for
 
- Public Attributes inherited from Private
KisCanvas2canvas
 
int displayedFrame
 
int intendedFrame
 

Private Attributes

const QScopedPointer< Privatem_d
 

Detailed Description

The undo / redo command for setting the shape marker.

Definition at line 17 of file KoPathShapeMarkerCommand.cpp.

Constructor & Destructor Documentation

◆ KoPathShapeMarkerCommand()

KoPathShapeMarkerCommand::KoPathShapeMarkerCommand ( const QList< KoPathShape * > & shapes,
KoMarker * marker,
KoFlake::MarkerPosition position,
KUndo2Command * parent = 0 )

Command to set a new shape marker.

Parameters
shapesa set of all the shapes that should get the new marker.
markerthe new marker, the same for all given shapes
positionthe position - start or end - of the marker on the shape
parentthe parent command used for macro commands

Definition at line 26 of file KoPathShapeMarkerCommand.cpp.

27 : KUndo2Command(kundo2_i18n("Set marker"), parent),
28 m_d(new Private)
29{
30 m_d->shapes = shapes;
31 m_d->marker = marker;
32 m_d->position = position;
33
34 // save old markers
35 Q_FOREACH (KoPathShape *shape, m_d->shapes) {
36 m_d->oldMarkers.append(QExplicitlySharedDataPointer<KoMarker>(shape->marker(position)));
37 m_d->oldAutoFillMarkers.append(shape->autoFillMarkers());
38 }
39}
KUndo2Command(KUndo2Command *parent=0)
The position of a path point within a path shape.
Definition KoPathShape.h:63
bool autoFillMarkers() const
KoMarker * marker(KoFlake::MarkerPosition pos) const
QList< KoShape * > shapes() const
KUndo2MagicString kundo2_i18n(const char *text)
QExplicitlySharedDataPointer< KoMarker > marker
the new marker to set
const QScopedPointer< Private > m_d
QList< KoPathShape * > shapes
the shapes to set marker for

References KoPathShape::autoFillMarkers(), m_d, marker, KoPathShape::marker(), position, shapes, and KoShapeContainer::shapes().

◆ ~KoPathShapeMarkerCommand()

KoPathShapeMarkerCommand::~KoPathShapeMarkerCommand ( )
override

Definition at line 41 of file KoPathShapeMarkerCommand.cpp.

42{
43}

Member Function Documentation

◆ id()

int KoPathShapeMarkerCommand::id ( ) const
overridevirtual

Returns the ID of this command.

A command ID is used in command compression. It must be an integer unique to this command's class, or -1 if the command doesn't support compression.

If the command supports compression this function must be overridden in the derived class to return the correct ID. The base implementation returns -1.

KUndo2QStack::push() will only try to merge two commands if they have the same ID, and the ID is not -1.

See also
mergeWith(), KUndo2QStack::push()

Reimplemented from KUndo2Command.

Definition at line 74 of file KoPathShapeMarkerCommand.cpp.

References KisCommandUtils::ChangeShapeMarkersId.

◆ mergeWith()

bool KoPathShapeMarkerCommand::mergeWith ( const KUndo2Command * command)
overridevirtual

Attempts to merge this command with command. Returns true on success; otherwise returns false.

If this function returns true, calling this command's redo() must have the same effect as redoing both this command and command. Similarly, calling this command's undo() must have the same effect as undoing command and this command.

KUndo2QStack will only try to merge two commands if they have the same id, and the id is not -1.

The default implementation returns false.

See also
id() KUndo2QStack::push()

Reimplemented from KUndo2Command.

Definition at line 79 of file KoPathShapeMarkerCommand.cpp.

80{
81 const KoPathShapeMarkerCommand *other = dynamic_cast<const KoPathShapeMarkerCommand*>(command);
82
83 if (!other ||
84 other->m_d->shapes != m_d->shapes ||
85 other->m_d->position != m_d->position) {
86
87 return false;
88 }
89
90 m_d->marker = other->m_d->marker;
91 return true;
92}
The undo / redo command for setting the shape marker.

References m_d, and marker.

◆ redo()

void KoPathShapeMarkerCommand::redo ( )
overridevirtual

Applies a change to the document. This function must be implemented in the derived class. Calling KUndo2QStack::push(), KUndo2QStack::undo() or KUndo2QStack::redo() from this function leads to undefined behavior.

The default implementation calls redo() on all child commands.

See also
undo()

Reimplemented from KUndo2Command.

Definition at line 45 of file KoPathShapeMarkerCommand.cpp.

46{
48 Q_FOREACH (KoPathShape *shape, m_d->shapes) {
49 const QRectF oldDirtyRect = shape->boundingRect();
50 shape->setMarker(m_d->marker.data(), m_d->position);
51
52 // we have no GUI for selection auto-filling yet! So just enable it!
53 shape->setAutoFillMarkers(true);
54
55 shape->updateAbsolute(oldDirtyRect | shape->boundingRect());
56 }
57}
virtual void redo()
void setAutoFillMarkers(bool value)
void setMarker(KoMarker *marker, KoFlake::MarkerPosition pos)
QRectF boundingRect() const override
reimplemented
virtual void updateAbsolute(const QRectF &rect) const
Definition KoShape.cpp:616

References KoPathShape::boundingRect(), m_d, KUndo2Command::redo(), KoPathShape::setAutoFillMarkers(), KoPathShape::setMarker(), KoShapeContainer::shapes(), and KoShape::updateAbsolute().

◆ undo()

void KoPathShapeMarkerCommand::undo ( )
overridevirtual

Reverts a change to the document. After undo() is called, the state of the document should be the same as before redo() was called. This function must be implemented in the derived class. Calling KUndo2QStack::push(), KUndo2QStack::undo() or KUndo2QStack::redo() from this function leads to undefined behavior.

The default implementation calls undo() on all child commands in reverse order.

See also
redo()

Reimplemented from KUndo2Command.

Definition at line 59 of file KoPathShapeMarkerCommand.cpp.

60{
62 auto markerIt = m_d->oldMarkers.begin();
63 auto autoFillIt = m_d->oldAutoFillMarkers.begin();
64 Q_FOREACH (KoPathShape *shape, m_d->shapes) {
65 const QRectF oldDirtyRect = shape->boundingRect();
66 shape->setMarker((*markerIt).data(), m_d->position);
67 shape->setAutoFillMarkers(*autoFillIt);
68 shape->updateAbsolute(oldDirtyRect | shape->boundingRect());
69 ++markerIt;
70 ++autoFillIt;
71 }
72}
virtual void undo()

References KoPathShape::boundingRect(), m_d, KoPathShape::setAutoFillMarkers(), KoPathShape::setMarker(), KoShapeContainer::shapes(), KUndo2Command::undo(), and KoShape::updateAbsolute().

Member Data Documentation

◆ m_d

const QScopedPointer<Private> KoPathShapeMarkerCommand::m_d
private

Definition at line 45 of file KoPathShapeMarkerCommand.h.

◆ marker

QExplicitlySharedDataPointer<KoMarker> KoPathShapeMarkerCommand::marker

the new marker to set

Definition at line 21 of file KoPathShapeMarkerCommand.cpp.

◆ oldAutoFillMarkers

QList<bool> KoPathShapeMarkerCommand::oldAutoFillMarkers

Definition at line 23 of file KoPathShapeMarkerCommand.cpp.

◆ oldMarkers

QList<QExplicitlySharedDataPointer<KoMarker> > KoPathShapeMarkerCommand::oldMarkers

the old markers, one for each shape

Definition at line 20 of file KoPathShapeMarkerCommand.cpp.

◆ position

KoFlake::MarkerPosition KoPathShapeMarkerCommand::position

Definition at line 22 of file KoPathShapeMarkerCommand.cpp.

◆ shapes

QList<KoPathShape*> KoPathShapeMarkerCommand::shapes

the shapes to set marker for

Definition at line 19 of file KoPathShapeMarkerCommand.cpp.


The documentation for this class was generated from the following files: