Qt自定义图形实现拖拽效果
本文实例为大家分享了Qt自定义图形实现拖拽效果的具体代码,供大家参考,具体内容如下
在这里自定义图形是通过QPaintEvent事件绘画的图形,也可以通过自定义控件的方式添加到qt中。
首先定义类来自定义图形,这里通过paintEvent事件来实现(主要就是绘画一个图形)
voidQEventView::paintEvent(QPaintEvent*event)
{
resize(115+m_iLen,36);
QPainterpainter(this);
painter.setRenderHint(QPainter::Antialiasing);
painter.setPen(Qt::blue);
//定义箭头的坐标
staticconstQPointpointArr[7]=
{
QPoint(0,10),
QPoint(100+m_iLen,10),
QPoint(100+m_iLen,0),
QPoint(115+m_iLen,18),
QPoint(100+m_iLen,36),
QPoint(100+m_iLen,26),
QPoint(0,26)
};
inti=0;
while(i<7)
{
if(i==6)
painter.drawLine(pointArr[i],pointArr[0]);
else
painter.drawLine(pointArr[i],pointArr[i+1]);
i++;
}
painter.drawText(QPoint(0,22),m_sEventName);
}
接着,主窗口程序通过mousePressEvent()mouseMoveEvent(),实现拖拽移动,
voidMainWindow::mousePressEvent(QMouseEvent*event)
{
qDebug()<<"1:"<pos();
//获取控件的对象
m_pTempWidget=childAt(event->pos());
qDebug()<::iteratoriter=m_mapEventPoint.begin();
while(iter!=m_mapEventPoint.end())
{
if(iter.key()==m_pTempWidget)
{
m_windowInitPoint=iter.key()->frameGeometry().topLeft();
m_StartPoint=event->pos();
break;
}
++iter;
}
}
voidMainWindow::mouseMoveEvent(QMouseEvent*event)
{
QMap::iteratoriter=m_mapEventPoint.begin();
while(iter!=m_mapEventPoint.end())
{
if(iter.key()==m_pTempWidget)
{
QPointdistance=event->pos()-m_StartPoint;
iter.key()->move(m_windowInitPoint+distance);
break;
}
++iter;
}
}
就能实现简单的拖拽功能,效果图如下:
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持毛票票。
声明:本文内容来源于网络,版权归原作者所有,内容由互联网用户自发贡献自行上传,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任。如果您发现有涉嫌版权的内容,欢迎发送邮件至:czq8825#qq.com(发邮件时,请将#更换为@)进行举报,并提供相关证据,一经查实,本站将立刻删除涉嫌侵权内容。