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

#include <SvgTextPathInfoChangeCommand.h>

+ Inheritance diagram for SvgTextPathInfoChangeCommand:

Public Member Functions

int id () const override
 
bool mergeWith (const KUndo2Command *other) override
 
void redo () override
 
 SvgTextPathInfoChangeCommand (KoSvgTextShape *shape, int pos, KoSvgText::TextOnPathInfo textPathInfo, KUndo2Command *parent=nullptr)
 
void undo () override
 
- 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 ()
 

Private Attributes

KoSvgText::TextOnPathInfo m_newInfo
 
int m_pos
 
KoSvgTextShapem_shape
 
KoSvgTextShapeMementoSP m_textData
 

Detailed Description

Definition at line 15 of file SvgTextPathInfoChangeCommand.h.

Constructor & Destructor Documentation

◆ SvgTextPathInfoChangeCommand()

SvgTextPathInfoChangeCommand::SvgTextPathInfoChangeCommand ( KoSvgTextShape * shape,
int pos,
KoSvgText::TextOnPathInfo textPathInfo,
KUndo2Command * parent = nullptr )

Definition at line 10 of file SvgTextPathInfoChangeCommand.cpp.

11 : KUndo2Command(parent)
12 , m_shape(shape)
13 , m_textData(shape->getMemento())
14 , m_pos(pos)
15 , m_newInfo(textPathInfo)
16{
17 setText(kundo2_i18n("Change Text On Path Properties"));
18}
void setText(const KUndo2MagicString &text)
KUndo2Command(KUndo2Command *parent=0)
KoSvgTextShapeMementoSP getMemento()
Get a memento holding the current textdata and layout info.
KUndo2MagicString kundo2_i18n(const char *text)

References kundo2_i18n(), and KUndo2Command::setText().

Member Function Documentation

◆ id()

int SvgTextPathInfoChangeCommand::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 52 of file SvgTextPathInfoChangeCommand.cpp.

References KisCommandUtils::SvgTextPathInfoChangeCommandId.

◆ mergeWith()

bool SvgTextPathInfoChangeCommand::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 57 of file SvgTextPathInfoChangeCommand.cpp.

58{
59 const SvgTextPathInfoChangeCommand *command = dynamic_cast<const SvgTextPathInfoChangeCommand*>(other);
60
61 if (!command || command->m_shape != m_shape || m_pos != command->m_pos) {
62 return false;
63 }
64
65 m_newInfo = command->m_newInfo;
66 return true;
67
68}

References m_newInfo, m_pos, and m_shape.

◆ redo()

void SvgTextPathInfoChangeCommand::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 20 of file SvgTextPathInfoChangeCommand.cpp.

21{
24
25
26 if (m_newInfo.side != index.textPathInfo()->side) {
31 }
32
38
43}
static void bulkShapesUpdate(const UpdatesList &updates)
void notifyChanged()
Definition KoShape.cpp:618
The KoSvgTextNodeIndex class.
KoSvgTextProperties * properties()
properties The properties for this node as a pointer.
KoSvgText::TextOnPathInfo * textPathInfo()
textPathInfo the text path info for this node as a pointer.
@ TextAnchorId
KoSvgText::TextAnchor.
void setProperty(PropertyId id, const QVariant &value)
QVariant propertyOrDefault(PropertyId id) const
void notifyCursorPosChanged(int pos, int anchor)
Notify that the cursor position has changed.
KoSvgTextNodeIndex topLevelNodeForPos(int pos) const
topLevelNodeForPos Get, if possible, an index for the child element of the root at pos....
void relayout() const
TextAnchor
Where the text is anchored for SVG 1.1 text and 'inline-size'.
Definition KoSvgText.h:79
@ AnchorEnd
Anchor right for LTR, left for RTL.
Definition KoSvgText.h:82
@ AnchorStart
Anchor left for LTR, right for RTL.
Definition KoSvgText.h:80
@ AnchorMiddle
Anchor to the middle.
Definition KoSvgText.h:81
TextPathMethod method
Definition KoSvgText.h:626
TextPathSpacing spacing
Definition KoSvgText.h:627

References KoSvgText::AnchorEnd, KoSvgText::AnchorMiddle, KoSvgText::AnchorStart, KoShapeBulkActionLock::bulkShapesUpdate(), m_newInfo, m_pos, m_shape, KoSvgText::TextOnPathInfo::method, KoShape::notifyChanged(), KoSvgTextShape::notifyCursorPosChanged(), KoSvgTextNodeIndex::properties(), KoSvgTextProperties::propertyOrDefault(), KoSvgTextShape::relayout(), KoSvgTextProperties::setProperty(), KoSvgText::TextOnPathInfo::side, KoSvgText::TextOnPathInfo::spacing, KoSvgText::TextOnPathInfo::startOffset, KoSvgText::TextOnPathInfo::startOffsetIsPercentage, KoSvgTextProperties::TextAnchorId, KoSvgTextNodeIndex::textPathInfo(), KoSvgTextShape::topLevelNodeForPos(), and KoShapeBulkActionLock::unlock().

◆ undo()

void SvgTextPathInfoChangeCommand::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 45 of file SvgTextPathInfoChangeCommand.cpp.

46{
50}
void setMemento(const KoSvgTextShapeMementoSP memento)
Set the text data and layout info, reset listening cursors to 0.

References KoShapeBulkActionLock::bulkShapesUpdate(), m_pos, m_shape, m_textData, KoSvgTextShape::setMemento(), and KoShapeBulkActionLock::unlock().

Member Data Documentation

◆ m_newInfo

KoSvgText::TextOnPathInfo SvgTextPathInfoChangeCommand::m_newInfo
private

Definition at line 30 of file SvgTextPathInfoChangeCommand.h.

◆ m_pos

int SvgTextPathInfoChangeCommand::m_pos
private

Definition at line 29 of file SvgTextPathInfoChangeCommand.h.

◆ m_shape

KoSvgTextShape* SvgTextPathInfoChangeCommand::m_shape
private

Definition at line 27 of file SvgTextPathInfoChangeCommand.h.

◆ m_textData

KoSvgTextShapeMementoSP SvgTextPathInfoChangeCommand::m_textData
private

Definition at line 28 of file SvgTextPathInfoChangeCommand.h.


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