在 QT 目录中打开下面的文件:
/src/3rdparty/webkit/JavaScriptCore/bindings/runtime.cpp
有下面几行:
- #ifPLATFORM(QT)
-
caseInstance::QtLanguage:{
- newInstance=Bindings::QtInstance::getQtInstance((QObject*)nativeInstance,rootObject);
-
break;
-
}
- #endif
这就表明,可以用 QtLanguage 来编写自定义的 javascript 对象。这里也有几个别的 Language,也就是说可以用它们来编写扩展 javascript 对象,应该也能自定义自己的 Language。既然是用 qt 的 GUI,使用 QtLanguage 应该是最合适的。
先打开它的例子文件:
/src/3rdparty/webkit/JavaScriptCore/bindings/testqtbindings.cpp
可以看到其中有这样几行:
- staticcharcode[]=
-
"myInterface.foo();/n"
-
"myInterface.testString=/"Hello/";/n"
-
"str=myInterface.testString;/n"
-
"myInterface.testInt=10;/n"
-
"i=myInterface.testInt;/n";
这就是说,testqtbindings.cpp 的内容可以对下面的 javascript 进行解析:
- myInterface.foo();
-
myInterface.testString="Hello";
-
varstr=myInterface.testString;
- myInterface.testInt=10;
-
vari=myInterface.testInt;
我想定义自己的 javascript,比如在 myInterface 对象前面加上一个 CSDN 对象:
- CSDN.myInterface.foo();
-
CSDN.myInterface.testString="Hello";
- varstr=CSDN.myInterface.testString;
这件事情本来很简单,可是就象 CSDN.myInterface.foo() 这样,连接 CSDN 和 myInterface 两个对象的事情,在网上(中文和英文网站)找了半天没找着,结果还是我自己想到的。
1. 在原来的文件中再添加一个 MyCSDNObject 对象:
- classMyCSDNObject:publicQObject
- {
- Q_OBJECT
- Q_PROPERTY(QStringtestStringREADtestStringWRITEsetTestString)
-
Q_PROPERTY(inttestIntREADtestIntWRITEsetTestInt)
-
- Q_PROPERTY(QObject*myInterfaceREADtestMyInterface)
-
public:
- MyCSDNObject():QObject(0),integer(0),m_myObject(NULL){}
-
voidsetTestString(constQString&str){
-
qDebug()<<"calledsetTestString"<<str;
-
string=str;
- }
-
voidsetTestInt(inti){
-
qDebug()<<"calledsetTestInt"<<i;
- integer=i;
- }
-
QStringtestString()const{
-
qDebug()<<"calledtestString"<<string;
-
returnstring;
- }
-
inttestInt()const{
-
qDebug()<<"calledtestInt"<<integer;
-
returninteger;
- }
-
- QObject*testMyInterface()
- {
-
if(m_myObject==NULL)
-
m_myObject=newMyObject();
-
returnm_myObject;
- }
-
QStringstring;
-
intinteger;
-
- MyObject*m_myObject;
-
publicslots:
-
voidfoo(){qDebug()<<"fooinvoked";}
- };
这样 MyCSDNObject 和 MyObject 这样两个对象就可以连起来了,成为 CSDN.testMyInterface
2. 修改一下创建的根对象的名字
- global->put(exec,Identifier("CSDN"),Instance::createRuntimeObject(Instance::QtLanguage,(void*)myObject));
这样就可以了。这是个测试程序,需要把这些测试代码添加到 WebKit 浏览器中。打开文件:
./src/3rdparty/webkit/WebKit/qt/Api/qwebframe.h
把刚才的 MyObject 类和 MyCSDNObject 类在其中声名一下,然后添加CSDN 根对象作为QWebFrame 类的私有成员,如下所示:
- classMyObject:publicQObject
- {
- Q_OBJECT
-
- };
-
classMyCSDNObject:publicQObject
- {
- Q_OBJECT
-
- };
-
classQWEBKIT_EXPORTQWebFrame:publicQObject
- {
- Q_OBJECT
- Q_PROPERTY(qrealtextSizeMultiplierREADtextSizeMultiplierWRITEsetTextSizeMultiplier)
- Q_PROPERTY(QStringtitleREADtitle)
- Q_PROPERTY(QUrlurlREADurlWRITEsetUrl)
- Q_PROPERTY(QIconiconREADicon)
- Q_PROPERTY(QSizecontentsSizeREADcontentsSize)
-
private:
- QWebFrame(QWebPage*parent,QWebFrameData*frameData);
- QWebFrame(QWebFrame*parent,QWebFrameData*frameData);
- ~QWebFrame();
-
- MyCSDNObject*m_csdn;
-
public:
-
- };
打开 qwebframe.cpp 文件,在 QWebFrame 的构造函数中创建 CSDN 根对象。
- QWebFrame::QWebFrame(QWebPage*parent,QWebFrameData*frameData)
- :QObject(parent)
-
,d(newQWebFramePrivate)
- {
- d->page=parent;
-
d->init(this,parent->d->page,frameData);
-
- {
- KJS::Bindings::RootObject*root=d->frame->bindingRootObject();
- KJS::ExecState*exec=root->interpreter()->globalExec();
- KJS::JSObject*global=root->interpreter()->globalObject();
-
m_csdn=newMyCSDNObject();
-
global->put(exec,KJS::Identifier("CSDN"),KJS::Bindings::Instance::createRuntimeObject(KJS::Bindings::Instance::QtLanguage,(void*)m_csdn,root));
- }
-
if(!frameData->url.isEmpty()){
- ResourceRequestrequest(frameData->url,frameData->referrer);
- d->frame->loader()->load(request,frameData->name);
- }
- }
在 QWebFrame 的析构函数中删除 CSDN 根对象
- QWebFrame::~QWebFrame()
- {
-
if(d->frame&&d->frame->loader()&&d->frame->loader()->client())
- static_cast(d->frame->loader()->client())->m_webFrame=0;
-
if(m_csdn)
- {
- deletem_csdn;
- m_csdn=NULL;
- }
- deleted;
- }
再手工编写一个 HTML 测试页 csdn1.htm,内容如下:
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN"> <html> <head> <title> New Document </title> <script language="JavaScript"> <!-- function test() { CSDN.myInterface.foo(); CSDN.myInterface.testString = "Hello QtWebKit JavaScript"; var str = CSDN.myInterface.testString; document.getElementById("txtMessage").innerHTML = str; } //--> </script> </head>
<body> <p><a href="javascript:test();">test qt-webkit javascript</a></p> <p id="txtMessage"></p> </body> </html>
|
编译并运行WebKit 浏览器,让它打开刚才的测试页 csdn1.htm,点击上面的 test qt-webkit javascript 链接,可以得到下面的效果:
上面的 Hello QtWebKit JavaScript 就是 javascript 设置的 CSDN.myInterface.testString内容。
在 QT 目录中打开下面的文件:
/src/3rdparty/webkit/JavaScriptCore/bindings/runtime.cpp
有下面几行:
- #ifPLATFORM(QT)
-
caseInstance::QtLanguage:{
- newInstance=Bindings::QtInstance::getQtInstance((QObject*)nativeInstance,rootObject);
-
break;
-
}
- #endif
这就表明,可以用 QtLanguage 来编写自定义的 javascript 对象。这里也有几个别的 Language,也就是说可以用它们来编写扩展 javascript 对象,应该也能自定义自己的 Language。既然是用 qt 的 GUI,使用 QtLanguage 应该是最合适的。
先打开它的例子文件:
/src/3rdparty/webkit/JavaScriptCore/bindings/testqtbindings.cpp
可以看到其中有这样几行:
- staticcharcode[]=
-
"myInterface.foo();/n"
-
"myInterface.testString=/"Hello/";/n"
-
"str=myInterface.testString;/n"
-
"myInterface.testInt=10;/n"
-
"i=myInterface.testInt;/n";
这就是说,testqtbindings.cpp 的内容可以对下面的 javascript 进行解析:
- myInterface.foo();
-
myInterface.testString="Hello";
-
varstr=myInterface.testString;
- myInterface.testInt=10;
-
vari=myInterface.testInt;
我想定义自己的 javascript,比如在 myInterface 对象前面加上一个 CSDN 对象:
- CSDN.myInterface.foo();
-
CSDN.myInterface.testString="Hello";
- varstr=CSDN.myInterface.testString;
这件事情本来很简单,可是就象 CSDN.myInterface.foo() 这样,连接 CSDN 和 myInterface 两个对象的事情,在网上(中文和英文网站)找了半天没找着,结果还是我自己想到的。
1. 在原来的文件中再添加一个 MyCSDNObject 对象:
- classMyCSDNObject:publicQObject
- {
- Q_OBJECT
- Q_PROPERTY(QStringtestStringREADtestStringWRITEsetTestString)
-
Q_PROPERTY(inttestIntREADtestIntWRITEsetTestInt)
-
- Q_PROPERTY(QObject*myInterfaceREADtestMyInterface)
-
public:
- MyCSDNObject():QObject(0),integer(0),m_myObject(NULL){}
-
voidsetTestString(constQString&str){
-
qDebug()<<"calledsetTestString"<<str;
-
string=str;
- }
-
voidsetTestInt(inti){
-
qDebug()<<"calledsetTestInt"<<i;
- integer=i;
- }
-
QStringtestString()const{
-
qDebug()<<"calledtestString"<<string;
-
returnstring;
- }
-
inttestInt()const{
-
qDebug()<<"calledtestInt"<<integer;
-
returninteger;
- }
-
- QObject*testMyInterface()
- {
-
if(m_myObject==NULL)
-
m_myObject=newMyObject();
-
returnm_myObject;
- }
-
QStringstring;
-
intinteger;
-
- MyObject*m_myObject;
-
publicslots:
-
voidfoo(){qDebug()<<"fooinvoked";}
- };
这样 MyCSDNObject 和 MyObject 这样两个对象就可以连起来了,成为 CSDN.testMyInterface
2. 修改一下创建的根对象的名字
- global->put(exec,Identifier("CSDN"),Instance::createRuntimeObject(Instance::QtLanguage,(void*)myObject));
这样就可以了。这是个测试程序,需要把这些测试代码添加到 WebKit 浏览器中。打开文件:
./src/3rdparty/webkit/WebKit/qt/Api/qwebframe.h
把刚才的 MyObject 类和 MyCSDNObject 类在其中声名一下,然后添加CSDN 根对象作为QWebFrame 类的私有成员,如下所示:
- classMyObject:publicQObject
- {
- Q_OBJECT
-
- };
-
classMyCSDNObject:publicQObject
- {
- Q_OBJECT
-
- };
-
classQWEBKIT_EXPORTQWebFrame:publicQObject
- {
- Q_OBJECT
- Q_PROPERTY(qrealtextSizeMultiplierREADtextSizeMultiplierWRITEsetTextSizeMultiplier)
- Q_PROPERTY(QStringtitleREADtitle)
- Q_PROPERTY(QUrlurlREADurlWRITEsetUrl)
- Q_PROPERTY(QIconiconREADicon)
- Q_PROPERTY(QSizecontentsSizeREADcontentsSize)
-
private:
- QWebFrame(QWebPage*parent,QWebFrameData*frameData);
- QWebFrame(QWebFrame*parent,QWebFrameData*frameData);
- ~QWebFrame();
-
- MyCSDNObject*m_csdn;
-
public:
-
- };
打开 qwebframe.cpp 文件,在 QWebFrame 的构造函数中创建 CSDN 根对象。
- QWebFrame::QWebFrame(QWebPage*parent,QWebFrameData*frameData)
- :QObject(parent)
-
,d(newQWebFramePrivate)
- {
- d->page=parent;
-
d->init(this,parent->d->page,frameData);
-
- {
- KJS::Bindings::RootObject*root=d->frame->bindingRootObject();
- KJS::ExecState*exec=root->interpreter()->globalExec();
- KJS::JSObject*global=root->interpreter()->globalObject();
-
m_csdn=newMyCSDNObject();
-
global->put(exec,KJS::Identifier("CSDN"),KJS::Bindings::Instance::createRuntimeObject(KJS::Bindings::Instance::QtLanguage,(void*)m_csdn,root));
- }
-
if(!frameData->url.isEmpty()){
- ResourceRequestrequest(frameData->url,frameData->referrer);
- d->frame->loader()->load(request,frameData->name);
- }
- }
在 QWebFrame 的析构函数中删除 CSDN 根对象
- QWebFrame::~QWebFrame()
- {
-
if(d->frame&&d->frame->loader()&&d->frame->loader()->client())
- static_cast(d->frame->loader()->client())->m_webFrame=0;
-
if(m_csdn)
- {
- deletem_csdn;
- m_csdn=NULL;
- }
- deleted;
- }
再手工编写一个 HTML 测试页 csdn1.htm,内容如下:
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN"> <html> <head> <title> New Document </title> <script language="JavaScript"> <!-- function test() { CSDN.myInterface.foo(); CSDN.myInterface.testString = "Hello QtWebKit JavaScript"; var str = CSDN.myInterface.testString; document.getElementById("txtMessage").innerHTML = str; } //--> </script> </head>
<body> <p><a href="javascript:test();">test qt-webkit javascript</a></p> <p id="txtMessage"></p> </body> </html>
|
编译并运行WebKit 浏览器,让它打开刚才的测试页 csdn1.htm,点击上面的 test qt-webkit javascript 链接,可以得到下面的效果:
上面的 Hello QtWebKit JavaScript 就是 javascript 设置的 CSDN.myInterface.testString内容。
分享到:
相关推荐
-no-javascript-jit \ -no-separate-debug-info \ -no-dbus \ -no-exceptions \ -no-declarative \ -nomake docs \ -make lib \ -make include \ -no-largefile \ -no-xmlpatterns \ -no-...
[-no-javascript-jit] [-javascript-jit] [-no-script] [-script] [-no-scripttools] [-scripttools] [-no-declarative] [-declarative] [-no-declarative-debug] [-declarative-debug] [additional platform ...
利用Qt中的WebKit与网页中的javascript进行交互; Demo中实现用javascript代码调用Qt中的函数,用Qt中的代码调用javascript中的函数; 测试网页:myjstest.html
qt webkit web native communicate
很棒的Qt 精选Qt相关资料的精选清单。 基本模块 -其他模块使用的核心非图形类。 图形用户界面(GUI)组件的基类。... WebKit-用于基于WebKit2的实现和新的QML API的类。 另请参阅附加模块中的Qt
请先查看博客http://blog.csdn.net/longsir_area/article/details/42965565 再确定是否下载
capybara-webkit 由于不推荐使用QtWebKit,而赞成使用QtWebEngine,因此该项目的开发已暂停。 相反,我们建议使用或驱动程序。Qt依赖关系和安装问题capybara-webkit依赖于跨平台开发工具包Qt的WebKit实现。 您需要...
QDigraph 使用 javascript 库绘制有向图
一点不懂webkit和javascript开始摸起。如有疏漏多多斧正。 例子的功能就是在标准的qt主窗口加载一个谷歌地图。webkit在(0,0)放置一个图标。地图移动后通知Qt在标准输出打印经纬度。 因为以前上传资源的时候有人...
而Qt要显示web部分的东西,肯定是要用到QtWebkit(Qt4)或者 QtWebEngine(Qt5),这个视版本而定。 ECharts 提供了常规的折线图、柱状图、散点图、饼图、K线图,用于统计的盒形图,用于地理数据可视化的地图、...
UnicodeTiles.js 是提供一个基于文本字符...— 键盘处理Meta - general stuff基于 QtWebkit (要求 Qt)最好使用最新的 Chrome 和 Firefox 浏览器支持 IE9 和 Opera 11.61 不支持 IE8 及以下版本示例local link | online
htmlPy是的QtWebKit库的包装。 它有助于使用HTML5,CSS3和Javascript为独立的Python应用程序创建漂亮的GUI。 它建立在之上,这使其高度可定制且跨平台。 htmlPy与Python2和Python3兼容。 它可以与任何python库或...
它使用QtWebKit作为它核心浏览器的功能,使用webkit来编译解释执行JavaScript代码。任何你可以在基于webkit浏览器做的事情,它都能做到。它不仅是个隐形的浏览器,提供了诸如CSS选择器、支持Web标准、DOM操作、JSON...
BrowserExt PHP扩展是基于QtWebKit的程序化浏览器,用于Web抓取。 支持javascript和AJAX。 使用xpath选择元素 允许您填写表格,单击文档的元素 允许检索文档元素的属性,属性和其他参数,遍历树中的元素 允许通过...
它使用QtWebKit作为它核心浏览器的功能,使用webkit来编译解释执行JavaScript代码。任何你可以在基于webkit浏览器做的事情,它都能做到。它不仅是个隐形的浏览器,提供了诸如CSS选择器、支持Web标准、DOM操作、JSON...
它使用QtWebKit作为它核心浏览器的功能,使用webkit来编译解释执行javaScript代码。任何你可以基于在webkit浏览器做的事情,它都能做到。它不仅是个隐性的浏览器,提供了诸如css选择器、支持wen标准、DOM操作、json...
om-控制中心版本:1.0.0 这是用于测试的 om-control-center 需要以下依赖项: python-qt4-webkit web.py bigbashview bigbashview 已与 om-control-center 脚本集成到 om-control-center 中安装依赖要安装 python-qt...
侵略者 Invader是用于从网站获取数据的Python简单模块。 还具有JavaScript支持! 入侵者基于...$ sudo apt-get install qt5-default libqt5webkit5-dev build-essential python-lxml python-pip xvfb $ sudo
它使用QtWebKit作为它核心浏览器的功能,使用webkit来编译解释执行JavaScript代码。任何你可以在基于webkit浏览器做的事情,它都能做到。它不仅是个隐形的浏览器,提供了诸如CSS选择器、支持Web标准、DOM操作、JSON...