• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1# chromium
2- [简介](#简介)
3- [目录](#目录)
4- [使用说明](#使用说明)
5- [相关仓](#相关仓)
6## 简介
7### 内容介绍
81. Chromium是由Google主导开发的网页浏览器,以BSD许可证等多重自由版权发行并开放源代码,是Google的Chrome浏览器背后的引擎,其目的是为了创建一个安全、稳定和快速的通用浏览器。
92. OpenHarmony nwebview基于Chromium构建。
10### 软件架构
11软件架构说明
12```
13    -----------------------
14    |      web组件          |
15    -----------------------
16    |      nwebview        |
17    -----------------------
18    |       CEF            |
19    -----------------------
20    |      Chromium        |
21    -----------------------
22    |  OpenHarmony基础库    |
23    -----------------------
24```
25* web组件:OpenHarmony的UI组件。
26* nwebview:基于CEF构建的OpenHarmony web组件的Native引擎。
27* CEF:CEF全称Chromium Embedded Framework,是一个基于Google Chromium 的开源项目。
28* Chromium: Chromium是一个由Google主导开发的网页浏览器,以BSD许可证等多重自由版权发行并开放源代码。
29## 目录
30```
31.
32└── patch                      # 构建nwebview,针对chromium修改的patch目录
33```
34## 使用说明
351. 执行./init_chromium.sh,初始化源代码,主要做以下几步
36* 下载google工具集depot_tools。
37* 拉取chromium源码,下载chromium依赖的相关三方库
38* 在源代码基础上增加针对nweb的构建修改,主要包括:增加cef代码,openharmony编译构建适配,nweb构建源码,chromium漏洞补丁以及nweb的bugfix修改。
39*注1:关于cef的介绍,可以访问cef仓:[third_party_cef](https://gitee.com/openharmony/third_party_cef)*
402. 全量编译RK3568平台openharmony镜像,成功后,再执行第三步编译基于openharmony平台的nweb组件。
41*注2:关于如何构建RK3568平台openharmony镜像,可以访问:[RK3568编译指导](https://gitee.com/openharmony/docs/blob/master/zh-cn/device-dev/quick-start/quickstart-ide-3568-build.md)*
423. 执行./build.sh rk3568,编译源码。
434. 通过DevEco studio将编译目标打包成NWeb.hap,使用hdc_std install NWeb.hap安装至RK3568,
44* 1.IDE下载可访问:[下载官网](https://developer.harmonyos.com/cn/develop/deveco-studio#download)
45   ![](figures/下载版本.png "下载版本")
46
47* 2.新建OpenHarmony空白工程
48   ![](figures/新建工程.png "新建工程")
49* 3.复制编译生成的文件(src/out/rk3568src/out/rk3568_64目录下)至工程对应位置
50    32位镜像,so放置于/entry/libs/armeabi-v7a/
51    64位镜像,so放置于/entry/libs/arm64-v8a/
52    其他资源文件放置于/entry/src/main/resources/rawfile/
53    如图所示为32位镜像对应放置位置:
54   ![](figures/存放路径.png "存放路径")
55
56* 4.删除entry/src/main/ets/pages/Index.ets文件
57
58* 5.修改src/main/ets/entryability/EntryAbility.ts文件为以下内容:
59   ![](figures/EntryAbility_ts.png "EntryAbility.ts")
60
61* 6.修改src/main/module.json5文件,删除"abilities"字段
62
63* 7.删除src/main/resources/base/media/icon.png
64
65* 8.修改AppScope/app.json5中"vendor"的值为"nweb",
66
67* 9.删除src/main/resources/base/profile/main_pages.json中”src”中的内容
68
69* 10.配置自动签名之后,通过IDE打包hap
70
71* 11.由于签名不同,无法直接安装,通过
72  hdc file send 本地hap包 /system/app/com.ohos.nweb/NWeb.hap
73进行安装
74
75## 相关仓
76[arkui_ace_engine](https://gitee.com/openharmony/arkui_ace_engine)
77
78[third_party_cef](https://gitee.com/openharmony/third_party_cef)
79
80[web_webview](https://gitee.com/openharmony/web_webview)
81
82**[third_party_chromium](https://gitee.com/openharmony/third_party_chromium)**
83