青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

posts - 319, comments - 22, trackbacks - 0, articles - 11
  C++博客 :: 首頁 :: 新隨筆 :: 聯系 :: 聚合  :: 管理

使用QML實現浮動桌面搜索框

Posted on 2011-08-05 07:33 RTY 閱讀(2735) 評論(0)  編輯 收藏 引用 所屬分類: QML

使用QML實現浮動桌面搜索框

前段時間接觸了一下QML,深深地被這門強大易用的語言所吸引。

QML的語法類似CSS,可以引入javascript作為邏輯,還能夠和C++對象交互。

QML帶來的好處至少有以下幾點:

 

  1. 分工更明確:設計師可以專攻QML制作UI,C++工程師也能專注于自己的本職工作。
  2. 開發更高效:重新編寫的QML不需要編譯(因為它是一門腳本語言),所以只需要刷新一下你的QML Viewer就可以了。
  3. 界面更精美:QML開發和網頁開發很相似,所以我們可以比較容易地把一個精美的網頁效果移植到本地程序。
  4. 風格更一致:Qt本身是一個跨平臺的開發框架,所以我們在Window XP上看到的是一個樣子,Win7上看到的是另一個樣子,到了Ubuntu或者Mac更是變了模樣,使用QML可以屏蔽這些不一致。
下面帶來一個簡單的示例,希望對讀者們有幫助。
谷歌桌面相信很多人都用過,雙擊ctrl可以呼出一個浮動的搜索框,非常方便。我們將使用QML仿制這一效果。先看效果圖:

 
怎么樣?很炫吧~
好的,首先打開你的Qt Creator(QML是Qt4.7以后才有的特性,請升級你的SDK到最新版本 )。然后新建一個項目。接著新建一個C++ Class,命名為FloatBox。現在你的工程的目錄結構應該像這樣:

接著,再新建一個QML文件:


 

我們將這個QML文件命名為TextBox。這個QML文件主要是實現搜索框中的文本框。

輸入以下代碼:

 

Qml代碼  收藏代碼
  1. import Qt 4.7  
  2.   
  3. FocusScope {  
  4.     id: focusScope  
  5.     width: 600; height: 40  
  6.     focus:true  
  7.   
  8.     BorderImage {  
  9.         source: "../images/lineedit-bg.png"  
  10.         width: parent.width; height: parent.height  
  11.         border { left: 4; top: 4; right: 4; bottom: 4 }  
  12.     }  
  13.   
  14.     Text {  
  15.         id: typeSomething  
  16.         anchors.fill: parent; anchors.leftMargin: 8  
  17.         verticalAlignment: Text.AlignVCenter  
  18.         text: "\u8BF7\u8F93\u5165\u7F51\u5740"  
  19.         color: "gray"  
  20.     }  
  21.   
  22.     MouseArea {  
  23.         anchors.fill: parent  
  24.         onClicked: { focusScope.focus = true; textInput.openSoftwareInputPanel(); }  
  25.     }  
  26.   
  27.     TextInput {  
  28.         id: textInput  
  29.         anchors { left: parent.left; leftMargin: 8; right: clear.left; rightMargin: 8; verticalCenter: parent.verticalCenter }  
  30.         focus: true  
  31.         font.pixelSize:20  
  32.     }  
  33.   
  34.     Image {  
  35.         id: clear  
  36.         anchors { right: parent.right; rightMargin: 8; verticalCenter: parent.verticalCenter }  
  37.         source: "../images/clear.png"  
  38.         opacity: 0  
  39.   
  40.         MouseArea {  
  41.             anchors.fill: parent  
  42.             onClicked: { textInput.text = ''; focusScope.focus = true; textInput.openSoftwareInputPanel(); }  
  43.         }  
  44.     }  
  45.   
  46.     states: State {  
  47.         name: "hasText"; when: textInput.text != ''  
  48.         PropertyChanges { target: typeSomething; opacity: 0 }  
  49.         PropertyChanges { target: clear; opacity: 1 }  
  50.     }  
  51.   
  52.     transitions: [  
  53.         Transition {  
  54.             from: ""; to: "hasText"  
  55.             NumberAnimation { exclude: typeSomething; properties: "opacity" }  
  56.         },  
  57.         Transition {  
  58.             from: "hasText"; to: ""  
  59.             NumberAnimation { properties: "opacity" }  
  60.         }  
  61.     ]  
  62. }  

 

 你也許會注意到,在Text的text屬性中,我輸入的是utf編碼的漢字。事實上,想要在QML文件里顯示中文還是有一點小麻煩的,要么就是用utf編碼過的漢字,要么使用Qt翻譯家來轉換。直接在QML中輸入中文將無法顯示。
 接著,新建ShadowRectangle文件。該文件實現的是陰影效果。代碼如下:

 

