Ipelib
|
#include <ipetext.h>
Inherits ipe::Object.
Classes | |
struct | XForm |
Public Types | |
enum | TextType { ELabel , EMinipage } |
Public Types inherited from ipe::Object | |
enum | Type { EGroup , EPath , EText , EImage , EReference } |
Public Member Functions | |
Text () | |
Text (const AllAttributes &attr, String data, const Vector &pos, TextType type, double width=10.0) | |
Text (const Text &rhs) | |
~Text () | |
Text (const XmlAttributes &attr, String data) | |
virtual Object * | clone () const |
virtual Text * | asText () |
virtual Type | type () const |
virtual void | saveAsXml (Stream &stream, String layer) const |
virtual void | draw (Painter &painter) const |
virtual void | drawSimple (Painter &painter) const |
virtual void | accept (Visitor &visitor) const |
virtual void | addToBBox (Rect &box, const Matrix &m, bool) const |
virtual double | distance (const Vector &v, const Matrix &m, double bound) const |
virtual void | snapCtl (const Vector &mouse, const Matrix &m, Vector &pos, double &bound) const |
virtual void | checkStyle (const Cascade *sheet, AttributeSeq &seq) const |
virtual bool | setAttribute (Property prop, Attribute value) |
virtual Attribute | getAttribute (Property prop) const noexcept |
Vector | align () const |
TextType | textType () const |
Vector | position () const |
String | text () const |
void | setStroke (Attribute stroke) |
void | setOpacity (Attribute opaq) |
Attribute | stroke () const |
Attribute | size () const |
Attribute | style () const |
Attribute | opacity () const |
bool | isMinipage () const |
void | setTextType (TextType type) |
THorizontalAlignment | horizontalAlignment () const |
TVerticalAlignment | verticalAlignment () const |
void | setHorizontalAlignment (THorizontalAlignment align) |
void | setVerticalAlignment (TVerticalAlignment align) |
double | width () const |
double | height () const |
double | depth () const |
double | totalHeight () const |
void | setSize (Attribute size) |
void | setStyle (Attribute style) |
void | setWidth (double width) |
void | setText (String text) |
void | setXForm (XForm *xform) const |
const XForm * | getXForm () const |
Public Member Functions inherited from ipe::Object | |
virtual | ~Object ()=0 |
virtual Group * | asGroup () |
virtual const Group * | asGroup () const |
virtual Path * | asPath () |
virtual Image * | asImage () |
virtual Reference * | asReference () |
virtual TPinned | pinned () const |
void | setPinned (TPinned pin) |
TTransformations | transformations () const |
void | setTransformations (TTransformations trans) |
virtual void | setMatrix (const Matrix &matrix) |
const Matrix & | matrix () const |
void | setCustom (Attribute value) |
Attribute | getCustom () const noexcept |
virtual void | snapVtx (const Vector &mouse, const Matrix &m, Vector &pos, double &bound) const |
virtual void | snapBnd (const Vector &mouse, const Matrix &m, Vector &pos, double &bound) const |
Static Public Member Functions | |
static TVerticalAlignment | makeVAlign (String str, TVerticalAlignment def) |
static THorizontalAlignment | makeHAlign (String str, THorizontalAlignment def) |
static void | saveAlignment (Stream &stream, THorizontalAlignment h, TVerticalAlignment v) |
Additional Inherited Members | |
Protected Member Functions inherited from ipe::Object | |
Object () | |
Object (const AllAttributes &attr) | |
Object (const Object &rhs) | |
Object (const XmlAttributes &attr) | |
void | saveAttributesAsXml (Stream &stream, String layer) const |
Matrix | effectiveMatrix (const Matrix &m, const Vector &pos=Vector::ZERO) const noexcept |
Static Protected Member Functions inherited from ipe::Object | |
static void | checkSymbol (Kind kind, Attribute attr, const Cascade *sheet, AttributeSeq &seq) |
Protected Attributes inherited from ipe::Object | |
Matrix | iMatrix |
Attribute | iCustom |
TPinned | iPinned: 8 |
TTransformations | iTransformations: 8 |
The text object.
The text object stores a Latex source representation, which needs to be translated into PDF by Pdflatex before it can be saved as PDF.
There are two types of text objects: labels and minipages. The textType() method tells you which, or use isMinipage().
The dimensions of a text object are given by width(), height(), and depth(). They are recomputed by Ipe when running LaTeX, with the exception of the width for minipage objects (whose width is fixed). Before Latex has been run, the dimensions are not reliable.
The position of the reference point relative to the text box is given by verticalAlignment() and horizontalAlignment().
The text() must be a legal LaTeX fragment that can be interpreted by LaTeX inside \hbox
, possibly using the macros or packages defined in the preamble.
enum ipe::Text::TextType |
|
explicit |
Construct an empty internal text object.
References ipe::Attribute::BLACK(), ipe::EAlignBottom, ipe::EAlignLeft, ipe::Attribute::NORMAL(), ipe::Attribute::OPAQUE(), and ipe::Vector::ZERO.
Referenced by clone().
|
explicit |
Create text object.
References ipe::EAlignTop, ELabel, ipe::ETransformationsTranslations, ipe::AllAttributes::iHorizontalAlignment, ipe::AllAttributes::iLabelStyle, ipe::AllAttributes::iOpacity, ipe::AllAttributes::iStroke, ipe::AllAttributes::iTextSize, ipe::AllAttributes::iTextStyle, ipe::AllAttributes::iTransformableText, ipe::Object::iTransformations, ipe::AllAttributes::iVerticalAlignment, type(), and width().
Text::Text | ( | const Text & | rhs | ) |
Copy constructor.
References ipe::Text::XForm::iRefCount.
Text::~Text | ( | ) |
Destructor.
References ipe::Text::XForm::iRefCount.
|
explicit |
Create from XML stream.
References ipe::Attribute::BLACK(), ipe::EAlignBottom, ipe::EAlignLeft, ipe::EAlignTop, ELabel, EMinipage, ipe::Lex::getDouble(), ipe::XmlAttributes::has(), isMinipage(), ipe::Attribute::makeColor(), makeHAlign(), ipe::Attribute::makeTextSize(), makeVAlign(), ipe::Attribute::NORMAL(), ipe::Attribute::OPAQUE(), ipe::String::size(), ipe::String::substr(), ipe::Vector::x, and ipe::Vector::y.
|
virtual |
|
virtual |
Return pointer to this object.
Reimplemented from ipe::Object.
|
virtual |
Save object to XML stream.
Implements ipe::Object.
References ELabel, EMinipage, isMinipage(), ipe::Attribute::NORMAL(), ipe::Attribute::OPAQUE(), ipe::Stream::putXmlString(), saveAlignment(), ipe::Object::saveAttributesAsXml(), ipe::Attribute::string(), ipe::Vector::x, and ipe::Vector::y.
|
virtual |
Save text as PDF.
Implements ipe::Object.
References align(), ipe::Painter::drawText(), ipe::Object::matrix(), ipe::Painter::pop(), ipe::Painter::popMatrix(), ipe::Painter::push(), ipe::Painter::pushMatrix(), ipe::Painter::setOpacity(), ipe::Painter::setStroke(), ipe::Painter::transform(), ipe::Object::transformations(), ipe::Painter::translate(), and ipe::Painter::untransform().
Referenced by ipe::CanvasBase::drawObjects(), and ipe::Thumbnail::saveRender().
|
virtual |
Draw simple version for selecting and transforming.
Implements ipe::Object.
References align(), ipe::Painter::closePath(), ipe::Painter::drawPath(), ipe::EStrokedOnly, ipe::Painter::lineTo(), ipe::Object::matrix(), ipe::Painter::moveTo(), ipe::Painter::newPath(), ipe::Painter::popMatrix(), ipe::Painter::pushMatrix(), totalHeight(), ipe::Painter::transform(), ipe::Object::transformations(), ipe::Painter::translate(), and ipe::Painter::untransform().
|
virtual |
Call visitText of visitor.
Implements ipe::Object.
References ipe::Visitor::visitText().
Referenced by ipe::Latex::scanPage().
Extend box to include the object transformed by m.
For objects in a page, don't call this directly. The Page caches the bounding box of each object, so it is far more efficient to call Page::bbox.
Control points that lie outside the visual object are included if cp is true.
If called with an empty box and cp == false
, the result of this function is a tight bounding box for the object, with a little leeway in case the boundary is determined by a spline (it has to be approximated to perform this operation).
Implements ipe::Object.
References ipe::Rect::addPoint().
Return distance of transformed object to point v. If larger than bound, can just return bound.
Implements ipe::Object.
|
virtual |
Compute control point snapping position for transformed object.
Looks only for positions closer than bound. If successful, modify pos and bound. The default implementation does nothing.
Reimplemented from ipe::Object.
References ipe::Object::matrix().
|
virtual |
Check symbolic size attribute.
Reimplemented from ipe::Object.
References ipe::Object::checkSymbol(), ipe::EColor, ELabel, ipe::ELabelStyle, ipe::EOpacity, ipe::ETextSize, and ipe::ETextStyle.
Set an attribute on this object.
Returns true if an attribute was actually changed.
Reimplemented from ipe::Object.
References ipe::Attribute::boolean(), ELabel, EMinipage, ipe::EPropHorizontalAlignment, ipe::EPropLabelStyle, ipe::EPropMinipage, ipe::EPropOpacity, ipe::EPropStrokeColor, ipe::EPropTextSize, ipe::EPropTextStyle, ipe::EPropTransformableText, ipe::EPropVerticalAlignment, ipe::EPropWidth, ipe::ETransformationsAffine, ipe::ETransformationsTranslations, ipe::Attribute::horizontalAlignment(), horizontalAlignment(), ipe::Attribute::isEnum(), isMinipage(), ipe::Attribute::isNumber(), ipe::Attribute::NORMAL(), ipe::Attribute::number(), opacity(), ipe::Object::setAttribute(), setOpacity(), setSize(), setStroke(), setStyle(), ipe::Object::setTransformations(), setWidth(), size(), stroke(), style(), ipe::Fixed::toDouble(), ipe::Object::transformations(), ipe::Attribute::verticalAlignment(), verticalAlignment(), and width().
Get setting of an attribute of this object.
If object does not have this attribute, returnes "undefined" attribute.
Reimplemented from ipe::Object.
References ipe::Attribute::Boolean(), ipe::EPropHorizontalAlignment, ipe::EPropLabelStyle, ipe::EPropMinipage, ipe::EPropOpacity, ipe::EPropStrokeColor, ipe::EPropTextSize, ipe::EPropTextStyle, ipe::EPropVerticalAlignment, ipe::EPropWidth, ipe::Fixed::fromDouble(), ipe::Object::getAttribute(), and ipe::size().
Vector Text::align | ( | ) | const |
Return position of reference point in text box coordinate system.
Assume a coordinate system where the text box has corners (0,0) and (Width(), TotalHeight()). This function returns the coordinates of the reference point in this coordinate system.
References depth(), ipe::EAlignBaseline, ipe::EAlignBottom, ipe::EAlignHCenter, ipe::EAlignLeft, ipe::EAlignRight, ipe::EAlignTop, ipe::EAlignVCenter, horizontalAlignment(), totalHeight(), verticalAlignment(), width(), ipe::Vector::x, and ipe::Vector::y.
Referenced by ipe::CairoPainter::doDrawText(), draw(), drawSimple(), setHorizontalAlignment(), and setVerticalAlignment().
Text::TextType Text::textType | ( | ) | const |
|
inline |
Return text position.
|
inline |
Return text source.
Referenced by ipe::Latex::createLatexSource(), ipe::CairoPainter::doDrawText(), and setText().
void Text::setStroke | ( | Attribute | stroke | ) |
Set stroke color.
References stroke().
Referenced by ipe::Page::applyTitleStyle(), and setAttribute().
void Text::setOpacity | ( | Attribute | opaq | ) |
Set opacity of the object.
Referenced by setAttribute().
|
inline |
Return stroke color.
Referenced by ipe::Latex::createLatexSource(), setAttribute(), and setStroke().
|
inline |
Return font size.
Referenced by ipe::Latex::addPageNumber(), setAttribute(), and setSize().
|
inline |
Return Latex style of text object.
Referenced by ipe::Latex::createLatexSource(), setAttribute(), and setStyle().
|
inline |
Return opacity of the opject.
Referenced by setAttribute().
|
inline |
Return true if text object is formatted as a minipage.
Equivalent to type being EMinipage.
References EMinipage.
Referenced by ipe::Latex::createLatexSource(), saveAsXml(), setAttribute(), setXForm(), and Text().
void Text::setTextType | ( | TextType | type | ) |
Change type.
This invalidates (and destroys) the XForm.
References ipe::Attribute::NORMAL(), setXForm(), and type().
|
inline |
Return horizontal alignment of text object.
Referenced by align(), and setAttribute().
|
inline |
Return vertical alignment of text object.
Referenced by align(), and setAttribute().
void Text::setHorizontalAlignment | ( | THorizontalAlignment | align | ) |
Change horizontal alignment (text moves with respect to reference point).
References align().
Referenced by ipe::Page::applyTitleStyle().
void Text::setVerticalAlignment | ( | TVerticalAlignment | align | ) |
Change vertical alignment (text moves with respect to reference point).
References align().
Referenced by ipe::Page::applyTitleStyle().
|
static |
Return vertical alignment indicated by a name, or else default.
References ipe::EAlignBaseline, ipe::EAlignBottom, ipe::EAlignTop, and ipe::EAlignVCenter.
Referenced by ipe::ImlParser::parseStyle(), and Text().
|
static |
Return horizontal alignment indicated by a name, or else default.
References ipe::EAlignHCenter, ipe::EAlignLeft, and ipe::EAlignRight.
Referenced by ipe::ImlParser::parseStyle(), and Text().
|
static |
References ipe::EAlignBaseline, ipe::EAlignBottom, ipe::EAlignHCenter, ipe::EAlignLeft, ipe::EAlignRight, ipe::EAlignTop, and ipe::EAlignVCenter.
Referenced by ipe::StyleSheet::saveAsXml(), and saveAsXml().
|
inline |
Return width of text object.
Referenced by align(), ipe::Latex::createLatexSource(), ipe::BBoxPainter::doDrawText(), ipe::CairoPainter::doDrawText(), setAttribute(), setWidth(), and Text().
|
inline |
Return height of text object (from baseline to top).
|
inline |
Return depth of text object.
Referenced by align().
|
inline |
Return height + depth of text object.
Referenced by align(), ipe::BBoxPainter::doDrawText(), ipe::CairoPainter::doDrawText(), and drawSimple().
void Text::setSize | ( | Attribute | size | ) |
Set font size of text.
This invalidates (and destroys) the XForm.
References setXForm(), and size().
Referenced by ipe::Page::applyTitleStyle(), and setAttribute().
void Text::setStyle | ( | Attribute | style | ) |
Set Latex style of text.
This invalidates (and destroys) the XForm.
References setXForm(), and style().
Referenced by setAttribute().
void Text::setWidth | ( | double | width | ) |
Set width of paragraph.
This invalidates (and destroys) the XForm. The function panics if object is not a (true) minipage.
References EMinipage, setXForm(), textType(), and width().
Referenced by setAttribute().
void Text::setText | ( | String | text | ) |
Sets the text of the text object.
This invalidates (and destroys) the XForm.
References setXForm(), and text().
Referenced by ipe::Page::setTitle().
void Text::setXForm | ( | XForm * | xform | ) | const |
Update the PDF code for this object.
References ipe::Rect::height(), ipe::Text::XForm::iBBox, ipe::Text::XForm::iDepth, ipe::Text::XForm::iRefCount, isMinipage(), ipe::Text::XForm::iStretch, and ipe::Rect::width().
Referenced by setSize(), setStyle(), setText(), setTextType(), and setWidth().
|
inline |
Return the PDF representation of this text object.
If Pdflatex has not been run yet, returns 0.
Referenced by ipe::Latex::createLatexSource(), ipe::PdfPainter::doDrawText(), and ipe::CairoPainter::doDrawText().