分享一下我老师大神的人工智能教程!零基础,通俗易懂!http://blog.csdn.net/jiangjunshow
也欢迎大家转载本篇文章。分享知识,造福人民,实现我们中华民族伟大复兴!
用C++扩展Electron(node-ffi版)
Electron内置的node.js,理论上可以通过扩展node.js来扩展Electron。但是通常由于系统中存在的node.js与Electron内置的node.js的版本号不同,给node.js编译的扩展是无法在Electron中使用的,需要一些特殊处理才行。
0.先安装node.js和python(2.7)。请参考:
1.新建一个demo项目: 创建demo目录,并进入其中,然后运行下面命令。
mkdir democd demonpm init
- 1
- 2
- 3
运行npm init时,把『entry point』设置成main.js,之后会生成一个package.json(具体内容与输入参数有关):
{ "name": "demo", "version": "1.0.0", "description": "a demo for node call native functions", "main": "main.js", "scripts": { "test": "echo \"Error: no test specified\" && exit 1" }, "keywords": [ "node" ], "author": "Li XianJing", "license": "ISC"}
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
- 11
- 12
- 13
- 14
2.安装electron和编译工具和头文件。
sudo npm install -g prebuild node-gyp electronnpm install ffi bindings --save
- 1
- 2
3.用C++编写原生代码( 为了让目录结构整洁一点,我们把代码放到native只目录下)。
下面的文件(native/demo.cc),添加一个Add方法,计算两个数之和:
double Add(double a, double b) { return a+b;}
- 1
- 2
- 3
4.写一个Makefile(native/Makefile), 用来编译C++代码。
all: $(CC) -g -shared demo.c -o libdemo.dylibclean: rm -frv libdemo*
- 1
- 2
- 3
- 4
5.用prebuild编译指定版本的electron的ref/ffi(可以把下面的命令放到Makefile中)。
(1.4.12是electron的版本号)
cd native && make; cd -cd node_modules/ref && prebuild -b 1.4.12 -r electron; cd -cd node_modules/ffi && prebuild -b 1.4.12 -r electron; cd -
- 1
- 2
- 3
6.编写Electron的入口(main.js):
const electron = require('electron')const app = electron.appconst BrowserWindow = electron.BrowserWindowconst path = require('path')const url = require('url')let mainWindowfunction createWindow () { mainWindow = new BrowserWindow({width: 800, height: 600}) mainWindow.loadURL(url.format({ pathname: path.join(__dirname, 'index.html'), protocol: 'file:', slashes: true })) mainWindow.webContents.openDevTools() mainWindow.on('closed', function () { mainWindow = null })}app.on('ready', createWindow)app.on('window-all-closed', function () { if (process.platform !== 'darwin') { app.quit() }})app.on('activate', function () { if (mainWindow === null) { createWindow() }})
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
- 11
- 12
- 13
- 14
- 15
- 16
- 17
- 18
- 19
- 20
- 21
- 22
- 23
- 24
- 25
- 26
- 27
- 28
- 29
- 30
- 31
- 32
- 33
- 34
7.编写Electron的index.html
<!DOCTYPE html><html><script>var ffi = require('ffi');var demo = ffi.Library('./native/libdemo', { 'Add': [ 'double', [ 'double', 'double'] ]});window.onload = function() { console.log(demo.Add(12345, 54321));}</script></html>
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
- 11
- 12
- 13
12.测试效果:
Electron .
- 1
参考: