Qt自定义图形实现拖拽效果-创新互联

本文实例为大家分享了Qt自定义图形实现拖拽效果的具体代码,供大家参考,具体内容如下

创新互联专注于中大型企业的网站设计制作、成都做网站和网站改版、网站营销服务,追求商业策划与数据分析、创意艺术与技术开发的融合,累计客户上千余家,服务满意度达97%。帮助广大客户顺利对接上互联网浪潮,准确优选出符合自己需要的互联网运用,我们将一直专注品牌网站设计和互联网程序开发,在前进的路上,与客户一起成长!

在这里自定义图形是通过QPaintEvent事件绘画的图形,也可以通过自定义控件的方式添加到qt中。

首先定义类来自定义图形,这里通过paintEvent事件来实现(主要就是绘画一个图形)

void QEventView::paintEvent(QPaintEvent *event)
{
  resize(115+m_iLen,36);
  QPainter painter(this);
  painter.setRenderHint(QPainter::Antialiasing);
  painter.setPen(Qt::blue);
 
  //定义箭头的坐标
  static const QPoint pointArr[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)
  };
  int i = 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);
 
}

本文名称:Qt自定义图形实现拖拽效果-创新互联
分享链接:http://pwwzsj.com/article/djhjge.html