Chrome Native Client 简介 目的: Native Client是一种允许在浏览器中运行native compiled code 的技术,允许开发者运用自己熟悉的语言来开发web应用,而不只是JavaScript,目前NativeClient技术只能应用于google自己的chrome中。 一个使用Native client技术的web应用的组成:JavaScript,HTML, CSS, 和Native Client 模块,Native Client 模块:就是用Native语言编写的,供web调用的模块,目前NativeClient SDK只支持C和C++作为native 语言。
应用场景: 1. 使用现有的已经存在的软件模块完成一个web 应用,而不需要换一种web语言来编写。 2. 一些传统桌面程序的迁移。 3. 多媒体应用的迁移。 4. 游戏应用的迁移。
Native client的工作原理: 一个Native Client应用主要分为3个组成部分: 1, HTML/JavaScriptapplication: 提供了用户界面和时间处理机制。 2, PepperAPI: 使得JavaScript code 和NativeClient module可以相互通信,同时允许Native Client 模块创建和管理浏览器相关的资源。 3, NativeClient module: 通常用于完成大量的计算,和大数据的操作。
下面看一下HTML/JavaScript和Native client Module之间的消息交互过程: 1. Html/JavaScript代码向NativeClientModule 发送消息: 在HTML/JavaScript代码中以一个<embed>块表示NativeClient module, 例如: <embed name="nacl_module" id="hello_world" width=0height=0 src="hello_world.nmf" type="application/x-nacl"/> 在load 完native client 之后,就可以通过getElementByID(hello_world),来获得Nativeclient的句柄--helloworldModule,之后可以通过helloworldModule->PostMessage()向NativeClient发送消息。 2. Html/JavaScript接收NativeClientModule发送的消息。 在html/JavaScript代码中,通过注册监听message消息,来实现对nativeClient消息的handle. listener.addEventListener('message',handleMessage, true); 3. NativeClient Module向html/javaScript发送消息。 在nativeClient端,以一个pp::Instance()来代表html/JavaScript实体, 于是NativeClientModule 就可以通过pp::Instance->PostMessage来向html/JavaScript端发送消息。 4. NativeClient Module 接收html/javaScript消息。 可以通过pp::Instance()的hanleMessage()接口来处理发过过来的消息。
参考: https://developers.google.com/native-client/overview?hl=zh-CN#intro https://developers.google.com/native-client/devguide/tutorial#review |
|