mirror of
https://github.com/fralx/LimeReport.git
synced 2025-01-11 09:08:09 +03:00
Magnet feature has been added
This commit is contained in:
parent
5108c3a49d
commit
59635e3216
@ -52,6 +52,7 @@ namespace Const{
|
||||
double const SELECTED_RESIZE_ZONE_OPACITY = 0.6;
|
||||
Qt::GlobalColor const RESIZE_ZONE_COLOR = Qt::green;
|
||||
Qt::GlobalColor const SELECTION_COLOR = Qt::red;
|
||||
Qt::GlobalColor const JOIN_COLOR = Qt::blue;
|
||||
double const SELECTION_COLOR_OPACITY = 0.6;
|
||||
const qreal fontFACTOR = 3.5;
|
||||
const int mmFACTOR = 10;
|
||||
|
BIN
src/images/magnet.png
Normal file
BIN
src/images/magnet.png
Normal file
Binary file not shown.
After Width: | Height: | Size: 782 B |
@ -163,6 +163,7 @@ public:
|
||||
virtual bool isHeader() const {return false;}
|
||||
virtual bool isGroupHeader() const {return false;}
|
||||
virtual bool isData() const {return false;}
|
||||
bool isBand(){return true;}
|
||||
|
||||
void setTryToKeepTogether(bool value);
|
||||
bool tryToKeepTogether();
|
||||
|
@ -69,6 +69,7 @@ BaseDesignIntf::BaseDesignIntf(const QString &storageTypeName, QObject *owner, Q
|
||||
m_itemMode(DesignMode),
|
||||
m_objectState(ObjectCreated),
|
||||
m_selectionMarker(0),
|
||||
m_joinMarker(0),
|
||||
m_backgroundBrush(Solid),
|
||||
m_backgroundBrushcolor(Qt::white),
|
||||
m_margin(4),
|
||||
@ -82,9 +83,8 @@ BaseDesignIntf::BaseDesignIntf(const QString &storageTypeName, QObject *owner, Q
|
||||
m_font = QFont("Arial",10);
|
||||
}
|
||||
initFlags();
|
||||
m_selectionMarker = new SelectionMarker(this);
|
||||
m_selectionMarker->setColor(Const::SELECTION_COLOR);
|
||||
m_selectionMarker->setVisible(false);
|
||||
|
||||
|
||||
//connect(this,SIGNAL(objectNameChanged(QString)),this,SLOT(slotObjectNameChanged(QString)));
|
||||
}
|
||||
|
||||
@ -99,7 +99,10 @@ QRectF BaseDesignIntf::boundingRect() const
|
||||
return m_boundingRect;
|
||||
}
|
||||
|
||||
BaseDesignIntf::~BaseDesignIntf(void) {delete m_selectionMarker;}
|
||||
BaseDesignIntf::~BaseDesignIntf(void) {
|
||||
delete m_selectionMarker;
|
||||
delete m_joinMarker;
|
||||
}
|
||||
|
||||
void BaseDesignIntf::setParentReportItem(const QString &value)
|
||||
{
|
||||
@ -112,7 +115,7 @@ void BaseDesignIntf::setParentReportItem(const QString &value)
|
||||
}
|
||||
}
|
||||
|
||||
QString BaseDesignIntf::parentReportItem()
|
||||
QString BaseDesignIntf::parentReportItemName()
|
||||
{
|
||||
BaseDesignIntf *parent = dynamic_cast<BaseDesignIntf *>(parentItem());
|
||||
if (parent) return parent->objectName();
|
||||
@ -292,7 +295,7 @@ void BaseDesignIntf::mousePressEvent(QGraphicsSceneMouseEvent *event)
|
||||
m_startPos = pos();
|
||||
m_oldGeometry = geometry();
|
||||
QGraphicsItem::mousePressEvent(event);
|
||||
QApplication::processEvents();
|
||||
//QApplication::processEvents();
|
||||
emit(itemSelected(this));
|
||||
}
|
||||
else QGraphicsItem::mousePressEvent(event);
|
||||
@ -392,22 +395,10 @@ void BaseDesignIntf::hoverLeaveEvent(QGraphicsSceneHoverEvent *)
|
||||
|
||||
void BaseDesignIntf::mouseMoveEvent(QGraphicsSceneMouseEvent *event)
|
||||
{
|
||||
|
||||
// if (!scene()->items(event->scenePos()).contains(parentItem())){
|
||||
// BandDesignIntf* band = 0;
|
||||
// PageItemDesignIntf* pageItem = 0;
|
||||
// foreach (QGraphicsItem* item, scene()->items(event->scenePos())) {
|
||||
// band = dynamic_cast<BandDesignIntf*>(item);
|
||||
// if (band){
|
||||
// break;
|
||||
// }
|
||||
// pageItem = dynamic_cast<PageItemDesignIntf*>(item);
|
||||
// }
|
||||
// if (band)
|
||||
// qDebug()<<"band found"<<band->objectName();
|
||||
// if (pageItem)
|
||||
// qDebug()<<"page found"<<pageItem->objectName();
|
||||
// }
|
||||
if (!isSelected()){
|
||||
QGraphicsItem::mouseMoveEvent(event);
|
||||
return;
|
||||
}
|
||||
|
||||
int hStep = dynamic_cast<PageDesignIntf*>(scene())->horizontalGridStep();
|
||||
int vStep = dynamic_cast<PageDesignIntf*>(scene())->verticalGridStep();
|
||||
@ -469,7 +460,11 @@ void BaseDesignIntf::mouseMoveEvent(QGraphicsSceneMouseEvent *event)
|
||||
};
|
||||
|
||||
setItemPos(m_startPos - delta);
|
||||
|
||||
if (!isBand() && scene()->selectedItems().count()>1)
|
||||
moveSelectedItems(tmpPos - pos());
|
||||
if (scene()->selectedItems().count()==1 && (page()->magneticMovement()))
|
||||
page()->itemMoved(this);
|
||||
}
|
||||
}
|
||||
|
||||
@ -571,6 +566,19 @@ QPointF BaseDesignIntf::modifyPosForAlignedItem(const QPointF& pos){
|
||||
return result;
|
||||
}
|
||||
|
||||
void BaseDesignIntf::turnOnJoinMarker(bool value)
|
||||
{
|
||||
if (value){
|
||||
m_joinMarker = new Marker(this);
|
||||
m_joinMarker->setColor(Const::JOIN_COLOR);
|
||||
m_joinMarker->setRect(rect());
|
||||
m_joinMarker->setVisible(true);
|
||||
} else {
|
||||
delete m_joinMarker;
|
||||
m_joinMarker = 0;
|
||||
}
|
||||
}
|
||||
|
||||
void BaseDesignIntf::updateItemAlign(){
|
||||
BaseDesignIntf* parent = dynamic_cast<BaseDesignIntf*>(parentItem());
|
||||
PageItemDesignIntf* parentPage = dynamic_cast<PageItemDesignIntf*>(parentItem());
|
||||
@ -604,6 +612,19 @@ void BaseDesignIntf::updatePosibleDirectionFlags(){
|
||||
}
|
||||
}
|
||||
|
||||
void BaseDesignIntf::turnOnSelectionMarker(bool value)
|
||||
{
|
||||
if (value && !m_selectionMarker){
|
||||
m_selectionMarker = new SelectionMarker(this);
|
||||
m_selectionMarker->setColor(selectionMarkerColor());
|
||||
updateSelectionMarker();
|
||||
m_selectionMarker->setVisible(true);
|
||||
} else {
|
||||
delete m_selectionMarker;
|
||||
m_selectionMarker = 0;
|
||||
}
|
||||
}
|
||||
|
||||
void BaseDesignIntf::setItemAlign(const ItemAlign &itemAlign)
|
||||
{
|
||||
if (m_itemAlign != itemAlign){
|
||||
@ -864,8 +885,7 @@ QVariant BaseDesignIntf::itemChange(QGraphicsItem::GraphicsItemChange change, co
|
||||
updateSelectionMarker();
|
||||
}
|
||||
if (change == QGraphicsItem::ItemSelectedChange) {
|
||||
updateSelectionMarker();
|
||||
m_selectionMarker->setVisible(value.toBool());
|
||||
turnOnSelectionMarker(value.toBool());
|
||||
}
|
||||
if (change == QGraphicsItem::ItemParentHasChanged) {
|
||||
parentChangedEvent(dynamic_cast<BaseDesignIntf*>(value.value<QGraphicsItem*>()));
|
||||
@ -916,7 +936,7 @@ void BaseDesignIntf::moveSelectedItems(QPointF delta)
|
||||
foreach(QGraphicsItem * item, selectedItems) {
|
||||
if (item != this) {
|
||||
selectedItem = dynamic_cast<BaseDesignIntf *>(item);
|
||||
if (selectedItem) {
|
||||
if (selectedItem && !selectedItem->isBand()) {
|
||||
if (!selectedItem->m_fixedPos)
|
||||
selectedItem->setItemPos(selectedItem->pos() - delta);
|
||||
}
|
||||
@ -1023,7 +1043,7 @@ void BaseDesignIntf::updateSelectionMarker()
|
||||
if ((!m_selectionMarker->scene()) && scene()) scene()->addItem(m_selectionMarker);
|
||||
if (parentItem()) {
|
||||
m_selectionMarker->setRect(rect());
|
||||
m_selectionMarker->setPos(0,0/*parentItem()->mapToScene(pos())*/);
|
||||
m_selectionMarker->setPos(0,0);
|
||||
}
|
||||
}
|
||||
}
|
||||
@ -1235,45 +1255,11 @@ void BaseDesignIntf::notify(const QVector<QString>& propertyNames)
|
||||
}
|
||||
|
||||
SelectionMarker::SelectionMarker(QGraphicsItem *parent)//, QGraphicsScene *scene)
|
||||
: QGraphicsItem(parent)//, scene)
|
||||
: Marker(parent)
|
||||
{
|
||||
setAcceptHoverEvents(true);
|
||||
}
|
||||
|
||||
QRectF SelectionMarker::boundingRect() const
|
||||
{
|
||||
return m_rect.adjusted(-15,-15,15,15);
|
||||
}
|
||||
|
||||
void SelectionMarker::paint(QPainter *painter, const QStyleOptionGraphicsItem *, QWidget *)
|
||||
{
|
||||
QPen pen;
|
||||
const int markerSize = 5;
|
||||
pen.setColor(m_color);
|
||||
pen.setWidth(2);
|
||||
pen.setStyle(Qt::DotLine);
|
||||
painter->setPen(pen);
|
||||
painter->setOpacity(Const::SELECTION_COLOR_OPACITY);
|
||||
painter->drawRect(m_rect);
|
||||
painter->setBrush(m_color);
|
||||
painter->setPen(Qt::transparent);
|
||||
painter->setOpacity(1);
|
||||
painter->drawRect(QRectF(-markerSize,-markerSize,markerSize*2,markerSize*2));
|
||||
painter->drawRect(QRectF(m_rect.right()-markerSize,m_rect.bottom()-markerSize,markerSize*2,markerSize*2));
|
||||
painter->drawRect(QRectF(m_rect.right()-markerSize,m_rect.top()-markerSize,markerSize*2,markerSize*2));
|
||||
painter->drawRect(QRectF(m_rect.left()-markerSize,m_rect.bottom()-markerSize,markerSize*2,markerSize*2));
|
||||
painter->drawRect(QRectF(m_rect.left()-markerSize,
|
||||
m_rect.bottom()-m_rect.height()/2-markerSize,markerSize*2,markerSize*2));
|
||||
painter->drawRect(QRectF(m_rect.right()-markerSize,
|
||||
m_rect.bottom()-m_rect.height()/2-markerSize,markerSize*2,markerSize*2));
|
||||
painter->drawRect(QRectF(m_rect.left()+m_rect.width()/2-markerSize,
|
||||
m_rect.top()-markerSize,markerSize*2,markerSize*2));
|
||||
painter->drawRect(QRectF(m_rect.left()+m_rect.width()/2-markerSize,
|
||||
m_rect.bottom()-markerSize,markerSize*2,markerSize*2));
|
||||
|
||||
//painter->drawRect();
|
||||
}
|
||||
|
||||
void SelectionMarker::hoverMoveEvent(QGraphicsSceneHoverEvent *event)
|
||||
{
|
||||
BaseDesignIntf* baseItem = dynamic_cast<BaseDesignIntf*>(parentItem());
|
||||
@ -1307,6 +1293,53 @@ void SelectionMarker::mouseMoveEvent(QGraphicsSceneMouseEvent *event)
|
||||
if(baseItem) baseItem->mouseMoveEvent(event);
|
||||
}
|
||||
|
||||
QRectF Marker::boundingRect() const
|
||||
{
|
||||
return m_rect.adjusted(-15,-15,15,15);
|
||||
}
|
||||
|
||||
void Marker::paint(QPainter *painter, const QStyleOptionGraphicsItem *, QWidget *)
|
||||
{
|
||||
QPen pen;
|
||||
const int markerSize = 5;
|
||||
pen.setColor(color());
|
||||
pen.setWidth(2);
|
||||
pen.setStyle(Qt::DotLine);
|
||||
painter->setPen(pen);
|
||||
painter->setOpacity(Const::SELECTION_COLOR_OPACITY);
|
||||
painter->drawRect(rect());
|
||||
painter->setBrush(color());
|
||||
painter->setPen(Qt::transparent);
|
||||
painter->setOpacity(1);
|
||||
painter->drawRect(QRectF(-markerSize,-markerSize,markerSize*2,markerSize*2));
|
||||
painter->drawRect(QRectF(rect().right()-markerSize,rect().bottom()-markerSize,markerSize*2,markerSize*2));
|
||||
painter->drawRect(QRectF(rect().right()-markerSize,rect().top()-markerSize,markerSize*2,markerSize*2));
|
||||
painter->drawRect(QRectF(rect().left()-markerSize,rect().bottom()-markerSize,markerSize*2,markerSize*2));
|
||||
painter->drawRect(QRectF(rect().left()-markerSize,
|
||||
rect().bottom()-rect().height()/2-markerSize,markerSize*2,markerSize*2));
|
||||
painter->drawRect(QRectF(rect().right()-markerSize,
|
||||
rect().bottom()-rect().height()/2-markerSize,markerSize*2,markerSize*2));
|
||||
painter->drawRect(QRectF(rect().left()+rect().width()/2-markerSize,
|
||||
rect().top()-markerSize,markerSize*2,markerSize*2));
|
||||
painter->drawRect(QRectF(rect().left()+rect().width()/2-markerSize,
|
||||
rect().bottom()-markerSize,markerSize*2,markerSize*2));
|
||||
}
|
||||
|
||||
QRectF Marker::rect() const
|
||||
{
|
||||
return m_rect;
|
||||
}
|
||||
|
||||
QColor Marker::color() const
|
||||
{
|
||||
return m_color;
|
||||
}
|
||||
|
||||
BaseDesignIntf *Marker::object() const
|
||||
{
|
||||
return m_object;
|
||||
}
|
||||
|
||||
|
||||
}
|
||||
|
||||
|
@ -48,23 +48,31 @@ class ReportEnginePrivate;
|
||||
class PageDesignIntf;
|
||||
class BaseDesignIntf;
|
||||
|
||||
class SelectionMarker : public QGraphicsItem{
|
||||
class Marker : public QGraphicsItem{
|
||||
public:
|
||||
SelectionMarker(QGraphicsItem* parent=0);//, QGraphicsScene* scene=0);
|
||||
Marker(QGraphicsItem* parent=0):QGraphicsItem(parent){}
|
||||
QRectF boundingRect() const;
|
||||
void paint(QPainter *painter, const QStyleOptionGraphicsItem *, QWidget *);
|
||||
void setRect(QRectF rect){prepareGeometryChange();m_rect=rect;}
|
||||
void setColor(QColor color){m_color=color;}
|
||||
QRectF rect() const;
|
||||
QColor color() const;
|
||||
BaseDesignIntf *object() const;
|
||||
private:
|
||||
QRectF m_rect;
|
||||
QColor m_color;
|
||||
BaseDesignIntf* m_object;
|
||||
};
|
||||
|
||||
class SelectionMarker : public Marker{
|
||||
public:
|
||||
SelectionMarker(QGraphicsItem* parent=0);
|
||||
protected:
|
||||
void hoverMoveEvent(QGraphicsSceneHoverEvent *event);
|
||||
void mousePressEvent(QGraphicsSceneMouseEvent *event);
|
||||
void mouseReleaseEvent(QGraphicsSceneMouseEvent *event);
|
||||
void mouseDoubleClickEvent(QGraphicsSceneMouseEvent *event);
|
||||
void mouseMoveEvent(QGraphicsSceneMouseEvent *event);
|
||||
private:
|
||||
QRectF m_rect;
|
||||
QColor m_color;
|
||||
BaseDesignIntf* m_object;
|
||||
};
|
||||
|
||||
class DataSourceManager;
|
||||
@ -82,7 +90,7 @@ class BaseDesignIntf :
|
||||
Q_PROPERTY(ACollectionProperty children READ fakeCollectionReader DESIGNABLE false)
|
||||
Q_PROPERTY(qreal zOrder READ zValue WRITE setZValueProperty DESIGNABLE false)
|
||||
Q_PROPERTY(BorderLines borders READ borderLines WRITE setBorderLinesFlags)
|
||||
Q_PROPERTY(QString parentName READ parentReportItem WRITE setParentReportItem DESIGNABLE false)
|
||||
Q_PROPERTY(QString parentName READ parentReportItemName WRITE setParentReportItem DESIGNABLE false)
|
||||
Q_PROPERTY(int borderLineSize READ borderLineSize WRITE setBorderLineSize)
|
||||
Q_PROPERTY(bool isVisible READ isVisible WRITE setVisible DESIGNABLE false)
|
||||
|
||||
@ -115,7 +123,7 @@ public:
|
||||
virtual ~BaseDesignIntf();
|
||||
|
||||
void setParentReportItem(const QString& value);
|
||||
QString parentReportItem();
|
||||
QString parentReportItemName();
|
||||
|
||||
BrushMode backgroundBrushMode(){return m_backgroundBrush;}
|
||||
void setBackgroundBrushMode(BrushMode value);
|
||||
@ -231,6 +239,8 @@ public:
|
||||
virtual void setItemAlign(const ItemAlign &itemAlign);
|
||||
void updateItemAlign();
|
||||
QPointF modifyPosForAlignedItem(const QPointF &pos);
|
||||
void turnOnJoinMarker(bool value);
|
||||
virtual bool isBand(){return false;}
|
||||
protected:
|
||||
|
||||
//ICollectionContainer
|
||||
@ -277,7 +287,7 @@ protected:
|
||||
RenderPass currentRenderPass(){return m_currentPass;}
|
||||
|
||||
virtual bool drawDesignBorders() const {return true;}
|
||||
SelectionMarker* selectionMarker() {return m_selectionMarker;}
|
||||
virtual QColor selectionMarkerColor(){ return Const::SELECTION_COLOR;}
|
||||
private:
|
||||
void updateSelectionMarker();
|
||||
int resizeDirectionFlags(QPointF position);
|
||||
@ -285,6 +295,7 @@ private:
|
||||
Qt::CursorShape getPosibleCursor(int cursorFlags);
|
||||
void setZValueProperty(qreal value);
|
||||
void updatePosibleDirectionFlags();
|
||||
void turnOnSelectionMarker(bool value);
|
||||
private:
|
||||
QPointF m_startPos;
|
||||
//QPointF m_startScenePos;
|
||||
@ -321,6 +332,7 @@ private:
|
||||
|
||||
ObjectState m_objectState;
|
||||
SelectionMarker* m_selectionMarker;
|
||||
Marker* m_joinMarker;
|
||||
|
||||
BrushMode m_backgroundBrush;
|
||||
QColor m_backgroundBrushcolor;
|
||||
|
@ -52,6 +52,7 @@ namespace Const{
|
||||
double const SELECTED_RESIZE_ZONE_OPACITY = 0.6;
|
||||
Qt::GlobalColor const RESIZE_ZONE_COLOR = Qt::green;
|
||||
Qt::GlobalColor const SELECTION_COLOR = Qt::red;
|
||||
Qt::GlobalColor const JOIN_COLOR = Qt::blue;
|
||||
double const SELECTION_COLOR_OPACITY = 0.6;
|
||||
const qreal fontFACTOR = 3.5;
|
||||
const int mmFACTOR = 10;
|
||||
|
@ -89,7 +89,10 @@ PageDesignIntf::PageDesignIntf(QObject *parent):
|
||||
m_horizontalGridStep(2),
|
||||
m_updating(false),
|
||||
m_currentObjectIndex(1),
|
||||
m_multiSelectStarted(false)
|
||||
m_multiSelectStarted(false),
|
||||
m_movedItem(0),
|
||||
m_joinItem(0),
|
||||
m_magneticMovement(false)
|
||||
{
|
||||
m_reportEditor = dynamic_cast<ReportEnginePrivate *>(parent);
|
||||
updatePageRect();
|
||||
@ -315,11 +318,7 @@ void PageDesignIntf::mouseMoveEvent(QGraphicsSceneMouseEvent *event)
|
||||
}
|
||||
}
|
||||
|
||||
if (event->button() & Qt::LeftButton && event->modifiers()==0){
|
||||
|
||||
}
|
||||
|
||||
if (event->buttons() & Qt::LeftButton && m_multiSelectStarted/*event->modifiers()==Qt::ShiftModifier*/){
|
||||
if (event->buttons() & Qt::LeftButton && m_multiSelectStarted){
|
||||
if (!m_selectionRect){
|
||||
m_selectionRect = new QGraphicsRectItem();
|
||||
QBrush brush(QColor(140,190,30,50));
|
||||
@ -350,6 +349,35 @@ void PageDesignIntf::mouseMoveEvent(QGraphicsSceneMouseEvent *event)
|
||||
void PageDesignIntf::mouseReleaseEvent(QGraphicsSceneMouseEvent *event)
|
||||
{
|
||||
if ( (event->button() == Qt::LeftButton)) {
|
||||
if (m_joinItem && selectedItems().count()==1){
|
||||
BaseDesignIntf* selectedItem = dynamic_cast<BaseDesignIntf*>(selectedItems().at(0));
|
||||
if (m_magneticMovement){
|
||||
if (m_joinType == Width){
|
||||
|
||||
QPointF tmpPos;
|
||||
if (selectedItem->pos().y()>m_joinItem->pos().y())
|
||||
tmpPos = QPointF(m_joinItem->x(),m_joinItem->pos().y()+m_joinItem->height());
|
||||
else
|
||||
tmpPos = QPointF(m_joinItem->x(),m_joinItem->pos().y()-selectedItem->height());
|
||||
|
||||
selectedItem->setPos(tmpPos);
|
||||
selectedItem->setWidth(m_joinItem->width());
|
||||
|
||||
} else {
|
||||
|
||||
QPointF tmpPos;
|
||||
if (selectedItem->pos().x()>m_joinItem->pos().x())
|
||||
tmpPos = QPointF(m_joinItem->x()+m_joinItem->width(),m_joinItem->pos().y());
|
||||
else
|
||||
tmpPos = QPointF(m_joinItem->x()-selectedItem->width(),m_joinItem->pos().y());
|
||||
|
||||
selectedItem->setPos(tmpPos);
|
||||
selectedItem->setHeight(m_joinItem->height());
|
||||
}
|
||||
}
|
||||
m_joinItem->turnOnJoinMarker(false);
|
||||
m_joinItem = 0;
|
||||
}
|
||||
checkSizeOrPosChanges();
|
||||
}
|
||||
if (m_selectionRect) {
|
||||
@ -1016,6 +1044,16 @@ void PageDesignIntf::changeSelectedGroupProperty(const QString &name, const QVar
|
||||
}
|
||||
}
|
||||
|
||||
bool PageDesignIntf::magneticMovement() const
|
||||
{
|
||||
return m_magneticMovement;
|
||||
}
|
||||
|
||||
void PageDesignIntf::setMagneticMovement(bool magneticMovement)
|
||||
{
|
||||
m_magneticMovement = magneticMovement;
|
||||
}
|
||||
|
||||
int PageDesignIntf::horizontalGridStep() const
|
||||
{
|
||||
return m_horizontalGridStep;
|
||||
@ -1032,6 +1070,51 @@ void PageDesignIntf::endUpdate()
|
||||
emit pageUpdateFinished(this);
|
||||
}
|
||||
|
||||
void PageDesignIntf::itemMoved(BaseDesignIntf *item)
|
||||
{
|
||||
if (m_movedItem!=item){
|
||||
BaseDesignIntf* curItem = dynamic_cast<BaseDesignIntf*>(item->parentItem()); ;
|
||||
while (curItem){
|
||||
m_movedItemContainer = dynamic_cast<BandDesignIntf*>(curItem);
|
||||
if (!m_movedItemContainer)
|
||||
m_movedItemContainer = dynamic_cast<PageItemDesignIntf*>(curItem);
|
||||
if (m_movedItemContainer) break;
|
||||
else curItem = dynamic_cast<BaseDesignIntf*>(curItem->parentItem());
|
||||
}
|
||||
if (m_movedItemContainer){
|
||||
m_projections.clear();
|
||||
foreach(BaseDesignIntf* bi, m_movedItemContainer->childBaseItems()){
|
||||
if (bi != item)
|
||||
m_projections.append(ItemProjections(bi));
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
QRectF r1(item->pos().x(),item->pos().y()-50,item->width(),item->height()+100);
|
||||
QRectF r2(item->pos().x()-50,item->pos().y(),item->width()+100,item->height());
|
||||
qreal maxSquare = 0;
|
||||
|
||||
if (m_joinItem) {
|
||||
m_joinItem->turnOnJoinMarker(false);
|
||||
m_joinItem = 0;
|
||||
}
|
||||
|
||||
foreach(ItemProjections p, m_projections){
|
||||
qreal tmpSquare = qMax(p.square(r1)/item->width(),p.square(r2)/item->height());
|
||||
if (tmpSquare>maxSquare) {
|
||||
maxSquare = tmpSquare;
|
||||
m_joinItem = p.item();
|
||||
if (p.square(r1)/item->width()>p.square(r2)/item->height())
|
||||
m_joinType = Width;
|
||||
else
|
||||
m_joinType = Height;
|
||||
}
|
||||
}
|
||||
|
||||
if (m_joinItem) m_joinItem->turnOnJoinMarker(true);
|
||||
|
||||
}
|
||||
|
||||
int PageDesignIntf::verticalGridStep() const
|
||||
{
|
||||
return m_verticalGridStep;
|
||||
@ -1907,13 +1990,13 @@ void CommandGroup::undoIt()
|
||||
|
||||
void CommandGroup::addCommand(CommandIf::Ptr command, bool execute)
|
||||
{
|
||||
if (execute)
|
||||
if (execute){
|
||||
if (command->doIt())
|
||||
m_commands.append(command);
|
||||
|
||||
else
|
||||
}else{
|
||||
m_commands.append(command);
|
||||
}
|
||||
}
|
||||
|
||||
PrintRange::PrintRange(QAbstractPrintDialog::PrintRange rangeType, int fromPage, int toPage)
|
||||
:m_rangeType(rangeType), m_fromPage(fromPage), m_toPage(toPage)
|
||||
@ -2023,10 +2106,6 @@ bool PropertyItemAlignChangedCommand::doIt()
|
||||
{
|
||||
BaseDesignIntf *reportItem = page()->reportItemByName(m_objectName);
|
||||
|
||||
//if (m_oldValue == BaseDesignIntf::DesignedItemAlign){
|
||||
// m_savedPos = reportItem->pos();
|
||||
//}
|
||||
|
||||
if (reportItem && (reportItem->property(m_propertyName.toLatin1()) != m_newValue)) {
|
||||
reportItem->setProperty(m_propertyName.toLatin1(), m_newValue);
|
||||
}
|
||||
@ -2046,5 +2125,64 @@ void PropertyItemAlignChangedCommand::undoIt()
|
||||
}
|
||||
}
|
||||
|
||||
bool Projection::intersect(Projection projection)
|
||||
{
|
||||
if (
|
||||
(projection.start()>=start() && projection.start()<=end()) ||
|
||||
(projection.end()>=start() && projection.end()<=end()) ||
|
||||
(projection.start()<=start() && projection.end()>=end())
|
||||
) return true;
|
||||
return false;
|
||||
}
|
||||
|
||||
qreal Projection::start() const
|
||||
{
|
||||
return m_start;
|
||||
}
|
||||
|
||||
qreal Projection::end() const
|
||||
{
|
||||
return m_end;
|
||||
}
|
||||
|
||||
bool ItemProjections::intersect(QRectF rect)
|
||||
{
|
||||
Projection xProjection(rect.x(),rect.x()+rect.width());
|
||||
Projection yProjection(rect.y(),rect.y()+rect.height());
|
||||
if (m_xProjection.intersect(xProjection) && m_yProjection.intersect(yProjection))
|
||||
return true;
|
||||
return false;
|
||||
}
|
||||
|
||||
bool ItemProjections::intersect(BaseDesignIntf *item)
|
||||
{
|
||||
return intersect(QRectF(item->pos().x(), item->pos().y(), item->width(), item->height()));
|
||||
}
|
||||
|
||||
qreal lineLength(qreal start, qreal end, Projection p){
|
||||
qreal result = 0;
|
||||
if (start>=p.start() && end<=p.end())
|
||||
result = end - start;
|
||||
if (start>=p.start() && start<=p.end())
|
||||
result = p.end() - start;
|
||||
else if (end>=p.start() && end<=p.end())
|
||||
result = end-p.start();
|
||||
else if (start<=p.start() && end>=p.end())
|
||||
result = p.end() - p.start();
|
||||
return result;
|
||||
}
|
||||
|
||||
qreal ItemProjections::square(QRectF rect)
|
||||
{
|
||||
qreal a = lineLength(rect.left(),rect.right(),m_xProjection);
|
||||
qreal b = lineLength(rect.top(),rect.bottom(),m_yProjection);
|
||||
return a*b;
|
||||
}
|
||||
|
||||
qreal ItemProjections::square(BaseDesignIntf *item)
|
||||
{
|
||||
return square(QRectF(item->pos().x(),item->pos().y(),item->width(),item->height()));
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
|
@ -66,6 +66,36 @@ namespace LimeReport {
|
||||
QSizeF size;
|
||||
};
|
||||
|
||||
class Projection{
|
||||
public:
|
||||
Projection(qreal start, qreal end)
|
||||
:m_start(start),m_end(end){}
|
||||
bool intersect(Projection projection);
|
||||
qreal start() const;
|
||||
qreal end() const;
|
||||
private:
|
||||
qreal m_start;
|
||||
qreal m_end;
|
||||
};
|
||||
|
||||
class ItemProjections{
|
||||
public:
|
||||
ItemProjections(BaseDesignIntf* item)
|
||||
:m_xProjection(item->pos().x(), item->pos().x()+item->width()),
|
||||
m_yProjection(item->pos().y(), item->pos().y()+item->height()),
|
||||
m_item(item)
|
||||
{}
|
||||
bool intersect(QRectF rect);
|
||||
bool intersect(BaseDesignIntf* item);
|
||||
qreal square(QRectF rect);
|
||||
qreal square(BaseDesignIntf* item);
|
||||
BaseDesignIntf* item(){return m_item;}
|
||||
private:
|
||||
Projection m_xProjection;
|
||||
Projection m_yProjection;
|
||||
BaseDesignIntf* m_item;
|
||||
};
|
||||
|
||||
class PageDesignIntf : public QGraphicsScene, public ObjectLoadingStateIntf{
|
||||
Q_OBJECT
|
||||
Q_PROPERTY(QObject* pageItem READ pageItem())
|
||||
@ -143,6 +173,11 @@ namespace LimeReport {
|
||||
void beginUpdate(){m_updating = true;}
|
||||
bool isUpdating(){return m_updating;}
|
||||
void endUpdate();
|
||||
|
||||
void itemMoved(BaseDesignIntf* item);
|
||||
bool magneticMovement() const;
|
||||
void setMagneticMovement(bool magneticMovement);
|
||||
|
||||
protected:
|
||||
|
||||
virtual void keyPressEvent(QKeyEvent *event);
|
||||
@ -233,6 +268,7 @@ namespace LimeReport {
|
||||
void changeSelectedGroupProperty(const QString& name,const QVariant& value);
|
||||
|
||||
private:
|
||||
enum JoinType{Width, Height};
|
||||
PageSize m_pageSize;
|
||||
QSizeF m_pageSizeValue;
|
||||
Orientation m_orientation;
|
||||
@ -267,6 +303,12 @@ namespace LimeReport {
|
||||
bool m_updating;
|
||||
int m_currentObjectIndex;
|
||||
bool m_multiSelectStarted;
|
||||
QList<ItemProjections> m_projections;
|
||||
BaseDesignIntf* m_movedItem;
|
||||
BaseDesignIntf* m_movedItemContainer;
|
||||
BaseDesignIntf* m_joinItem;
|
||||
JoinType m_joinType;
|
||||
bool m_magneticMovement;
|
||||
};
|
||||
|
||||
class AbstractPageCommand : public CommandIf{
|
||||
|
@ -52,7 +52,6 @@ PageItemDesignIntf::PageItemDesignIntf(QObject *owner, QGraphicsItem *parent) :
|
||||
setFixedPos(true);
|
||||
setPosibleResizeDirectionFlags(Fixed);
|
||||
initPageSize(m_pageSize);
|
||||
selectionMarker()->setColor(Qt::transparent);
|
||||
}
|
||||
|
||||
PageItemDesignIntf::PageItemDesignIntf(const PageSize pageSize, const QRectF &rect, QObject *owner, QGraphicsItem *parent) :
|
||||
|
@ -113,6 +113,7 @@ protected:
|
||||
QSizeF getRectByPageSize(const PageSize &size);
|
||||
void initPageSize(const PageSize &size);
|
||||
void initPageSize(const QSizeF &size);
|
||||
QColor selectionMarkerColor(){return Qt::transparent;}
|
||||
private:
|
||||
void paintGrid(QPainter *ppainter);
|
||||
void initColumnsPos(QVector<qreal>&posByColumns, qreal pos, int columnCount);
|
||||
|
@ -134,6 +134,19 @@ ReportDesignWidget::ReportDesignWidget(ReportEnginePrivate *report, QMainWindow
|
||||
#endif
|
||||
}
|
||||
|
||||
bool ReportDesignWidget::useMagnet() const
|
||||
{
|
||||
return m_useMagnet;
|
||||
}
|
||||
|
||||
void ReportDesignWidget::setUseMagnet(bool useMagnet)
|
||||
{
|
||||
m_useMagnet = useMagnet;
|
||||
for (int i=0;i<m_report->pageCount();++i){
|
||||
m_report->pageAt(i)->setMagneticMovement(useMagnet);
|
||||
}
|
||||
}
|
||||
|
||||
void ReportDesignWidget::saveState(QSettings* settings)
|
||||
{
|
||||
settings->beginGroup("DesignerWidget");
|
||||
|
@ -99,6 +99,8 @@ public:
|
||||
void applySettings();
|
||||
void applyUseGrid();
|
||||
bool useGrid(){ return m_useGrid;}
|
||||
bool useMagnet() const;
|
||||
void setUseMagnet(bool useMagnet);
|
||||
|
||||
public slots:
|
||||
void saveToFile(const QString&);
|
||||
@ -161,6 +163,7 @@ private:
|
||||
int m_verticalGridStep;
|
||||
int m_horizontalGridStep;
|
||||
bool m_useGrid;
|
||||
bool m_useMagnet;
|
||||
// static ReportDesignWidget* m_instance;
|
||||
};
|
||||
|
||||
|
@ -136,8 +136,16 @@ void ReportDesignWindow::createActions()
|
||||
m_useGridAction = new QAction(tr("Use grid"),this);
|
||||
m_useGridAction->setIcon(QIcon(":/report/images/grid"));
|
||||
m_useGridAction->setCheckable(true);
|
||||
m_useGridAction->setShortcut(QKeySequence(Qt::CTRL + Qt::Key_G));
|
||||
connect(m_useGridAction,SIGNAL(toggled(bool)),this,SLOT(slotUseGrid(bool)));
|
||||
|
||||
m_useMagnetAction = new QAction(tr("Use magnet"),this);
|
||||
m_useMagnetAction->setIcon(QIcon(":/report/images/magnet"));
|
||||
m_useMagnetAction->setCheckable(true);
|
||||
m_useMagnetAction->setShortcut(QKeySequence(Qt::CTRL + Qt::Key_M));
|
||||
connect(m_useMagnetAction,SIGNAL(toggled(bool)),this,SLOT(slotUseMagnet(bool)));
|
||||
|
||||
|
||||
m_newTextItemAction = new QAction(tr("Text Item"),this);
|
||||
m_newTextItemAction->setIcon(QIcon(":/items/TextItem"));
|
||||
m_actionMap.insert("TextItem",m_newTextItemAction);
|
||||
@ -281,6 +289,8 @@ void ReportDesignWindow::createToolBars()
|
||||
m_itemsAlignmentEditorBar->setIconSize(m_mainToolBar->iconSize());
|
||||
m_itemsAlignmentEditorBar->setObjectName("itemsAlignmentTools");
|
||||
m_itemsAlignmentEditorBar->insertAction(m_itemsAlignmentEditorBar->actions().at(0),m_useGridAction);
|
||||
m_itemsAlignmentEditorBar->insertAction(m_itemsAlignmentEditorBar->actions().at(1),m_useMagnetAction);
|
||||
m_itemsAlignmentEditorBar->insertSeparator(m_itemsAlignmentEditorBar->actions().at(2));
|
||||
addToolBar(m_itemsAlignmentEditorBar);
|
||||
m_itemsBordersEditorBar = new ItemsBordersEditorWidget(m_reportDesignWidget,tr("Borders"),this);
|
||||
m_itemsBordersEditorBar->setIconSize(m_mainToolBar->iconSize());
|
||||
@ -1035,6 +1045,11 @@ void ReportDesignWindow::slotUseGrid(bool value)
|
||||
m_reportDesignWidget->setUseGrid(value);
|
||||
}
|
||||
|
||||
void ReportDesignWindow::slotUseMagnet(bool value)
|
||||
{
|
||||
m_reportDesignWidget->setUseMagnet(value);
|
||||
}
|
||||
|
||||
void ReportDesignWindow::slotLoadRecentFile(const QString fileName)
|
||||
{
|
||||
if (checkNeedToSave()){
|
||||
|
@ -111,6 +111,7 @@ private slots:
|
||||
void slotHideRightPanel(bool value);
|
||||
void slotEditSettings();
|
||||
void slotUseGrid(bool value);
|
||||
void slotUseMagnet(bool value);
|
||||
void slotLoadRecentFile(const QString fileName);
|
||||
protected:
|
||||
void closeEvent(QCloseEvent *event);
|
||||
@ -170,6 +171,7 @@ private:
|
||||
QAction* m_cutAction;
|
||||
QAction* m_settingsAction;
|
||||
QAction* m_useGridAction;
|
||||
QAction* m_useMagnetAction;
|
||||
|
||||
QAction* m_newPageHeader;
|
||||
QAction* m_newPageFooter;
|
||||
|
@ -19,7 +19,7 @@
|
||||
<file alias="/images/hourglass">images/Hourglass_80.png</file>
|
||||
<file alias="/images/closebox">images/closebox.png</file>
|
||||
<file alias="/images/designBig">images/design.png</file>
|
||||
<file alias="ImageItem">images/barcode.png</file>
|
||||
<file alias="/images/ImageItem">images/barcode.png</file>
|
||||
<file alias="/images/addBarcode">images/barcode2.png</file>
|
||||
<file>images/edit_pecil2.png</file>
|
||||
<file>images/undo1.png</file>
|
||||
@ -154,11 +154,12 @@
|
||||
<file>images/logo.png</file>
|
||||
<file alias="/images/copyright">images/cpyright_logo.png</file>
|
||||
<file>images/logo_100.png</file>
|
||||
<file alias="empty">images/empty.png</file>
|
||||
<file alias="/images/empty">images/empty.png</file>
|
||||
<file alias="/images/hideLeftPanel">images/hideLeftPanel.png</file>
|
||||
<file alias="/images/hideRightPanel">images/hideRightPanel.png</file>
|
||||
<file alias="/images/pdf">images/PDF2.png</file>
|
||||
<file alias="/images/settings">images/settings.png</file>
|
||||
<file alias="/images/grid">images/grid.png</file>
|
||||
<file alias="/images/magnet">images/magnet.png</file>
|
||||
</qresource>
|
||||
</RCC>
|
||||
|
Loading…
Reference in New Issue
Block a user