2009-02-27 13:57:26 +00:00
|
|
|
/** \ingroup MapComposer
|
|
|
|
* A legend that can be placed onto a map composition
|
|
|
|
*/
|
2012-09-24 02:28:15 +02:00
|
|
|
class QgsComposerLegend : QgsComposerItem
|
2009-02-27 13:57:26 +00:00
|
|
|
{
|
|
|
|
%TypeHeaderCode
|
|
|
|
#include <qgscomposerlegend.h>
|
2013-03-26 20:03:59 +01:00
|
|
|
#include <qgscomposerlegendstyle.h>
|
2009-02-27 13:57:26 +00:00
|
|
|
%End
|
|
|
|
|
|
|
|
public:
|
2009-02-28 14:35:45 +00:00
|
|
|
QgsComposerLegend( QgsComposition* composition /TransferThis/);
|
2009-02-27 13:57:26 +00:00
|
|
|
~QgsComposerLegend();
|
|
|
|
|
2010-11-25 21:45:52 +00:00
|
|
|
/** return correct graphics item type. Added in v1.7 */
|
|
|
|
virtual int type() const;
|
|
|
|
|
2009-02-27 13:57:26 +00:00
|
|
|
/** \brief Reimplementation of QCanvasItem::paint*/
|
|
|
|
void paint( QPainter* painter, const QStyleOptionGraphicsItem* itemStyle, QWidget* pWidget );
|
|
|
|
|
|
|
|
/**Paints the legend and calculates its size. If painter is 0, only size is calculated*/
|
|
|
|
QSizeF paintAndDetermineSize( QPainter* painter );
|
|
|
|
|
|
|
|
/**Sets item box to the whole content*/
|
|
|
|
void adjustBoxSize();
|
|
|
|
|
|
|
|
/**Returns pointer to the legend model*/
|
|
|
|
QgsLegendModel* model();
|
|
|
|
|
|
|
|
//setters and getters
|
|
|
|
void setTitle( const QString& t );
|
|
|
|
QString title() const;
|
|
|
|
|
2014-04-28 19:11:11 +10:00
|
|
|
/**Returns the alignment of the legend title
|
2014-04-07 13:55:44 +02:00
|
|
|
* @returns Qt::AlignmentFlag for the legend title
|
|
|
|
* @note added in 2.3
|
|
|
|
* @see setTitleAlignment
|
|
|
|
*/
|
|
|
|
Qt::AlignmentFlag titleAlignment() const;
|
|
|
|
/**Sets the alignment of the legend title
|
|
|
|
* @param alignment Text alignment for drawing the legend title
|
|
|
|
* @note added in 2.3
|
|
|
|
* @see titleAlignment
|
|
|
|
*/
|
|
|
|
void setTitleAlignment( Qt::AlignmentFlag alignment );
|
|
|
|
|
2013-06-23 16:00:16 +02:00
|
|
|
/** Returns reference to modifiable style */
|
|
|
|
QgsComposerLegendStyle & rstyle( QgsComposerLegendStyle::Style s );
|
|
|
|
/** Returns style */
|
|
|
|
QgsComposerLegendStyle style( QgsComposerLegendStyle::Style s ) const;
|
|
|
|
void setStyle( QgsComposerLegendStyle::Style s, const QgsComposerLegendStyle style );
|
|
|
|
|
2013-03-26 20:03:59 +01:00
|
|
|
QFont styleFont( QgsComposerLegendStyle::Style s ) const;
|
2013-06-23 16:00:16 +02:00
|
|
|
/** Set style font */
|
2013-03-26 20:03:59 +01:00
|
|
|
void setStyleFont( QgsComposerLegendStyle::Style s, const QFont& f );
|
2013-06-23 16:00:16 +02:00
|
|
|
|
|
|
|
/** Set style margin*/
|
2013-03-26 20:03:59 +01:00
|
|
|
void setStyleMargin( QgsComposerLegendStyle::Style s, double margin );
|
|
|
|
void setStyleMargin( QgsComposerLegendStyle::Style s, QgsComposerLegendStyle::Side side, double margin );
|
2009-02-27 13:57:26 +00:00
|
|
|
|
|
|
|
double boxSpace() const;
|
|
|
|
void setBoxSpace( double s );
|
|
|
|
|
2013-06-23 16:00:16 +02:00
|
|
|
double columnSpace() const;
|
|
|
|
void setColumnSpace( double s );
|
|
|
|
|
|
|
|
QColor fontColor() const;
|
|
|
|
void setFontColor( const QColor& c );
|
|
|
|
|
2009-02-27 13:57:26 +00:00
|
|
|
double symbolWidth() const;
|
|
|
|
void setSymbolWidth( double w );
|
|
|
|
|
|
|
|
double symbolHeight() const;
|
|
|
|
void setSymbolHeight( double h );
|
|
|
|
|
2014-01-27 09:22:24 +01:00
|
|
|
double wmsLegendWidth() const;
|
|
|
|
void setWmsLegendWidth( double w );
|
|
|
|
|
|
|
|
double wmsLegendHeight() const;
|
|
|
|
void setWmsLegendHeight( double h );
|
|
|
|
|
2012-09-24 02:28:15 +02:00
|
|
|
void setWrapChar( const QString& t );
|
|
|
|
QString wrapChar() const;
|
|
|
|
|
2013-06-23 16:00:16 +02:00
|
|
|
int columnCount() const;
|
|
|
|
void setColumnCount( int c );
|
|
|
|
|
|
|
|
int splitLayer() const;
|
|
|
|
void setSplitLayer( bool s );
|
|
|
|
|
|
|
|
int equalColumnWidth() const;
|
|
|
|
void setEqualColumnWidth( bool s );
|
|
|
|
|
2012-09-24 02:28:15 +02:00
|
|
|
void setComposerMap( const QgsComposerMap* map );
|
|
|
|
const QgsComposerMap* composerMap() const;
|
|
|
|
|
2009-02-27 13:57:26 +00:00
|
|
|
/**Updates the model and all legend entries*/
|
|
|
|
void updateLegend();
|
|
|
|
|
|
|
|
/** stores state in Dom node
|
|
|
|
* @param elem is Dom element corresponding to 'Composer' tag
|
2012-09-24 02:28:15 +02:00
|
|
|
* @param doc Dom document
|
2009-02-27 13:57:26 +00:00
|
|
|
*/
|
|
|
|
bool writeXML( QDomElement& elem, QDomDocument & doc ) const;
|
|
|
|
|
|
|
|
/** sets state from Dom document
|
|
|
|
* @param itemElem is Dom node corresponding to item tag
|
2012-09-24 02:28:15 +02:00
|
|
|
* @param doc is Dom document
|
2009-02-27 13:57:26 +00:00
|
|
|
*/
|
|
|
|
bool readXML( const QDomElement& itemElem, const QDomDocument& doc );
|
|
|
|
|
|
|
|
public slots:
|
|
|
|
/**Data changed*/
|
|
|
|
void synchronizeWithModel();
|
2012-09-24 02:28:15 +02:00
|
|
|
/**Sets mCompositionMap to 0 if the map is deleted*/
|
|
|
|
void invalidateCurrentMap();
|
2009-02-28 14:35:45 +00:00
|
|
|
};
|