Qml代碼  收藏代碼
  1. import Qt 4.7  
  2.   
  3. Item {  
  4.     property alias color : rectangle.color  
  5.   
  6.     BorderImage {  
  7.         anchors.fill: rectangle  
  8.         anchors { leftMargin: 0; topMargin: 0; rightMargin: -8; bottomMargin: -8 }  
  9.         border { left: 10; top: 10; right: 10; bottom: 10 }  
  10.         source: "../images/shadow.png"; smooth: true  
  11.     }  
  12.   
  13.     Rectangle { id: rectangle; anchors.fill: parent; radius:5}  
  14. }  

 

 最后新建main.qml文件,該文件實現的是整個搜索欄的效果。其代碼如下:

 

Qml代碼  收藏代碼
  1. import Qt 4.7  
  2.   
  3. Rectangle {  
  4.     id: page  
  5.     width: 614; height: 54  
  6.     color: "#7bffffff"  
  7.     radius:5  
  8.   
  9.     MouseArea {  
  10.         anchors.fill: parent  
  11.         onClicked: page.focus = false;  
  12.     }  
  13.     ShadowRectangle {  
  14.         color: "#434343"  
  15.         transformOrigin: "Center"  
  16.         opacity: 0.97  
  17.         visible: true  
  18.         anchors.centerIn: parent; width: 610; height: 50  
  19.     }  
  20.     TextBox {  
  21.         id: search;  
  22.         visible: true  
  23.         opacity: 1  
  24.         anchors.centerIn: parent  
  25.     }  
  26. }  

 

 QML的代碼通俗易懂,這里就不去解釋每一行代碼的意思了。

 

好的,下面讓我們把QML制作的搜索欄放置到桌面程序的窗體上。

在你的floatbox.h中添加一個私有變量:

 

Cpp代碼  收藏代碼
  1. private:  
  2.     QDeclarativeView *ui;  

 

 然后在你的floatbox.cpp的構造函數中輸入以下代碼:

 

Cpp代碼  收藏代碼
  1. // 使窗體透明而控件不透明  
  2. setWindowFlags(Qt::FramelessWindowHint);  
  3. setAttribute(Qt::WA_TranslucentBackground, true);  
  4. setStyleSheet("background:transparent;");  
  5.   
  6. ui = new QDeclarativeView;  
  7. ui->setSource(QUrl("qrc:/resources/qml/main.qml"));  
  8. setCentralWidget(ui);  
  9. resize(QSize(630, 60));  

 

 細心的你可以發現,我將qml文件加入了Qt的資源系統。這里要說明一點,非常重要:

在QML文件中如果引入了其他文件(包括js文件、圖片文件等),要么都加入Qt的資源系統,要么都不加入,因為Qt的資源文件無法和本地文件相互訪問。

所以,如果你也和我一樣新建了qrc文件,請將qml文件和圖片文件一并加入到資源系統中去。如下圖:



 到了這一步,我們的搜索工具欄差不多要完工了,想要運行,千萬不要忘記在pro文件添加declarative模塊。

 

Cpp代碼  收藏代碼
  1. QT       += core gui declarative  

 

 好的,現在你就可以按下ctrl+R欣賞一下成果了。

