Qt通過QGraphicsview實現(xiàn)簡單縮放及還原效果
本文主要介紹通過QGraphicsview實現(xiàn)簡單的縮放,以及縮放后還原原始大小。
1,自定義一個drawview繼承QGraphicsview,縮放主要實現(xiàn)的函數(shù)為
void scale(qreal sx,qreal sy);
通過scale可以對view進行放大或縮小。
則可以在drawview中定義縮放slots為
void drawview::zoomIn(qreal delta) { zoom(delta); } void drawview::zoomOut(qreal delta) { zoom(1/delta); } void drawview::zoom(float scaleFactor) { setTransformationAnchor(QGraphicsView::AnchorUnderMouse); qreal factor = transform().scale(scaleFactor, scaleFactor).mapRect(QRectF(0, 0, 1, 1)).width(); if (factor < 0.01 || factor > 2000) return; scale(scaleFactor, scaleFactor); }
2,在mainwindows中引用drawview中的縮放函數(shù)
void MainWindow::ZoomIn() { myview->zoomIn(1.2); qDebug()<<"zoomin"; } void MainWindow::ZoomOut() { qDebug()<<"zoomOut"; myview->zoomOut(1.2); }
3,還原原始大小
在看代碼之前,我們可以先了解一下QMatrix,
可以看到QMatrix包含有6個參數(shù),具體可以查看文檔,簡單來說
m11 - 水平縮放
m12 - 垂直拉伸
m21 - 水平拉伸
m22 - 垂直縮放
dx - 水平位移
dy - 垂直位移
通過這些參數(shù),我們可以知道我們所需要調節(jié)的只有m11和m22,則把這兩個參數(shù)設為1,不改變
void MainWindow::Original() { myview->setTransformationAnchor(QGraphicsView::AnchorViewCenter); QMatrix q; q.setMatrix(1,myview->matrix().m12(),myview->matrix().m21(),1,myview->matrix().dx(),myview->matrix().dy()); myview->setMatrix(q,false); }
PS:QGraphicsview的比例復原
我們都知道QGraphicsview的縮放是使用scale函數(shù)來設置的,但是每次設置scale都會在之前的基礎上進行縮放,有時間會需要復原原來的縮放比例,就牽扯到QGraphicsView的復原,查找資料,在網上找到一個解決方案,貼在下面,望大家可以學習。
先了解QMatrix,QMatrix包含有6個參數(shù),具體可以查看文檔,簡單來說
m11 - 水平縮放
m12 - 垂直拉伸
m21 - 水平拉伸
m22 - 垂直縮放
dx - 水平位移
dy - 垂直位移
可以通過QGraphicsview::setMatrix函數(shù)來設置比例復原,主要是修改QMatrix的m11和m22來調整。
復原setMatrix
pView->setTransformationAnchor(QGraphicsView::AnchorViewCenter);
QMatrix matrix;
matrix.setMatrix(1, pView->matrix().m12(), pView->matrix().m21(), 1, pView->matrix().dx(), pView->matrix().dy());
pView->setMatrix(matrix, false);
到此這篇關于Qt通過QGraphicsview實現(xiàn)簡單縮放及還原效果的文章就介紹到這了,更多相關Qt QGraphicsview縮放及還原內容請搜索本站以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持本站!
版權聲明:本站文章來源標注為YINGSOO的內容版權均為本站所有,歡迎引用、轉載,請保持原文完整并注明來源及原文鏈接。禁止復制或仿造本網站,禁止在非www.sddonglingsh.com所屬的服務器上建立鏡像,否則將依法追究法律責任。本站部分內容來源于網友推薦、互聯(lián)網收集整理而來,僅供學習參考,不代表本站立場,如有內容涉嫌侵權,請聯(lián)系alex-e#qq.com處理。