• <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>
            posts - 319, comments - 22, trackbacks - 0, articles - 11
              C++博客 :: 首頁 :: 新隨筆 :: 聯系 :: 聚合  :: 管理

            QML與現有Qt UI代碼的整合

            Posted on 2011-08-04 22:38 RTY 閱讀(2710) 評論(0)  編輯 收藏 引用 所屬分類: 轉載隨筆QML

            請尊重原創作品和譯文。轉載請保持文章完整性,并以超鏈接形式注明原始作者地址http://blog.csdn.net/changsheng230,方便其他朋友提問和指正。

            將QML整合到基于QWidget UI程序的方法有很多種,而具體采用哪種方法取決于現有UI代碼的特性。

            與基于QWidget的UI整合

            如果你已經有了一個基于QWidget的UI,QML widgets可以使用QDeclarativeView來進行集成。QDeclarativeView是QWidget的一個子類,所以你可以像加載其他QWidget一樣把它加載進你的UI。 具體方法是使用QDeclarativeView::setSource()方法加載一個QML文件到視圖中,然后將這個視圖(即QDeclarativeView)加到你的UI中。

            1. QDeclarativeView *qmlView = new QDeclarativeView;  
            2. qmlView->setSource(QUrl::fromLocalFile("myqml.qml"));  
            3.   
            4. QWidget *widget = myExistingWidget();  
            5. QVBoxLayout *layout = new QVBoxLayout(widget);  
            6. widget->addWidget(qmlView);  

            這種方法的缺點在于與QWidget相比,QDelarativeVeiw的初始化過程更慢,而且使用更多的內存。如果創建大量的QDelarativeVeiw對象可能會導致性能的下降。在這種情況下,更好的選擇是用QML重寫你的widgets,使用main QML widget來加載widget, 從而替代QDelarativeVeiw的濫用。

            請注意,QWidgets的UI設計理念與QML并不相同,所以將基于QWidget的應用移植到QML并不總是一個好主意。如果你的UI是由少數幾個復雜、靜態的元素的組成,使用QWidgets是一個更好的選擇。而如果你的UI是由大量簡單、動態的元素組成,那么QML則是你的最佳選擇。

            與基于QGraphicsView的UI整合

            將QML widgets加入到QGraphicsScene

            如果你已經有了一個基于Graphics View Framework的UI,你可以直接將QML widgets集成到你的QGraphicsScene中。具體方法是使用QDeclarativeComponent 從QML文件中創建一個QGraphicsObject,并通過使用QGraphicsScene::addItem(), 方法把這個圖形對象加到你的scene中,或者將其父化到已經存在與QGraphicsScene的組件中。舉例說明:

            >

            1. QGraphicsScene* scene = myExistingGraphicsScene();  
            2. QDeclarativeEngine *engine = new QDeclarativeEngine;  
            3. QDeclarativeComponent component(engine, QUrl::fromLocalFile("myqml.qml"));  
            4. QGraphicsObject *object =  
            5.     qobject_cast(component.create());  
            6. scene->addItem(object);  

            推薦使用下面的一些QGraphicsView選項來優化QML UIs的性能:

            在QML中加載QGraphicsWidget 對象

            另一個可供選擇的方法是將你現有的QGraphicsWidget 對象暴露給QML,并且在QML中構建你的scene。請參見圖形布局示例,它展示了如何結合QGraphicsWidget 、QGraphicsLinearLayout 以及QGraphicsGridLayout的使用,將Qt圖形布局類暴露給QML。

            為了將現有的QGraphicsWidget類暴露給QML,需使用qmlRegisterType()。在QML中使用C++型別的進一步信息,請參見在C++中拓展QML。 (譯者注:也看參閱QML與C++混合編程使用)

            英文原文出處:integrating QML with existing Qt UI code

            中文字幕久久精品 | 狠狠综合久久综合88亚洲 | 久久精品aⅴ无码中文字字幕不卡| 伊人久久国产免费观看视频| 亚洲中文久久精品无码| 久久久精品免费国产四虎| 香港aa三级久久三级老师2021国产三级精品三级在 | 亚洲欧洲精品成人久久奇米网| 久久精品一区二区三区AV| 久久99精品久久久久久久不卡| 国产精品伦理久久久久久| 亚洲综合日韩久久成人AV| 曰曰摸天天摸人人看久久久| 国产精品久久久久免费a∨| 久久精品aⅴ无码中文字字幕不卡| 精品久久久久久国产免费了| 色欲久久久天天天综合网精品| 青青青国产成人久久111网站| 久久天天躁狠狠躁夜夜avapp| 国产福利电影一区二区三区久久久久成人精品综合 | 久久99精品免费一区二区| 无码精品久久久天天影视 | 久久黄视频| A狠狠久久蜜臀婷色中文网| 2021国产精品午夜久久| 国产99久久久久久免费看| 久久久久久九九99精品| 免费精品国产日韩热久久| 免费一级做a爰片久久毛片潮 | 久久精品蜜芽亚洲国产AV| 亚洲精品第一综合99久久| 久久久久久国产精品美女| 一级做a爰片久久毛片16| 久久99热只有频精品8| 久久久久无码精品国产不卡| 久久天天躁狠狠躁夜夜avapp| 久久中文字幕人妻丝袜| 综合人妻久久一区二区精品| 亚洲中文字幕无码一久久区| 2021久久精品免费观看| 亚洲精品乱码久久久久久中文字幕 |