最后,老規矩,附上源代碼。

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            99re这里只有精品6| 香港久久久电影| 欧美激情第8页| 一本一道久久综合狠狠老精东影业 | 国语自产精品视频在线看| 亚洲日本欧美| 久久久久国产一区二区三区四区| 一区二区国产日产| 欧美二区在线| 一区二区在线免费观看| 久久久av网站| 久久超碰97人人做人人爱| 国产欧美日韩麻豆91| 亚洲一区二区三区精品在线观看| 亚洲日产国产精品| 性刺激综合网| 国产三级欧美三级| 久久精品国产清自在天天线| 篠田优中文在线播放第一区| 国内久久精品| 欧美xxx在线观看| 久久综合999| 亚洲欧洲一区二区三区在线观看| 免费91麻豆精品国产自产在线观看| 久久精品国语| 亚洲激情综合| 亚洲啪啪91| 欧美视频一区二区在线观看| 亚洲男同1069视频| 亚洲欧美国产77777| 国产一区二区三区四区hd| 免费观看亚洲视频大全| 欧美电影免费观看网站| 亚洲视频观看| 香蕉国产精品偷在线观看不卡| 国产日韩欧美一区二区三区在线观看 | 亚洲人妖在线| 亚洲福利视频一区| 欧美日韩成人网| 乱人伦精品视频在线观看| 欧美视频日韩视频| 久久婷婷人人澡人人喊人人爽 | 亚洲一区免费在线观看| 99在线热播精品免费| 久久综合伊人77777| 国产在线精品成人一区二区三区 | 亚洲激情在线观看视频免费| 亚洲国产经典视频| 欧美色精品天天在线观看视频| 亚洲欧美日韩视频二区| 欧美一区二区三区免费看| 亚洲韩日在线| 亚洲欧美日韩精品| 亚洲精品美女久久久久| 午夜视频在线观看一区二区三区| 亚洲激情女人| 欧美亚洲免费电影| 99国产欧美久久久精品| 欧美影院一区| 亚洲在线电影| 欧美成人综合在线| 久久久久久久久久久成人| 欧美精品免费播放| 免费成人高清视频| 国产欧美成人| 99在线视频精品| 亚洲国产美女| 香蕉国产精品偷在线观看不卡| 一区二区三区欧美视频| 久久精品国语| 久久久久99精品国产片| 欧美激情亚洲| 欧美大片免费观看| 国产日韩欧美视频在线| 亚洲网在线观看| 99视频在线观看一区三区| 久久国产精品99久久久久久老狼| 午夜精品一区二区三区在线视| 欧美猛交免费看| 欧美激情性爽国产精品17p| 国产亚洲精品久久久| 亚洲先锋成人| 亚洲欧美国产另类| 国产精品99免视看9| 亚洲日本一区二区三区| 日韩视频一区| 欧美精品色综合| 亚洲国内在线| 亚洲精品在线观看视频| 欧美成年人视频网站欧美| 欧美成人一区二区在线| 狠狠色丁香婷婷综合久久片| 欧美中日韩免费视频| 久久精品视频导航| 国产片一区二区| 日韩一级免费| 99re8这里有精品热视频免费 | 久久久综合免费视频| 国产精品久久久久久久久免费| 亚洲精品美女在线观看| 亚洲精选久久| 欧美日韩国产经典色站一区二区三区| 亚洲激情在线播放| 日韩一级黄色片| 欧美日韩久久不卡| 一本到高清视频免费精品| 亚洲伊人色欲综合网| 国产精品美女一区二区| 亚洲欧美日韩精品在线| 久久久精品日韩| 亚洲成色777777在线观看影院| 久久综合免费视频影院| 欧美激情欧美狂野欧美精品| 亚洲裸体在线观看| 欧美亚洲成人免费| 欧美亚洲一区| 久久综合网络一区二区| 亚洲精品老司机| 欧美午夜不卡影院在线观看完整版免费| 一区二区三区四区蜜桃| 欧美在线视频一区| 亚洲国产精品成人久久综合一区| 欧美激情一区二区三区不卡| 一区二区三区欧美日韩| 欧美一区在线视频| 亚洲丰满在线| 国产精品www色诱视频| 欧美一区影院| 美女在线一区二区| 一区二区三区精品久久久| 国产伦精品一区二区三区在线观看 | 国产精品一区二区久久久| 久久精品欧洲| 99国内精品久久久久久久软件| 久久精品视频在线看| 亚洲美女黄色片| 国产人成一区二区三区影院| 欧美成人第一页| 欧美一区=区| 亚洲精品国偷自产在线99热| 久久精品人人做人人爽电影蜜月| 亚洲人成高清| 国产日韩精品电影| 欧美久久影院| 久久久久久电影| 亚洲新中文字幕| 最近中文字幕日韩精品 | 日韩视频―中文字幕| 国产精品久久久久久妇女6080 | 美女精品在线观看| 在线一区日本视频| 红桃视频一区| 国产精品欧美日韩一区二区| 久久亚洲影院| 午夜久久美女| 一区二区三区四区五区视频| 欧美成人中文字幕| 欧美一区二视频| 中文日韩在线视频| 在线精品国精品国产尤物884a| 国产精品日韩二区| 欧美日韩a区| 欧美91福利在线观看| 久久精品一区二区三区四区 | 欧美精品一区二区精品网| 久久精品一区四区| 亚洲一区国产视频| 亚洲卡通欧美制服中文| 欧美成人一品| 久久不见久久见免费视频1| 亚洲综合电影| 亚洲午夜激情网页| 日韩特黄影片| 最新国产成人在线观看| 永久久久久久| 在线视频成人| 激情久久久久久久| 韩国成人精品a∨在线观看| 国产欧美日韩一区二区三区在线 | 国内一区二区在线视频观看 | 欧美日韩国产经典色站一区二区三区| 久久久亚洲综合| 久久久久99| 蜜桃伊人久久| 欧美成人午夜| 欧美激情一区| 欧美日韩日日骚| 亚洲欧美精品一区| 欧美一级午夜免费电影| 亚洲伊人久久综合| 亚洲欧美国产高清| 欧美一区二区私人影院日本| 久久精品视频在线免费观看| 久久精品国产免费看久久精品| 久久精品成人一区二区三区| 欧美一区二区视频在线观看| 久久人人看视频| 欧美精品乱码久久久久久按摩| 欧美精品亚洲| 国产精品亚洲一区|