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

eXile 的專欄

[T] 利用QT進行web與本地混合應用開發(fā)

 Qt Features for Hybrid Web/Native Application Development。
原文參見 http://www.qtsoftware.com/forms/whitepapers/reg-whitepaper-hybrid.(限于本人英文水平,只譯其大概)


Qt提供了本地 C++對象與JavaScript的無縫集成,是進行本地與web混合應用開發(fā)的理想平臺。


(一)Qt Webkit 集成
  利用Qt的Webkit 集成與QtNetwork模塊,你完全可以進行本地桌面與web混合應用開發(fā),你可以自由地混合JavaScript,樣式表,Web內(nèi)容和Qt組件。Webkit是一個非常成熟的web瀏覽引擎。Qt中集成了這個大名鼎鼎的引擎,通過QtWebkit,你可以在C++ 中執(zhí)行JavaScript,或者在網(wǎng)頁中集成C++對象,并且通過JavaScript和這些對象進行交互。
  一個現(xiàn)代的HTML渲染引擎只是混合開發(fā)的一半,另一半就是本地應用和渲染對象的交互。QT的Webkit 集成提供了這種解決方案:
  1.使用object標簽嵌入Qt Widgets組件。這可以讓使用C++代碼的Qt組件包含在網(wǎng)頁中,作為網(wǎng)頁的部分外觀。
  2.在JavaScript中訪問C++對象。你可以在JavaScript環(huán)境中插入C++對象,讓網(wǎng)頁腳本直接訪問你的數(shù)據(jù)結(jié)構(gòu)。
  3.在Qt中執(zhí)行JavaScript。你可以在C++調(diào)用網(wǎng)頁環(huán)境中的JavaScript函數(shù),觸發(fā)網(wǎng)頁事件。
  4.共享客戶端存儲。在JavaScript和C++中你都具有訪問數(shù)據(jù)庫的能力,這樣當下線時也能共享大量數(shù)據(jù)。


(二)與嵌入的Qt對象交互
  使用 QWebView 組件,有兩種方法可以在網(wǎng)頁中嵌入C++對象。你可以在網(wǎng)頁的JavaScript中添加C++對象,或者也可以創(chuàng)建一個插件,然后在網(wǎng)頁中使用object標簽嵌入。
  
  第二種方法更容易入手。當在網(wǎng)頁中放入 Widget組件時,它的所有public slots就像普通函數(shù)一樣被網(wǎng)頁中的JavaScript函數(shù)訪問。
    要在網(wǎng)頁中添加一個Widget,首先要告訴你的QWebPage對象,該Widget可用,這個通過子類化QWebPlugFactory完成,你需要重新實現(xiàn)兩個方法:plugs和create。plugs方法通知網(wǎng)頁該Widget可用,create方法根據(jù)請求創(chuàng)建widget。
  在HTML網(wǎng)頁中,widgets使用object標簽創(chuàng)建。比如,下面這個標簽試圖創(chuàng)建一個 application/x-qt-colorlabel 組件。

<object type="application/x-qt-colorlabel" width="50px" height="20px" id="label" />


  要利用這種創(chuàng)建,必須要允許使用插件并且要告訴QWebpage插件的工廠類。在下面的代碼中,ColorLabelFactory將會根據(jù)application/x-qt-colorlabel的請求創(chuàng)建相應實例。

QWebSettings::globalSettings()->setAttribute(QWebSettings::PluginsEnabled, true); 
webView->page()->setPluginFactory(new ColorLabelFactory(this));


  ColorLabel有一個公開的slot: chagneColor(),這個對于網(wǎng)頁中的JavaScript自動可用。在網(wǎng)頁中插入一個指向該元素的鏈接,可以以一種簡單的方式激活C++函數(shù)。

<a href='javascript:document.getElementById("label").changeColor();'>Change color!</a> 

 
 
  要反方向推進事件,必須要使你的對象在JavaScript文檔上下文中可用。要對QWebPage的每一個QWebFrame,調(diào)用addToJavaScriptWindowObject方法。這個方法允許你根據(jù)名字把一個對象添加到JavaScipt上下文中。

webView->page()->mainFrame()->addToJavaScriptWindowObject( "eventSource", new eventSource( this ) );


  要連接剛添加對象eventSource的信號,要加上一段JavaScript代碼,使用evaluateJavaScript方法完成。下面的代碼將把eventSource對象的signalName信號連接到一個JavaScript函數(shù)destFunction。

webView->page()->mainFrame()->evaluateJavaScript( "eventSource.signalName.connect(destFunction);" );



  如果你把一個對象添加到一個以標準瀏覽器查看的JavaScript頁面中,有一個信號需要知道。每一次JavaScript內(nèi)容被清除,F(xiàn)rame都會釋放 javaScriptWindowObjectCleared 信號。為了使你的Qt對象一直可用,你需要連接這個信號,并且在這里調(diào)用 addToJavaScriptWindowObject函數(shù)。


