提交 d5196a8b 编写于 作者: Z zengyawen

update docs

Signed-off-by: Nzengyawen <zengyawen1@huawei.com>
上级 64c0ba86
...@@ -16,6 +16,7 @@ ...@@ -16,6 +16,7 @@
- [Data Management](database/Readme-EN.md) - [Data Management](database/Readme-EN.md)
- [USB Service](usb/Readme-EN.md) - [USB Service](usb/Readme-EN.md)
- [DFX](dfx/Readme-EN.md) - [DFX](dfx/Readme-EN.md)
- [WebGL](webgl/Readme-EN.md)
- [Development References](reference/Readme-EN.md) - [Development References](reference/Readme-EN.md)
- [JavaScript-based Web-like Development Paradigm](reference/arkui-js/Readme-EN.md) - [JavaScript-based Web-like Development Paradigm](reference/arkui-js/Readme-EN.md)
- [TypeScript-based Declarative Development Paradigm](reference/arkui-ts/Readme-EN.md) - [TypeScript-based Declarative Development Paradigm](reference/arkui-ts/Readme-EN.md)
......
# WebGL
- [WebGL Overview](webgl-overview.md)
- [WebGL Development](webgl-guidelines.md)
此差异已折叠。
# WebGL Overview
Web Graphic Library (WebGL) is used for rendering interactive 2D and 3D graphics. WebGL used in OpenHarmony is based on OpenGL for Embedded Systems (OpenGL ES). It can be used in the **&lt;canvas&gt;** object of HTML5 without using plug-ins and supports cross-platform. WebGL is programmed by JavaScript code. Its APIs can implement graphics rendering and acceleration by using GPU hardware provided by the user equipment.
## Basic Concepts
### Shader
Shaders are instructions and data that run in a graphics card. In WebGL, shaders are written in the OpenGL Shading Language (GLSL).
There are vertex shaders and fragment shaders. The interaction between vertex shaders and fragment shaders involves rasterization.
- The vertex shader is mainly used to receive the coordinates of a point in a 3D space, process the coordinates into coordinates in a 2D space, and output the coordinates.
- The fragment shader is mainly used to output a color value for each pixel being processed.
- Rasterization is the process of converting the coordinates output by the vertex shader into pixels to be processed and passing the pixels to the fragment shader.
### Buffer
The buffer is a JavaScript object that resides in memory and stores the **attribute** object to be pushed to the shader.
### WebGLProgram
The WebGLProgram is a JavaScript object responsible for associating the shader with the buffer. A **WebGLProgram** object consists of two compiled WebGL shaders: a vertex shader and a fragment shader.
## Working Principles
**Figure 1** WebGL working principles
![en-us_image_0000001238544451](figures/en-us_image_0000001238544451.png)
- An application draws UI components using HTML5 at the foreground.
- Native APIs complete the interaction between JavaScript and C++ code.
- QuickJS and V8 are graphics frameworks that provide the **Surface** object for the WebGL module.
- The WebGL module exposes the GPU drawing APIs of OpenGL ES.
- The Embedded Graphics Library (EGL) implements adaptation to different platforms.
...@@ -16,5 +16,6 @@ ...@@ -16,5 +16,6 @@
- [数据管理](database/Readme-CN.md) - [数据管理](database/Readme-CN.md)
- [USB服务](usb/Readme-CN.md) - [USB服务](usb/Readme-CN.md)
- [DFX](dfx/Readme-CN.md) - [DFX](dfx/Readme-CN.md)
- [WebGL](webgl/Readme-CN.md)
- [开发参考](reference/Readme-CN.md) - [开发参考](reference/Readme-CN.md)
...@@ -5,4 +5,6 @@ ...@@ -5,4 +5,6 @@
* [基于Native的Data Ability创建与访问](data-ability-creating-accessing.md) * [基于Native的Data Ability创建与访问](data-ability-creating-accessing.md)
* [CommonEvent开发指南](common-event.md) * [CommonEvent开发指南](common-event.md)
* [Notification开发指南](notification.md) * [Notification开发指南](notification.md)
* [应用迁移开发指导](ability-continuation.md)
* [Ability助手使用指导](ability-assistant-guidelines.md)
# Ability助手使用指导
Ability assistant(Ability助手,简称为aa)是实现应用、原子化服务及测试用例启动功能,为开发者提供基本的调试及测试应用的工具。通过该工具,开发者可以在hdc shell中,发出命令以执行各种系统操作,比如启动Ability、强制停止进程、打印Ability相关信息等。
## 开发指导
工具已在设备环境预置,开发者可直接通过命令行调用。
### 查询相关
- **help**
用于显示aa相关的帮助信息。
**返回值:**
返回对应的帮助信息。
**使用方法:**
```
aa help
```
### Ability相关
- **start**
用于启动一个ability。
| 参数 | 参数说明 |
| --------- | ---------------------- |
| -h/--help | 帮助信息。 |
| -d | 可选参数,device id |
| -a | 必选参数,ability name |
| -b | 必选参数,bundle name |
| -D | 可选参数,调试模式 |
**返回值:**
当成功启动Ability时,返回“start ability successfully.”;当启动失败时,返回“error: failed to start ability.”。
使用方法:
```
aa start [-d <device-id>] -a <ability-name> -b <bundle-name> [-D]
```
- **stop-service**
用于停止Service Ability。
| 参数 | 参数说明 |
| --------- | ------------------------ |
| -h/--help | 帮助信息。 |
| -d | 可选参数,device id。 |
| -a | 必选参数,ability name。 |
| -b | 必选参数,bundle name。 |
**返回值:**
当成功停止Service Ability时,返回“stop service ability successfully.”;当停止失败时,返回“error: failed to stop service ability.”。
使用方法:
```
aa stop-service [-d <device-id>] -a <ability-name> -b <bundle-name>
```
- **dump**
用于打印Ability的相关信息。
| 参数 | 参数说明 |
| ---------------------- | -------------------------------------- |
| -h/--help | 帮助信息。 |
| -a/--all | 打印所有mission内的Ability。 |
| -s/--stack \<number> | 打印指定mission stack内的Ability。 |
| -m/--mission \<number> | 打印指定mission内的Ability。 |
| -l/--stack-list | 打印每个mission stack内的mission列表。 |
| -u/--ui | 打印system ui Ability。 |
| -e/--serv | 打印Service Ability。 |
| -d/--data | 打印Data Ability。 |
**使用方法:**
```
aa dump -a
```
- **force-stop**
通过bundle name强制停止一个进程。
**返回值:**
当成功强制停止该进程时,返回“force stop process successfully.”;当强制停止失败时,返回“error: failed to force stop process.”。
**使用方法:**
```
aa force-stop <bundle-name>
```
\ No newline at end of file
# IPC与RPC通信
- **[IPC与RPC通信概述](ipc-rpc-overview.md)**
- **[IPC与RPC通信开发指导](ipc-rpc-development-guideline.md)**
- **[远端状态订阅开发实例](subscribe-remote-state.md)**
\ No newline at end of file
...@@ -18,9 +18,11 @@ ...@@ -18,9 +18,11 @@
- 媒体 - 媒体
- [音频管理](js-apis-audio.md) - [音频管理](js-apis-audio.md)
- [媒体服务](js-apis-media.md) - [媒体服务](js-apis-media.md)
- [图片处理](js-apis-image.md)
- 安全 - 安全
- [用户认证](js-apis-useriam-userauth.md) - [用户认证](js-apis-useriam-userauth.md)
- [访问控制](js-apis-abilityAccessCtrl.md) - [访问控制](js-apis-abilityAccessCtrl.md)
- [通用密钥库系统](js-apis-huks.md)
- 数据管理 - 数据管理
- [轻量级存储](js-apis-data-preferences.md) - [轻量级存储](js-apis-data-preferences.md)
- [轻量级存储(废弃 since 8)](js-apis-data-storage.md) - [轻量级存储(废弃 since 8)](js-apis-data-storage.md)
...@@ -46,6 +48,7 @@ ...@@ -46,6 +48,7 @@
- [SIM卡管理](js-apis-sim.md) - [SIM卡管理](js-apis-sim.md)
- [网络搜索](js-apis-radio.md) - [网络搜索](js-apis-radio.md)
- [observer](js-apis-observer.md) - [observer](js-apis-observer.md)
- [蜂窝数据](js-apis-telephony-data.md)
- 网络与连接 - 网络与连接
- [WLAN](js-apis-wifi.md) - [WLAN](js-apis-wifi.md)
- [Bluetooth](js-apis-bluetooth.md) - [Bluetooth](js-apis-bluetooth.md)
...@@ -55,6 +58,7 @@ ...@@ -55,6 +58,7 @@
- [屏幕亮度](js-apis-brightness.md) - [屏幕亮度](js-apis-brightness.md)
- [电量信息](js-apis-battery-info.md) - [电量信息](js-apis-battery-info.md)
- [系统电源管理](js-apis-power.md) - [系统电源管理](js-apis-power.md)
- [热管理](js-apis-thermal.md)
- [Runninglock锁](js-apis-runninglock.md) - [Runninglock锁](js-apis-runninglock.md)
- [设备信息](js-apis-device-info.md) - [设备信息](js-apis-device-info.md)
- [系统属性](js-apis-system-parameter.md) - [系统属性](js-apis-system-parameter.md)
......
...@@ -1342,13 +1342,9 @@ ellipse(x: number, y: number, radiusX: number, radiusY: number, rotation: number ...@@ -1342,13 +1342,9 @@ ellipse(x: number, y: number, radiusX: number, radiusY: number, rotation: number
.backgroundColor('#ffff00') .backgroundColor('#ffff00')
.onReady(() =>{ .onReady(() =>{
this.context.beginPath() this.context.beginPath()
this.context.ellipse(200, 200, 50, 100, Math.PI * 0.25, Math.PI * 0.5, Math.PI, true) this.context.ellipse(200, 200, 50, 100, Math.PI * 0.25, Math.PI * 0.5, Math.PI)
this.context.stroke() this.context.stroke()
}) })
Button('back')
.onClick(() => {
router.back()
})
} }
.width('100%') .width('100%')
.height('100%') .height('100%')
...@@ -1462,10 +1458,6 @@ clip(): void ...@@ -1462,10 +1458,6 @@ clip(): void
this.context.fillStyle = "rgb(255,0,0)" this.context.fillStyle = "rgb(255,0,0)"
this.context.fillRect(0, 0, 150, 150) this.context.fillRect(0, 0, 150, 150)
}) })
Button('back')
.onClick(() => {
router.back()
})
} }
.width('100%') .width('100%')
.height('100%') .height('100%')
......
...@@ -387,7 +387,7 @@ ellipse(x: number, y: number, radiusX: number, radiusY: number, rotation: number ...@@ -387,7 +387,7 @@ ellipse(x: number, y: number, radiusX: number, radiusY: number, rotation: number
.height('100%') .height('100%')
.backgroundColor('#ffff00') .backgroundColor('#ffff00')
.onReady(() =>{ .onReady(() =>{
this.path2Db.ellipse(200, 200, 50, 100, Math.PI * 0.25, Math.PI * 0.5, Math.PI, true) this.path2Db.ellipse(200, 200, 50, 100, Math.PI * 0.25, Math.PI * 0.5, Math.PI)
this.context.stroke(this.path2Db) this.context.stroke(this.path2Db)
}) })
} }
......
...@@ -1424,7 +1424,7 @@ ellipse(x: number, y: number, radiusX: number, radiusY: number, rotation: number ...@@ -1424,7 +1424,7 @@ ellipse(x: number, y: number, radiusX: number, radiusY: number, rotation: number
.backgroundColor('#ffff00') .backgroundColor('#ffff00')
.onReady(() =>{ .onReady(() =>{
this.offContext.beginPath() this.offContext.beginPath()
this.offContext.ellipse(200, 200, 50, 100, Math.PI * 0.25, Math.PI * 0.5, Math.PI, true) this.offContext.ellipse(200, 200, 50, 100, Math.PI * 0.25, Math.PI * 0.5, Math.PI)
this.offContext.stroke() this.offContext.stroke()
var image = this.offContext.transferToImageBitmap() var image = this.offContext.transferToImageBitmap()
this.context.transferFromImageBitmap(image) this.context.transferFromImageBitmap(image)
......
...@@ -3,5 +3,10 @@ ...@@ -3,5 +3,10 @@
- 用户认证 - 用户认证
- [用户认证开发概述](userauth-overview.md) - [用户认证开发概述](userauth-overview.md)
- [用户认证开发指导](userauth-guidelines.md) - [用户认证开发指导](userauth-guidelines.md)
- 密钥管理
- [HUKS开发概述](huks-overview.md)
- [HUKS开发指导](huks-guidelines.md)
- Hap包签名工具 - Hap包签名工具
- [Hap包签名工具开发指](hapsigntool-guidelines.md) - [Hap包签名工具开发指](hapsigntool-guidelines.md)
# Hap包签名工具开发指 # Hap包签名工具开发指
...@@ -353,6 +353,7 @@ java -jar hap-sign-tool.jar sign-app -keyAlias "oh-app1-key-v1" -signAlg "SHA256 ...@@ -353,6 +353,7 @@ java -jar hap-sign-tool.jar sign-app -keyAlias "oh-app1-key-v1" -signAlg "SHA256
## 常见问题 ## 常见问题
**1.执行[生成应用签名证书](#生成应用签名证书)命令时,控制台打印结果,无文件输出** **1.执行[生成应用签名证书](#生成应用签名证书)命令时,控制台打印结果,无文件输出**
......
# HUKS开发指 # HUKS开发指
## 场景介绍 ## 场景介绍
......
# WebGL
- [概述](webgl-overview.md)
- [WebGL开发指导](webgl-guidelines.md)
此差异已折叠。
# 概述
WebGL的全称为Web Graphic Library(网页图形库),主要用于交互式渲染2D图形和3D图形。目前OpenHarmony中使用的WebGL是基于OpenGL裁剪的OpenGL ES,可以在HTML5的canvas元素对象中使用,无需使用插件,支持跨平台。WebGL程序是由JavaScript代码组成的,其中使用的API可以利用用户设备提供的GPU硬件完成图形渲染和加速。
## 基本概念
### 着色器
可以理解为运行在显卡中的指令和数据。在WebGL中,着色器是用OpenGL ES着色语言(GLSL)编写的。
完整的着色器包括顶点着色器和片元着色器。顶点着色器和片元着色器的交互则涉及到图片光栅化。
- 顶点着色器:最基本的任务是接收三维空间中点的坐标,将其处理为二维空间中的坐标并输出。
- 片元着色器:最基本的任务是对需要处理的屏幕上的每个像素输出一个颜色值。
- 图片光栅化:将顶点着色器输出的二维空间中的点坐标,转化为需要处理的像素并传递给片元着色器的过程。
### 缓冲区
驻存于内存中的JavaScript对象,存储着即将推送到着色器中的attribute对象。
### 着色器程序
将缓冲区中的数据推送到着色器中还需涉及“着色器程序”,一个负责关联着色器和缓冲区的JavaScript对象。一个WebGLProgram 对象由两个编译过后的 WebGLShader 组成,即顶点着色器和片段着色器(均由 GLSL 语言所写)。
## 运作机制
**图1** WebGL运作机制
![zh-cn_image_0000001238544451](figures/zh-cn_image_0000001238544451.png)
- 应用前端HTML5绘制界面组件。
- Native API完成前端JavaScript与C++代码交互。
- QuickJS与V8为图形框架,为WebGL模块提供绘制对象Surface。
- WebGL模块对外暴露OpenGL ES的GPU绘制接口。
- 中间接口层EGL(Embedded Graphics Library)完成不同平台的适配。
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册