您好,登錄后才能下訂單哦!
本文實例為大家分享了Qt自定義圖形實現(xiàn)拖拽效果的具體代碼,供大家參考,具體內(nèi)容如下
在這里自定義圖形是通過QPaintEvent事件繪畫的圖形,也可以通過自定義控件的方式添加到qt中。
首先定義類來自定義圖形,這里通過paintEvent事件來實現(xiàn)(主要就是繪畫一個圖形)
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(),實現(xiàn)拖拽移動,
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; } }
就能實現(xiàn)簡單的拖拽功能,效果圖如下:
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持億速云。
免責聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。