Qt自定义图形实现拖拽效果

发布时间:2020-10-22 18:58:31 作者:Tjmies
来源:脚本之家 阅读:296

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

在这里自定义图形是通过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);
 
}

接着,主窗口程序通过mousePressEvent() mouseMoveEvent(),实现拖拽移动,

void MainWindow::mousePressEvent(QMouseEvent *event)
{
  qDebug()<<" 1:"<<event->pos();
  //获取控件的对象
  m_pTempWidget = childAt(event->pos());
  qDebug()<<m_pTempWidget;
  if(!m_pTempWidget || m_pTempWidget == centralWidget())
    return;
  //容器存储自定义图形指针,以及图形的位置
  QMap<QEventView*,QPoint>::iterator iter = 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;
  }
}
 
void MainWindow::mouseMoveEvent(QMouseEvent *event)
{
  QMap<QEventView*,QPoint>::iterator iter = m_mapEventPoint.begin();
  while(iter != m_mapEventPoint.end())
  {
    if(iter.key() == m_pTempWidget)
    {
 
      QPoint distance = event->pos() - m_StartPoint;
      iter.key()->move(m_windowInitPoint + distance);
      break;
    }
    ++iter;
  }
}

就能实现简单的拖拽功能,效果图如下:

Qt自定义图形实现拖拽效果

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持亿速云。

推荐阅读:
  1. Qt如何实现基础图形绘制
  2. js实现鼠标拖拽效果

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

qt 拖拽 拖拽效果

上一篇:微信小程序实现跑马灯效果

下一篇:Python实现屏幕截图的两种方式

相关阅读

您好,登录后才能下订单哦!

密码登录
登录注册
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》