• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            清源游民 gameogre@gmail.com

            Graphics View 坐標(biāo)系統(tǒng)
            Graphics View基于笛卡爾坐標(biāo)系。item在場(chǎng)景中的位置與幾何形狀通過(guò)x,y坐標(biāo)表示。當(dāng)使用未經(jīng)變形的視圖來(lái)觀察場(chǎng)景時(shí),場(chǎng)景中的一個(gè)單位等于屏幕上的一個(gè)像素。在Graphics View中有三個(gè)有效的坐標(biāo)系統(tǒng):Item坐標(biāo)系,場(chǎng)景坐標(biāo)系,視圖坐標(biāo)系。為了簡(jiǎn)化你的實(shí)現(xiàn),Graphics View提供了方便的函數(shù),允許三個(gè)坐標(biāo)系之間相互映射。
            當(dāng)渲染時(shí),Graphics View的場(chǎng)景坐標(biāo)對(duì)應(yīng)于QPainter的邏輯坐標(biāo),視圖坐標(biāo)與設(shè)備坐標(biāo)相同。



            Item坐標(biāo)
            Items位于它們自己的坐標(biāo)系中。它的坐標(biāo)都以點(diǎn)(0,0)為中心點(diǎn),這也是所有變換的中心點(diǎn)。在item坐標(biāo)系中的幾何圖元,經(jīng)常被稱為item點(diǎn),item線,item矩形。當(dāng)創(chuàng)建一個(gè)定制的item,item坐標(biāo)是所需要考慮的。QGraphicsSceneQGraphicsView可以為你執(zhí)行所有轉(zhuǎn)換,這使得實(shí)現(xiàn)定制的item變得容易。舉例來(lái)說(shuō),假如你收到鼠標(biāo)按或是拖進(jìn)入事件,事件的位置以item坐標(biāo)的形式給出。QGraphicsItem::contain()虛函數(shù),當(dāng)某個(gè)點(diǎn)的位置在你的item范圍內(nèi)時(shí),返回true,否則返回false。這個(gè)點(diǎn)參數(shù)使用item坐標(biāo),相似地,item的包圍矩形與形狀也使用item坐標(biāo)。
            Item位置指的是item的中心點(diǎn)在它父親的坐標(biāo)系中的坐標(biāo)。以這種思想來(lái)看,場(chǎng)景指的就是那些祖先最少的item的“父親”。最上級(jí)的Item位置就是在場(chǎng)景中的位置。
            子坐標(biāo)與父坐標(biāo)之間是相關(guān)的,假如孩子未經(jīng)變換,子坐標(biāo)與父坐標(biāo)之間的差值等于在父坐標(biāo)系下,父item與子item之間的距離。例如,假如一個(gè)未經(jīng)變換的子item位置與其父item的中心重合,那么這兩個(gè)item的坐標(biāo)系統(tǒng)完全相同。如果孩子的位置是(10,0),那么孩子坐標(biāo)系中的(0,10)點(diǎn),對(duì)應(yīng)于父坐標(biāo)系中的(10,10)點(diǎn)。
            因?yàn)閕tem的位置與變換是相對(duì)于父item的,子item的坐標(biāo)不會(huì)被父親的變換影響,盡管父item的變換隱含地對(duì)子item做了變換。在上面的例子中,即使父item旋轉(zhuǎn),縮放,子item的(0,10)點(diǎn)依然對(duì)應(yīng)于父item的(10,10)點(diǎn)。然而,相對(duì)于場(chǎng)景來(lái)講,子item會(huì)遵循父item的變換。假如父item被縮放(2X,2X),子item的位置在場(chǎng)景中的坐標(biāo)是(20,0),它的(10,0)點(diǎn)則與場(chǎng)景中的(40,0)對(duì)應(yīng) 。除了QGraphicsItem::pos(),QGraphicsItem的函數(shù)以Item坐標(biāo)工作,如一個(gè)item's包圍矩形總是以item坐標(biāo)的形式給出。

            場(chǎng)景坐標(biāo)
            場(chǎng)景坐標(biāo)系統(tǒng)描述了每個(gè)最頂級(jí)item的位置,也是從視圖向場(chǎng)景投遞場(chǎng)景事件的基礎(chǔ)。場(chǎng)景中的每個(gè)item有場(chǎng)景位置與包圍矩形(QGraphicsItem::scenePos(),QGraphicsItem::sceneBoundingRect()), 另外,它有自己本地item位置與包圍矩形。場(chǎng)景位置描述了item在場(chǎng)景坐標(biāo)下的位置,它的場(chǎng)景包圍矩形則用于QGraphicsScene決定場(chǎng)景中哪塊區(qū)域發(fā)生了變化。場(chǎng)景中的變化通過(guò)QGraphicsScene::changed()信號(hào)來(lái)通知,它的參數(shù)是場(chǎng)景矩形列表。

            視圖坐標(biāo)
            視圖坐標(biāo)是widget的坐標(biāo),視圖坐標(biāo)中每個(gè)單位對(duì)應(yīng)一個(gè)像素。這種坐標(biāo)的特殊之處在于它是相對(duì)于widget或是視口的,不會(huì)被所觀察的場(chǎng)景所影響。QGraphicsView的視口的左上角總是(0,0),右下角總是(視口寬,視口高)。所有的鼠標(biāo)事件與拖拽事件,最初以視圖坐標(biāo)表示,就應(yīng)該把這些坐標(biāo)映射到場(chǎng)景坐標(biāo)以便與item交互。

            坐標(biāo)映射
            經(jīng)常,處理場(chǎng)景中item時(shí),在場(chǎng)景與item之間,item與item之間,視圖與場(chǎng)景之間進(jìn)行坐標(biāo)映射,形狀映射是非常有用的。舉例來(lái)講,當(dāng)你在QGraphicsView的視口中點(diǎn)擊鼠標(biāo)時(shí),你應(yīng)該通過(guò)調(diào)用QGraphicsView::mapToScence()QGraphicsScene::itemAt()來(lái)獲知光標(biāo)下是場(chǎng)景中的哪個(gè)item。假如你想獲知一個(gè)item位于視口中的什么位置,你應(yīng)該先在item上調(diào)用QGraphicsItem::mapToScene(),然后調(diào)用QGraphicsView::mapFromScene()。最后,假如你想在一個(gè)視圖橢圓中有哪些items,你應(yīng)該把QPainterPath傳遞到mapToScene(),然后再把映射后的路徑傳遞到QGraphicsScene::items()。
            你可以調(diào)用QGraphicsItem::mapToScene()QGraphicsItem::mapFromScene()在item與場(chǎng)景之間進(jìn)行坐標(biāo)與形狀的映射。也可以在item與其父item之間通過(guò)QGraphicsItem::mapToParent()QGraphicsItem::mapFromItem()進(jìn)行映射。所有映射函數(shù)可以包括點(diǎn),矩形,多邊形,路徑。視圖與場(chǎng)景之間的映射也與此類似。對(duì)于從視圖與item之間的映射,你應(yīng)該首先映射到場(chǎng)景,然后再?gòu)膱?chǎng)景向item進(jìn)行映射。

            posted on 2007-09-26 23:57 清源游民 閱讀(4698) 評(píng)論(0)  編輯 收藏 引用 所屬分類: Qt
            <2006年12月>
            262728293012
            3456789
            10111213141516
            17181920212223
            24252627282930
            31123456

            留言簿(35)

            隨筆分類(78)

            隨筆檔案(74)

            文章檔案(5)

            搜索

            •  

            最新評(píng)論

            閱讀排行榜

            評(píng)論排行榜

            久久精品毛片免费观看| 99精品国产综合久久久久五月天| 伊人久久综合精品无码AV专区| 亚洲人AV永久一区二区三区久久 | 久久国产精品无码HDAV| 久久99国产综合精品| 久久免费线看线看| 久久福利资源国产精品999| 97久久久久人妻精品专区| 亚洲国产成人精品91久久久 | 色综合久久天天综线观看| 久久久久高潮综合影院| 久久99国产精品久久| 一级A毛片免费观看久久精品| AV无码久久久久不卡网站下载| 久久久久99精品成人片| 精品精品国产自在久久高清| 天堂无码久久综合东京热| 久久精品国产免费| 久久婷婷成人综合色综合| 一级女性全黄久久生活片免费| 久久亚洲中文字幕精品有坂深雪| 久久夜色精品国产| 久久e热在这里只有国产中文精品99 | 久久精品久久久久观看99水蜜桃| 国产精品成人99久久久久| 国产午夜福利精品久久2021 | 久久免费视频6| 国产成人99久久亚洲综合精品| 国产婷婷成人久久Av免费高清 | 久久国产精品成人影院| 亚洲国产精品成人AV无码久久综合影院| 狠狠色噜噜狠狠狠狠狠色综合久久| 久久精品人妻中文系列| 亚洲va久久久噜噜噜久久天堂| 无码国内精品久久人妻麻豆按摩| 久久久精品视频免费观看| 久久成人18免费网站| 色综合久久天天综线观看| 久久中文字幕精品| 日韩精品久久久久久久电影蜜臀|