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

#include <SvgTextInsertRichCommand.h>

+ Inheritance diagram for SvgTextInsertRichCommand:

Public Member Functions

void redo () override
 
 SvgTextInsertRichCommand (KoSvgTextShape *shape, KoSvgTextShape *insert, int pos, int anchor, KUndo2Command *parent=0)
 
void undo () override
 
 ~SvgTextInsertRichCommand () override=default
 
- 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 int id () const
 
virtual bool isMerged () const
 
 KUndo2Command (const KUndo2MagicString &text, KUndo2Command *parent=0)
 
 KUndo2Command (KUndo2Command *parent=0)
 
virtual QVector< KUndo2Command * > mergeCommandsVector () const
 
virtual bool mergeWith (const KUndo2Command *other)
 
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

int m_anchor
 
KoSvgTextShapem_insert
 
int m_pos
 
KoSvgTextShapem_shape
 
KoSvgTextShapeMementoSP m_textData
 

Detailed Description

Definition at line 13 of file SvgTextInsertRichCommand.h.

Constructor & Destructor Documentation

◆ SvgTextInsertRichCommand()

SvgTextInsertRichCommand::SvgTextInsertRichCommand ( KoSvgTextShape * shape,
KoSvgTextShape * insert,
int pos,
int anchor,
KUndo2Command * parent = 0 )

Definition at line 9 of file SvgTextInsertRichCommand.cpp.

10 : KUndo2Command(parent)
11 , m_shape(shape)
12 , m_insert(insert)
13 , m_pos(pos)
14 , m_anchor(anchor)
15{
16 setText(kundo2_i18n("Insert Rich Text"));
17}
void setText(const KUndo2MagicString &text)
KUndo2Command(KUndo2Command *parent=0)
KUndo2MagicString kundo2_i18n(const char *text)

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

◆ ~SvgTextInsertRichCommand()

SvgTextInsertRichCommand::~SvgTextInsertRichCommand ( )
overridedefault

Member Function Documentation

◆ redo()

void SvgTextInsertRichCommand::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 19 of file SvgTextInsertRichCommand.cpp.

20{
21 QRectF updateRect = m_shape->boundingRect();
22 // Index defaults to -1 when there's no text in the shape.
23 int oldIndex = qMax(0, m_shape->indexForPos(m_pos));
24
29
30 int pos = m_shape->posForIndex(oldIndex + m_insert->plainText().size(), false, false);
33}
virtual void updateAbsolute(const QRectF &rect) const
Definition KoShape.cpp:616
void notifyCursorPosChanged(int pos, int anchor)
Notify that the cursor position has changed.
KoSvgTextShapeMementoSP getMemento()
Get a memento holding the current textdata and layout info.
QRectF boundingRect() const override
Get the bounding box of the shape.
void notifyMarkupChanged()
Notify that the markup has changed.
int indexForPos(int pos) const
indexForPos get the string index for a given cursor position.
bool insertRichText(int pos, const KoSvgTextShape *richText)
insertRichText Insert rich text at the given cursor pos. This will first split contents at the given ...
void cleanUp()
Cleans up the internal text data. Used by undo commands.
int posForIndex(int index, bool firstIndex=false, bool skipSynthetic=false) const
posForIndex Get the cursor position for a given index in a string.
KoSvgTextShapeMementoSP m_textData

References KoSvgTextShape::boundingRect(), KoSvgTextShape::cleanUp(), KoSvgTextShape::getMemento(), KoSvgTextShape::indexForPos(), KoSvgTextShape::insertRichText(), m_insert, m_pos, m_shape, m_textData, KoSvgTextShape::notifyCursorPosChanged(), KoSvgTextShape::notifyMarkupChanged(), KoSvgTextShape::plainText, KoSvgTextShape::posForIndex(), and KoShape::updateAbsolute().

◆ undo()

void SvgTextInsertRichCommand::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 35 of file SvgTextInsertRichCommand.cpp.

36{
37 QRectF updateRect = m_shape->boundingRect();
40}
void setMemento(const KoSvgTextShapeMementoSP memento)
Set the text data and layout info, reset listening cursors to 0.

References KoSvgTextShape::boundingRect(), m_anchor, m_pos, m_shape, m_textData, KoSvgTextShape::setMemento(), and KoShape::updateAbsolute().

Member Data Documentation

◆ m_anchor

int SvgTextInsertRichCommand::m_anchor
private

Definition at line 31 of file SvgTextInsertRichCommand.h.

◆ m_insert

KoSvgTextShape* SvgTextInsertRichCommand::m_insert
private

Definition at line 28 of file SvgTextInsertRichCommand.h.

◆ m_pos

int SvgTextInsertRichCommand::m_pos
private

Definition at line 30 of file SvgTextInsertRichCommand.h.

◆ m_shape

KoSvgTextShape* SvgTextInsertRichCommand::m_shape
private

Definition at line 27 of file SvgTextInsertRichCommand.h.

◆ m_textData

KoSvgTextShapeMementoSP SvgTextInsertRichCommand::m_textData
private

Definition at line 32 of file SvgTextInsertRichCommand.h.


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