(二)使用客戶端存儲共享數(shù)據(jù)

       隨著HTML5,WEB標準日益靠近于桌面,同樣,桌面也開始集成WEB。這方面一個最大的變化就是客戶端存儲。這在客戶機上給了每一方(比如每一個頁面)一個能利用SQL的數(shù)據(jù)庫引擎,可以緩存本地數(shù)據(jù),減少流量,使頁面能脫機使用。還可以用來存儲大量的結(jié)構(gòu)化的,可搜索的數(shù)據(jù)。

      客戶端存儲可以在JavaScript中使用,從JavaScript代碼中搜索數(shù)據(jù)庫,然后從搜索結(jié)果中生成頁面。這要使用 openDatabase和transaction函數(shù)。

假設現(xiàn)在有個數(shù)據(jù)庫, 代碼如下所示:

db = openDatabase("TestDb ""1.0""Client side storage test"200000);
db.transaction(
function(tx) {
      tx.executeSql(
"SELECT id, text FROM Texts", [], function(tx, result) {
          for (var i = 0; i < result.rows.length; ++i) {
              var row = result.rows.item(i);
               processText( row['id'], row['text'] );
         }
    }, 
  function(tx, error) {
         alert('Failed to retrieve texts from the database 
- ' + error.message);
         return;
    });
});

     使用QtWebkit,你可以使用QtSql模塊訪問同一個數(shù)據(jù)庫。這在混合開發(fā)中是一個非常有用的特征。比如,你的應用中的web頁面在和本地部分共享數(shù)據(jù)時,可以用同樣的機制來保存數(shù)據(jù)。
     為了避免安全問題,客戶端的數(shù)據(jù)庫只能由具有正確權(quán)限的一方在JavaScript中訪問。本地的C++代碼也可以通過靜態(tài)的QWebSecurityOrigin::allOrigins 方法,或者通過QWebFrame::securityOrigin 來訪問所有安全對象
   

       通過databases方法,可以訪問一個QWebDatabaew方法列表,每一個web數(shù)據(jù)庫對象有一個filename屬性,可以用來在本地代碼中訪問數(shù)據(jù)庫。

QWebDatabase webdb = mySecurityOrigin.databases()[index];
QSqlDatabase sqldb 
= QSqlDatabase::addDatabase("QSQLITE""webconnection");
sqldb.setDatabaseName(webdb.fileName());
if (sqldb.open()) {
    QStringList tables 
= sqldb.tables();
  
}

         在WEB和本地應用連接事件的能力,再加上共享數(shù)據(jù)的機制,更易于模糊WEB和桌面之間的界限。



(三)WEB轉(zhuǎn)換

       很多通過WEB得到的數(shù)據(jù)并不適合直接顯示。比如網(wǎng)絡新聞, 地理數(shù)據(jù),以及其它特定數(shù)據(jù)格式的應用。QT的網(wǎng)絡模塊可以以一種很簡單的方式下載這樣的數(shù)據(jù),然后解析數(shù)據(jù),把它轉(zhuǎn)換成能被自己的代碼處理的合適的格式。也可以通過QtXmlPatterns模塊處理,當輸出格式是XML或者想在XHMTL網(wǎng)頁中顯示時,這樣更加方便。

      我們通過一個小例子來大致了解一下這個有意思的部分。我們下載一個新聞源,用XSLT把它從XML轉(zhuǎn)換成XHTML,然后通過QWebPage把它顯示出來。(圖略)
      QNetworkAccessManager 類讓你很容易處理客戶端和WEB服務器之間的交互。它幫你處理諸如代理,保存設置,COOKIE以及SSL會話這些細節(jié)。總之,它不但讓你在象上傳下載這些常見情況更加容易,還可以幫你處理登錄,認證這些復雜會話。
    為了下載我們例子中的新聞源,我們所有要做的就是創(chuàng)建一個QNetworkAccessManager 然后調(diào)用它的get方法。結(jié)果通過 finished(QNetworkReply*) 信號返回。

{

QNetworkAccessManager 
*manager = new QNetworkAccessManager( this );
connect( manager, SIGNAL(finished(QNetworkReply
*)), this, SLOT(handleReply(QNetworkReply*)) );
connect( manager, SIGNAL(finished(QNetworkReply
*)), m_progressBar, SLOT(hide()) );
QNetworkReply 
*reply = manager->get( QNetworkRequest( QUrl( feedUrl ) ) );
connect( reply, SIGNAL(downloadProgress(qint64, qint64)),
this, SLOT(updateProgress(qint64,qint64)) );
}


未完。。。。

posted on 2009-03-09 16:41 eXile 閱讀(10241) 評論(7)  編輯 收藏 引用 所屬分類: C/C++QT

評論

# re: (TR)利用QT進行web與本地混合應用開發(fā) 2009-03-10 10:20 Arthur Lee

不能給個完整的原文鏈接嗎?  回復  更多評論   

# re: (TR)利用QT進行web與本地混合應用開發(fā) 2009-03-10 12:30 eXile

@Arthur Lee
加上了。。。
  回復  更多評論   

# re: (TR)利用QT進行web與本地混合應用開發(fā) 2009-03-10 15:49 temp33

用c++做web開發(fā),sb行為  回復  更多評論   

# re: (TR)利用QT進行web與本地混合應用開發(fā) 2009-03-10 22:05 eXile

不是做web開發(fā),而是本地桌面應用集成WEB服務。另外,現(xiàn)在很多本地應用實際上都是用網(wǎng)頁來做界面。  回復  更多評論   

# re: [T] 利用QT進行web與本地混合應用開發(fā) 2009-03-30 20:59

確實不錯  回復  更多評論   

# re: [T] 利用QT進行web與本地混合應用開發(fā) 2009-12-06 16:46 fasdfads

fasdfadsfasdfadsfadsfads們通過一個小例子來大致了解一下這個有意思的部分。我們下載一個新聞源,用XSLT把它從XML轉(zhuǎn)換成XHTML,然后通過QWebPage把它顯示出來。(圖略)
QNetworkAccessManager 類讓你很容易處理客戶端和WEB服務器之間的交互。它幫你處理諸如代理,保存設置,COOKIE以及SSL會話這些細節(jié)。總之,它不但讓你在象上傳下載這些常見情況更加容易,還可以幫你處理登錄,認證這些復雜會話。
為了下載我們例子中的新聞源,我們所有要做的就是創(chuàng)建一個QNetworkAccessManager 然后調(diào)用它的get方法。結(jié)果通過 finished(QNetworkReply*) 信號返回。  回復  更多評論   

# re: [T] 利用QT進行web與本地混合應用開發(fā) 2012-09-21 10:45 梁楓

非常好,我就需要  回復  更多評論   

導航

<2025年9月>
31123456
78910111213
14151617181920
21222324252627
2829301234
567891011

統(tǒng)計

常用鏈接

留言簿(18)

隨筆分類

隨筆檔案

服務器編程

搜索

最新評論

閱讀排行榜

評論排行榜

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            亚洲欧洲在线视频| 午夜精品久久久久久久99樱桃| 久久一区二区三区av| 久久综合九色欧美综合狠狠| 国产亚洲精品aa午夜观看| 亚洲国产第一| 亚洲国产精品传媒在线观看 | 久久亚洲精品网站| 精品电影在线观看| 欧美国产一区二区| 亚洲一区二区毛片| 久久精品伊人| 亚洲免费观看高清完整版在线观看| 欧美激情小视频| 亚洲欧美精品伊人久久| 欧美**字幕| 亚洲一区二区不卡免费| 影音先锋中文字幕一区二区| 欧美日韩国产一区二区三区| 欧美一区永久视频免费观看| 亚洲欧洲一区二区三区久久| 久久久久久高潮国产精品视| 亚洲国产美女精品久久久久∴| 久热精品在线视频| 亚洲一区二区三区四区视频| 欧美成人精品一区| 欧美一区二区三区在线看| 亚洲每日更新| 一色屋精品视频免费看| 国产精品初高中精品久久| 久久久综合免费视频| 亚洲欧美激情四射在线日 | 亚洲网站啪啪| 欧美电影电视剧在线观看| 亚洲欧美综合精品久久成人| 在线观看亚洲a| 日韩一级大片在线| 欧美激情视频网站| 欧美在线观看视频一区二区| 亚洲视频免费看| 日韩视频专区| 日韩视频永久免费| 亚洲福利视频二区| 精品福利免费观看| 国产亚洲午夜高清国产拍精品| 国产精品igao视频网网址不卡日韩| 欧美国产在线电影| 91久久国产综合久久蜜月精品| 国产精品视频免费在线观看| 蜜桃av久久久亚洲精品| 久久久久久久久久久久久久一区 | 久久精品国产清自在天天线 | 亚洲精品123区| 在线观看成人av| 激情丁香综合| 狠狠色噜噜狠狠狠狠色吗综合| 国产伦精品一区二区三区免费迷 | 欧美专区亚洲专区| 久久精品国产亚洲一区二区| 久久精品国产欧美亚洲人人爽| 久久精品成人一区二区三区蜜臀| 久久国产88| 欧美在线视频一区二区三区| 久久九九精品99国产精品| 久久久久久亚洲精品杨幂换脸| 久久久久久久尹人综合网亚洲| 久久精品99无色码中文字幕| 久久久久国产精品一区二区| 久久一区二区三区国产精品| 欧美不卡视频一区| 欧美日韩一区在线播放| 国产精品视频免费在线观看| 国户精品久久久久久久久久久不卡| 国产婷婷色一区二区三区| 黄色精品网站| 亚洲激情小视频| 亚洲欧美日韩精品久久| 久久精品免费播放| 欧美高清自拍一区| 亚洲午夜久久久| 久久久99国产精品免费| 欧美日韩不卡视频| 国产日韩欧美高清免费| 亚洲国产美女| 性亚洲最疯狂xxxx高清| 女人香蕉久久**毛片精品| 99视频+国产日韩欧美| 欧美伊人精品成人久久综合97| 亚洲毛片在线看| 欧美在线91| 亚洲日本激情| 久久精品国产综合| 国产精品黄色| 亚洲精品一区二区三区不| 午夜精品福利一区二区蜜股av| 欧美成年人视频网站| 一区二区免费看| 久久九九热免费视频| 欧美日韩视频在线| 国产综合色产在线精品| 亚洲一区在线免费| 欧美激情1区2区3区| 亚洲欧美日韩精品一区二区| 欧美电影资源| 国模精品一区二区三区| 亚洲网站在线观看| 欧美激情一区二区三区不卡| 亚洲欧美日韩直播| 欧美日韩喷水| 日韩一区二区高清| 欧美激情精品久久久久久免费印度 | 欧美一级午夜免费电影| 欧美人与性动交α欧美精品济南到| 樱桃成人精品视频在线播放| 欧美亚洲日本一区| 一区二区三区波多野结衣在线观看| 老鸭窝毛片一区二区三区| 国产一区二区av| 欧美专区第一页| 亚洲欧美一区二区三区极速播放 | 欧美大片一区二区三区| 久久噜噜噜精品国产亚洲综合 | 一本色道久久综合亚洲二区三区| 欧美高清一区二区| 久久一二三四| 91久久久在线| 亚洲国产精品嫩草影院| 麻豆av福利av久久av| 亚洲成人影音| 亚洲第一天堂无码专区| 欧美黄在线观看| 亚洲免费精彩视频| 91久久精品一区二区三区| 欧美刺激性大交免费视频| 亚洲精选在线观看| 亚洲三级视频在线观看| 欧美三级电影大全| 一区二区日韩免费看| 亚洲激情在线播放| 欧美激情第六页| 亚洲欧美日韩一区二区在线| 亚洲专区国产精品| 影院欧美亚洲| 亚洲电影免费在线| 欧美激情在线狂野欧美精品| 亚洲网站在线| 小嫩嫩精品导航| 在线看无码的免费网站| 亚洲激情在线观看| 久久激情网站| 亚洲理论在线| 亚洲午夜日本在线观看| 亚洲免费不卡| 一卡二卡3卡四卡高清精品视频| 一区二区高清视频在线观看| 亚洲影院色无极综合| 久久久www成人免费无遮挡大片| 理论片一区二区在线| 亚洲精选91| 老鸭窝毛片一区二区三区| 欧美激情视频网站| 国产亚洲一区二区三区在线观看 | 欧美一区亚洲| 久久久久久久久一区二区| 欧美激情视频一区二区三区在线播放 | 久久久www成人免费无遮挡大片 | 久热精品视频在线| 美女免费视频一区| 99综合精品| 欧美一进一出视频| 久久阴道视频| 国产色综合天天综合网| 亚洲网站视频福利| 老司机午夜精品视频| 亚洲天堂av综合网| 免费成年人欧美视频| 国产精品福利片| 亚洲国产综合视频在线观看| 久久国产精品久久精品国产| 国产精品日韩精品欧美在线| 国产精品人人爽人人做我的可爱 | 欧美成人自拍视频| 亚洲一区二区三区涩| 欧美日韩一区二区在线观看视频| 国模精品娜娜一二三区| 午夜精品久久久久久久久久久久久 | 久久综合九色| 亚洲自拍偷拍一区| 欧美精品三级日韩久久| 在线播放日韩| 噜噜噜在线观看免费视频日韩| 亚洲欧美国产制服动漫| 国产伦精品一区二区三| 久久精视频免费在线久久完整在线看| 亚洲欧美日韩一区在线观看| 一区免费观看视频| 亚洲性视频h| 亚洲精品自在久久| 久热精品视频| 欧美va亚洲va香蕉在线|