From 1ef9d32f3a13611b4716c1ed18eaf3ab859ac018 Mon Sep 17 00:00:00 2001 From: shawn_he Date: Fri, 21 Oct 2022 09:55:31 +0800 Subject: [PATCH] update doc Signed-off-by: shawn_he --- .../dfx/hiappevent-guidelines.md | 27 ++-- .../reference/apis/js-apis-call.md | 2 +- .../reference/apis/js-apis-contact.md | 12 +- .../reference/apis/js-apis-radio.md | 21 +++ .../reference/apis/js-apis-sim.md | 6 - .../reference/apis/js-apis-telephony-data.md | 23 +++ .../reference/apis/js-apis-update.md | 144 +++++++++--------- en/device-dev/get-code/gettools-acquire.md | 55 +++---- zh-cn/readme/figures/build_framework_ZN.png | Bin 16551 -> 0 bytes 9 files changed, 168 insertions(+), 122 deletions(-) delete mode 100644 zh-cn/readme/figures/build_framework_ZN.png diff --git a/en/application-dev/dfx/hiappevent-guidelines.md b/en/application-dev/dfx/hiappevent-guidelines.md index 48f725e080..afda67ee6f 100644 --- a/en/application-dev/dfx/hiappevent-guidelines.md +++ b/en/application-dev/dfx/hiappevent-guidelines.md @@ -12,12 +12,10 @@ The following table provides only a brief description of related APIs. For detai **Table 1** APIs for application event logging -| API | Description | -| ------------------------------------------------------------ | ------------------------------------------------------------ | -| write(string eventName, EventType type, object keyValues, AsyncCallback\ callback): void | Logs application events in asynchronous mode. This API uses an asynchronous callback to return the result. | -| write(string eventName, EventType type, object keyValues): Promise\ | Logs application events in asynchronous mode. This API uses a promise to return the result. | -| write(AppEventInfo info, AsyncCallback\ callback): void | Logs application events by domain in asynchronous mode. This API uses an asynchronous callback to return the result.| -| write(AppEventInfo info): Promise\ | Logs application events by domain in asynchronous mode. This API uses a promise to return the result.| +| API | Description | +| ------------------------------------------------------------ | ---------------------------------------------------- | +| write(AppEventInfo info, AsyncCallback\ callback): void | Logs application events in asynchronous mode. This API uses an asynchronous callback to return the result.| +| write(AppEventInfo info): Promise\ | Logs application events in asynchronous mode. This API uses a promise to return the result. | When an asynchronous callback is used, the return value can be processed directly in the callback. @@ -84,6 +82,7 @@ The following uses a one-time event watcher as an example to illustrate the deve .fontWeight(FontWeight.Bold) Button("1 writeTest").onClick(()=>{ + // Perform event logging based on the input event parameters. hiAppEvent.write({ domain: "test_domain", name: "test_event", @@ -100,6 +99,7 @@ The following uses a one-time event watcher as an example to illustrate the deve }) Button("2 addWatcherTest").onClick(()=>{ + // Add an event watcher based on the input subscription parameters. hiAppEvent.addWatcher({ name: "watcher1", appEventFilters: [{ domain: "test_domain" }], @@ -109,17 +109,23 @@ The following uses a one-time event watcher as an example to illustrate the deve timeOut: 2 }, onTrigger: function (curRow, curSize, holder) { + // If the holder object is null, return an error after recording it in the log. if (holder == null) { console.error("HiAppEvent holder is null"); return; } + // Set the size threshold to 1,000 bytes for obtaining an event package. + holder.setSize(1000); let eventPkg = null; + // Obtain the event package based on the configured size threshold. If returned event package is null, all event data has been obtained. while ((eventPkg = holder.takeNext()) != null) { - console.info("HiAppEvent eventPkg.packageId=" + eventPkg.packageId); - console.info("HiAppEvent eventPkg.row=" + eventPkg.row); - console.info("HiAppEvent eventPkg.size=" + eventPkg.size); + // Parse the obtained event package and display the result on the Log page. + console.info('HiAppEvent eventPkg.packageId=' + eventPkg.packageId); + console.info('HiAppEvent eventPkg.row=' + eventPkg.row); + console.info('HiAppEvent eventPkg.size=' + eventPkg.size); + // Traverse and parse event string arrays in the obtained event package. for (const eventInfo of eventPkg.data) { - console.info("HiAppEvent eventPkg.data=" + eventInfo); + console.info('HiAppEvent eventPkg.data=' + eventInfo); } } } @@ -127,6 +133,7 @@ The following uses a one-time event watcher as an example to illustrate the deve }) Button("3 removeWatcherTest").onClick(()=>{ + // Remove the specified event watcher. hiAppEvent.removeWatcher({ name: "watcher1" }) diff --git a/en/application-dev/reference/apis/js-apis-call.md b/en/application-dev/reference/apis/js-apis-call.md index 5ea820e616..ab561f5527 100644 --- a/en/application-dev/reference/apis/js-apis-call.md +++ b/en/application-dev/reference/apis/js-apis-call.md @@ -827,7 +827,7 @@ call.reject(1, (error, data) => { ## call.reject7+ -reject\(callId: number, options: RejectMessageOption, callback: AsyncCallback\): void +reject\(callId: number, options: RejectMessageOptions, callback: AsyncCallback\): void Rejects a call based on the specified call ID and options. This API uses an asynchronous callback to return the result. diff --git a/en/application-dev/reference/apis/js-apis-contact.md b/en/application-dev/reference/apis/js-apis-contact.md index 67b846c17b..a166781108 100644 --- a/en/application-dev/reference/apis/js-apis-contact.md +++ b/en/application-dev/reference/apis/js-apis-contact.md @@ -202,8 +202,8 @@ Updates a contact based on the specified contact information and attributes. Thi contact.updateContact({ name: {fullName: 'xxx'}, phoneNumbers: [{phoneNumber: '138xxxxxxxx'}] - },{ - attributes:[contact.Attribute.ATTR_EMAIL, contact.Attribute.ATTR_NAME] + }, { + attributes: [contact.Attribute.ATTR_EMAIL, contact.Attribute.ATTR_NAME] }, (err) => { if (err) { console.log('updateContact callback: err->${JSON.stringify(err)}'); @@ -432,7 +432,7 @@ Queries my card based on the specified contact attributes. This API uses an asyn ```js contact.queryMyCard({ - attributes:['ATTR_EMAIL', 'ATTR_NAME'] + attributes: [contact.Attribute.ATTR_EMAIL, contact.Attribute.ATTR_NAME] }, (err, data) => { if (err) { console.log(`queryMyCard callback: err->${JSON.stringify(err)}`); @@ -469,7 +469,7 @@ Queries my card based on the specified contact attributes. This API uses a promi ```js let promise = contact.queryMyCard({ - attributes:['ATTR_EMAIL', 'ATTR_NAME'] + attributes: [contact.Attribute.ATTR_EMAIL, contact.Attribute.ATTR_NAME] }); promise.then((data) => { console.log(`queryMyCard success: data->${JSON.stringify(data)}`); @@ -487,7 +487,7 @@ Selects a contact. This API uses an asynchronous callback to return the result. **Permission required**: ohos.permission.READ_CONTACTS -**System capability**: SystemCapability.Applications.ContactsData +**System capability**: SystemCapability.Applications.Contacts **Parameters** @@ -516,7 +516,7 @@ Selects a contact. This API uses a promise to return the result. **Permission required**: ohos.permission.READ_CONTACTS -**System capability**: SystemCapability.Applications.ContactsData +**System capability**: SystemCapability.Applications.Contacts **Return Value** diff --git a/en/application-dev/reference/apis/js-apis-radio.md b/en/application-dev/reference/apis/js-apis-radio.md index 26d35ffeca..ec920f58ca 100644 --- a/en/application-dev/reference/apis/js-apis-radio.md +++ b/en/application-dev/reference/apis/js-apis-radio.md @@ -384,6 +384,27 @@ promise.then(data => { }); ``` +## radio.isNrSupported7+ + +isNrSupported\(\): boolean + +Checks whether the current device supports 5G \(NR\). + +**System capability**: SystemCapability.Telephony.CoreService + +**Return value** + +| Type | Description | +| ------- | -------------------------------- | +| boolean | - **true**: The current device supports 5G \(NR\).
- **false**: The current device does not support 5G \(NR\).| + +**Example** + +```js +let result = radio.isNrSupported(); +console.log("Result: "+ result); +``` + ## radio.isNrSupported8+ diff --git a/en/application-dev/reference/apis/js-apis-sim.md b/en/application-dev/reference/apis/js-apis-sim.md index ae9a1ece9c..6622b4b719 100644 --- a/en/application-dev/reference/apis/js-apis-sim.md +++ b/en/application-dev/reference/apis/js-apis-sim.md @@ -2683,8 +2683,6 @@ getOpKey(slotId: number): Promise Obtains the opkey of the SIM card in the specified slot. This API uses a promise to return the result. -**System API**: This is a system API. - **System capability**: SystemCapability.Telephony.CoreService **Parameters** @@ -2716,8 +2714,6 @@ getOpName(slotId: number, callback: AsyncCallback): void Obtains the OpName of the SIM card in the specified slot. This API uses an asynchronous callback to return the result. -**System API**: This is a system API. - **System capability**: SystemCapability.Telephony.CoreService **Parameters** @@ -2742,8 +2738,6 @@ getOpName(slotId: number): Promise Obtains the OpName of the SIM card in the specified slot. This API uses a promise to return the result. -**System API**: This is a system API. - **System capability**: SystemCapability.Telephony.CoreService **Parameters** diff --git a/en/application-dev/reference/apis/js-apis-telephony-data.md b/en/application-dev/reference/apis/js-apis-telephony-data.md index 7d8018a4e8..f3a29a9cc6 100644 --- a/en/application-dev/reference/apis/js-apis-telephony-data.md +++ b/en/application-dev/reference/apis/js-apis-telephony-data.md @@ -63,6 +63,29 @@ promise.then((data) => { }); ``` +## data.getDefaultCellularDataSlotIdSync + +getDefaultCellularDataSlotIdSync(): number + +Obtains the default SIM card used for mobile data synchronously. + +**Required permission**: ohos.permission.GET_NETWORK_INFO + +**System capability**: SystemCapability.Telephony.CellularData + +**Return value** + +| Type | Description | +| ------ | -------------------------------------------------- | +| number | Card slot ID.
**0**: card slot 1
**1**: card slot 2| + +**Example** + +```js +console.log("Result: "+ data.getDefaultCellularDataSlotIdSync()) +``` + + ## data.setDefaultCellularDataSlotId setDefaultCellularDataSlotId(slotId: number,callback: AsyncCallback\): void diff --git a/en/application-dev/reference/apis/js-apis-update.md b/en/application-dev/reference/apis/js-apis-update.md index 91013f9724..bcbac54140 100644 --- a/en/application-dev/reference/apis/js-apis-update.md +++ b/en/application-dev/reference/apis/js-apis-update.md @@ -43,13 +43,13 @@ Obtains an **OnlineUpdater** object. ```ts try { - var upgradeInfo = { + const upgradeInfo = { upgradeApp: "com.ohos.ota.updateclient", businessType: { vendor: update.BusinessVendor.PUBLIC, subType: update.BusinessSubType.FIRMWARE } - } + }; let updater = update.getOnlineUpdater(upgradeInfo); } catch(error) { console.error(`Fail to get updater error: ${error}`); @@ -233,15 +233,15 @@ Obtains the description file of the new version. This API uses an asynchronous c ```ts // Version digest information -var versionDigestInfo = { +const versionDigestInfo = { versionDigest: "versionDigest" // Version digest information in the check result -} +}; // Options of the description file -var descriptionOptions = { +const descriptionOptions = { format: update.DescriptionFormat.STANDARD, // Standard format language: "zh-cn" // Chinese -} +}; updater.getNewVersionDescription(versionDigestInfo, descriptionOptions, (err, info) => { console.log(`getNewVersionDescription info ${JSON.stringify(info)}`); @@ -276,15 +276,15 @@ Obtains the description file of the new version. This API uses a promise to retu ```ts // Version digest information -var versionDigestInfo = { +const versionDigestInfo = { versionDigest: "versionDigest" // Version digest information in the check result -} +}; // Options of the description file -var descriptionOptions = { +const descriptionOptions = { format: update.DescriptionFormat.STANDARD, // Standard format language: "zh-cn" // Chinese -} +}; updater.getNewVersionDescription(versionDigestInfo, descriptionOptions).then(info => { console.log(`getNewVersionDescription promise info ${JSON.stringify(info)}`); @@ -368,10 +368,10 @@ Obtains the description file of the current version. This API uses an asynchrono ```ts // Options of the description file -var descriptionOptions = { +const descriptionOptions = { format: update.DescriptionFormat.STANDARD, // Standard format language: "zh-cn" // Chinese -} +}; updater.getCurrentVersionDescription(descriptionOptions, (err, info) => { console.log(`getCurrentVersionDescription info ${JSON.stringify(info)}`); @@ -405,10 +405,10 @@ Obtains the description file of the current version. This API uses a promise to ```ts // Options of the description file -var descriptionOptions = { +const descriptionOptions = { format: update.DescriptionFormat.STANDARD, // Standard format language: "zh-cn" // Chinese -} +}; updater.getCurrentVersionDescription(descriptionOptions).then(info => { console.log(`getCurrentVersionDescription promise info ${JSON.stringify(info)}`); @@ -489,15 +489,15 @@ Downloads the new version. This API uses an asynchronous callback to return the ```ts // Version digest information -var versionDigestInfo = { +const versionDigestInfo = { versionDigest: "versionDigest" // Version digest information in the check result -} +}; // Download options -var downloadOptions = { +const downloadOptions = { allowNetwork: update.NetType.CELLULAR, // Whether to allow download over data network order: update.Order.DOWNLOAD // Download -} +}; updater.download(versionDigestInfo, downloadOptions, (err) => { console.log(`download error ${JSON.stringify(err)}`); }); @@ -530,15 +530,15 @@ Downloads the new version. This API uses a promise to return the result. ```ts // Version digest information -var versionDigestInfo = { +const versionDigestInfo = { versionDigest: "versionDigest" // Version digest information in the check result -} +}; // Download options -var downloadOptions = { +const downloadOptions = { allowNetwork: update.NetType.CELLULAR, // Whether to allow download over data network order: update.Order.DOWNLOAD // Download -} +}; updater.download(versionDigestInfo, downloadOptions).then(() => { console.log(`download start`); }).catch(err => { @@ -568,14 +568,14 @@ Resumes download of the new version. This API uses an asynchronous callback to r ```ts // Version digest information -var versionDigestInfo = { +const versionDigestInfo = { versionDigest: "versionDigest" // Version digest information in the check result -} +}; // Options for resuming download -var resumeDownloadOptions = { +const resumeDownloadOptions = { allowNetwork: update.NetType.CELLULAR, // Whether to allow download over data network -} +}; updater.resumeDownload(versionDigestInfo, resumeDownloadOptions, (err) => { console.log(`resumeDownload error ${JSON.stringify(err)}`); }); @@ -608,14 +608,14 @@ Resumes download of the new version. This API uses a promise to return the resul ```ts // Version digest information -var versionDigestInfo = { +const versionDigestInfo = { versionDigest: "versionDigest" // Version digest information in the check result -} +}; // Options for resuming download -var resumeDownloadOptions = { +const resumeDownloadOptions = { allowNetwork: update.NetType.CELLULAR, // Whether to allow download over data network -} +}; updater.resumeDownload(versionDigestInfo, resumeDownloadOptions).then(value => { console.log(`resumeDownload start`); }).catch(err => { @@ -645,14 +645,14 @@ Pauses download of the new version. This API uses an asynchronous callback to re ```ts // Version digest information -var versionDigestInfo = { +const versionDigestInfo = { versionDigest: "versionDigest" // Version digest information in the check result -} +}; // Options for pausing download -var pauseDownloadOptions = { +const pauseDownloadOptions = { isAllowAutoResume: true // Whether to allow automatic resuming of download -} +}; updater.pauseDownload(versionDigestInfo, pauseDownloadOptions, (err) => { console.log(`pauseDownload error ${JSON.stringify(err)}`); }); @@ -685,14 +685,14 @@ Resumes download of the new version. This API uses a promise to return the resul ```ts // Version digest information -var versionDigestInfo = { +const versionDigestInfo = { versionDigest: "versionDigest" // Version digest information in the check result -} +}; // Options for pausing download -var pauseDownloadOptions = { +const pauseDownloadOptions = { isAllowAutoResume: true // Whether to allow automatic resuming of download -} +}; updater.pauseDownload(versionDigestInfo, pauseDownloadOptions).then(value => { console.log(`pauseDownload`); }).catch(err => { @@ -722,14 +722,14 @@ Updates the version. This API uses an asynchronous callback to return the result ```ts // Version digest information -var versionDigestInfo = { +const versionDigestInfo = { versionDigest: "versionDigest" // Version digest information in the check result -} +}; // Installation options -var upgradeOptions = { +const upgradeOptions = { order: update.Order.INSTALL // Installation command -} +}; updater.upgrade(versionDigestInfo, upgradeOptions, (err) => { console.log(`upgrade error ${JSON.stringify(err)}`); }); @@ -762,14 +762,14 @@ Updates the version. This API uses a promise to return the result. ```ts // Version digest information -var versionDigestInfo = { +const versionDigestInfo = { versionDigest: "versionDigest" // Version digest information in the check result -} +}; // Installation options -var upgradeOptions = { +const upgradeOptions = { order: update.Order.INSTALL // Installation command -} +}; updater.upgrade(versionDigestInfo, upgradeOptions).then(() => { console.log(`upgrade start`); }).catch(err => { @@ -799,14 +799,14 @@ Clears errors. This API uses an asynchronous callback to return the result. ```ts // Version digest information -var versionDigestInfo = { +const versionDigestInfo = { versionDigest: "versionDigest" // Version digest information in the check result -} +}; // Options for clearing errors -var clearOptions = { +const clearOptions = { status: update.UpgradeStatus.UPGRADE_FAIL, -} +}; updater.clearError(versionDigestInfo, clearOptions, (err) => { console.log(`clearError error ${JSON.stringify(err)}`); }); @@ -839,14 +839,14 @@ Clears errors. This API uses a promise to return the result. ```ts // Version digest information -var versionDigestInfo = { +const versionDigestInfo = { versionDigest: "versionDigest" // Version digest information in the check result -} +}; // Options for clearing errors -var clearOptions = { +lconstet clearOptions = { status: update.UpgradeStatus.UPGRADE_FAIL, -} +}; updater.clearError(versionDigestInfo, clearOptions).then(() => { console.log(`clearError success`); }).catch(err => { @@ -926,7 +926,7 @@ Sets the update policy. This API uses an asynchronous callback to return the res **Example** ```ts -let policy = { +const policy = { downloadStrategy: false, autoUpgradeStrategy: false, autoUpgradePeriods: [ { start: 120, end: 240 } ] // Automatic update period, in minutes @@ -961,7 +961,7 @@ Sets the update policy. This API uses a promise to return the result. **Example** ```ts -let policy = { +const policy = { downloadStrategy: false, autoUpgradeStrategy: false, autoUpgradePeriods: [ { start: 120, end: 240 } ] // Automatic update period, in minutes @@ -1041,10 +1041,10 @@ Enables listening for update events. This API uses an asynchronous callback to r **Example** ```ts -var eventClassifyInfo = { +const eventClassifyInfo = { eventClassify: update.EventClassify.TASK, // Listening for update events extraInfo: "" -} +}; updater.on(eventClassifyInfo, (eventInfo) => { console.log("updater on " + JSON.stringify(eventInfo)); @@ -1068,10 +1068,10 @@ Disables listening for update events. This API uses an asynchronous callback to **Example** ```ts -var eventClassifyInfo = { +const eventClassifyInfo = { eventClassify: update.EventClassify.TASK, // Listening for update events extraInfo: "" -} +}; updater.off(eventClassifyInfo, (eventInfo) => { console.log("updater off " + JSON.stringify(eventInfo)); @@ -1153,10 +1153,10 @@ Verifies the update package. This API uses an asynchronous callback to return th **Example** ```ts -var upgradeFile = { +const upgradeFile = { fileType: update.ComponentType.OTA, // OTA package filePath: "path" // Path of the local update package -} +}; localUpdater.verifyUpgradePackage(upgradeFile, "cerstFilePath", (err) => { console.log(`factoryReset error ${JSON.stringify(err)}`); @@ -1189,10 +1189,10 @@ Verifies the update package. This API uses a promise to return the result. **Example** ```ts -var upgradeFile = { +const upgradeFile = { fileType: update.ComponentType.OTA, // OTA package filePath: "path" // Path of the local update package -} +}; localUpdater.verifyUpgradePackage(upgradeFile, "cerstFilePath").then(() => { console.log(`verifyUpgradePackage success`); }).catch(err => { @@ -1219,10 +1219,10 @@ Installs the update package. This API uses an asynchronous callback to return th **Example** ```ts -var upgradeFiles = [{ +const upgradeFiles = [{ fileType: update.ComponentType.OTA, // OTA package filePath: "path" // Path of the local update package -}] +}]; localUpdater.applyNewVersion(upgradeFiles, (err) => { console.log(`applyNewVersion error ${JSON.stringify(err)}`); @@ -1248,10 +1248,10 @@ Installs the update package. This API uses a promise to return the result. **Example** ```ts -var upgradeFiles = [{ +localUpdater upgradeFiles = [{ fileType: update.ComponentType.OTA, // OTA package filePath: "path" // Path of the local update package -}] +}]; localUpdater.applyNewVersion(upgradeFiles).then(() => { console.log(`applyNewVersion success`); }).catch(err => { @@ -1276,10 +1276,10 @@ Enables listening for update events. This API uses an asynchronous callback to r **Example** ```ts -var eventClassifyInfo = { +const eventClassifyInfo = { eventClassify: update.EventClassify.TASK, // Listening for update events extraInfo: "" -} +}; function onTaskUpdate(eventInfo) { console.log(`on eventInfo id `, eventInfo.eventId); @@ -1305,10 +1305,10 @@ Disables listening for update events. This API uses an asynchronous callback to **Example** ```ts -var eventClassifyInfo = { +const eventClassifyInfo = { eventClassify: update.EventClassify.TASK, // Listening for update events extraInfo: "" -} +}; function onTaskUpdate(eventInfo) { console.log(`on eventInfo id `, eventInfo.eventId); diff --git a/en/device-dev/get-code/gettools-acquire.md b/en/device-dev/get-code/gettools-acquire.md index 3e62d40ed0..a3025ebd83 100644 --- a/en/device-dev/get-code/gettools-acquire.md +++ b/en/device-dev/get-code/gettools-acquire.md @@ -7,7 +7,7 @@ OpenHarmony provides the following two types of Docker environments for you to q - Standalone Docker environment: applicable when using Ubuntu or Windows to build a distribution - HPM-based Docker environment: applicable when using the HarmonyOS Package Manager \(HPM\) to build a distribution -**Table 1** Docker image +**Table 1** Docker image

Docker Environment

@@ -67,11 +67,12 @@ OpenHarmony provides the following two types of Docker environments for you to q Before using the Docker environment, perform the following operations: -1. Install Docker. For details, see [Install Docker Engine](https://docs.docker.com/engine/install/). -2. Obtain the OpenHarmony source code. For details, see [Source Code Acquisition](sourcecode-acquire.md). +1. Install Docker. For details, see [Install Docker Engine](https://docs.docker.com/engine/install/). +2. Obtain the OpenHarmony source code. For details, see [Source Code Acquisition](sourcecode-acquire.md). - >![](../public_sys-resources/icon-note.gif) **NOTE**
- >You do not need to obtain the source code for the HPM-based Docker environment. + > **NOTE** + > + > You do not need to obtain the source code for the HPM-based Docker environment. ## Standalone Docker Environment @@ -94,7 +95,7 @@ The Docker image of OpenHarmony is hosted on HUAWEI CLOUD SWR. Using the Docker docker run -it -v $(pwd):/home/openharmony swr.cn-south-1.myhuaweicloud.com/openharmony-docker/openharmony-docker:1.0.0 ``` - Run the following command in Windows \(assuming that the source code directory is **D:\\OpenHarmony**\): + Run the following command in Windows \(assuming that the source code directory is **D:\\OpenHarmony**\): ``` docker run -it -v D:\OpenHarmony:/home/openharmony swr.cn-south-1.myhuaweicloud.com/openharmony-docker/openharmony-docker:1.0.0 @@ -111,17 +112,17 @@ Set the build path to the current path. hb set ``` -**Figure 1** Setting page +**Figure 1** Setting page ![](figure/setting-page.png "setting-page") ->![](../public_sys-resources/icon-note.gif) **NOTE**
->The mapping between the development board and the building GUI: +> **NOTE**
+> The mapping between the development board and the building GUI: > ->- Hi3861: wifiiot\_hispark\_pegasus@hisilicon ->- Hi3516: ipcamera\_hispark\_taurus@hisilicon ->- Hi3518: ipcamera\_hispark\_aries@hisilicon +> - Hi3861: wifiiot\_hispark\_pegasus@hisilicon +> - Hi3516: ipcamera\_hispark\_taurus@hisilicon +> - Hi3518: ipcamera\_hispark\_aries@hisilicon -1. Select **ipcamera\_hispark\_taurus@hisilicon** and press **Enter**. +1. Select **ipcamera\_hispark\_taurus@hisilicon** and press **Enter**. 2. Start building. ``` @@ -130,7 +131,7 @@ hb set 3. View the build result. - The files will be generated in the **out/hispark\_taurus/ipcamera\_hispark\_taurus** directory. + The files will be generated in the **out/hispark\_taurus/ipcamera\_hispark\_taurus** directory. ### Setting Up the Docker Environment for Standard-System Devices \(reference memory ≥ 128 MB\) @@ -156,17 +157,17 @@ Run the following script to start building for standard-system devices \(referen ./build.sh --product-name {product_name} --ccache ``` -**product\_name** indicates the platform supported by the current distribution, for example, hispark_taurus_standard and rk3568. +**product\_name** indicates the platform supported by the current distribution, for example, hispark_taurus_standard and rk3568. -Files generated during building are stored in the **out/{device_name}/** directory, and the generated image is stored in the **out/{device_name}/packages/phone/images/** directory. +Files generated during building are stored in the **out/{device_name}/** directory, and the generated image is stored in the **out/{device_name}/packages/phone/images/** directory. >![](../public_sys-resources/icon-note.gif) **NOTE**
->You can exit Docker by simply running the **exit** command. +>You can exit Docker by simply running the **exit** command. ## HPM-based Docker Environment -**docker\_dist** is a template component in the [HPM](https://hpm.harmonyos.com/#/en/home) system. It helps to quickly initialize an HPM project and use the Docker image to quickly build a distribution of OpenHarmony, greatly simplifying environment configurations needed for building. After configuring the Ubuntu and hpm-cli development environments, perform the following steps to access the Docker environment: +**docker\_dist** is a template component in the [HPM](https://hpm.harmonyos.com/#/en/home) system. It helps to quickly initialize an HPM project and use the Docker image to quickly build a distribution of OpenHarmony, greatly simplifying environment configurations needed for building. After configuring the Ubuntu and hpm-cli development environments, perform the following steps to access the Docker environment: ### Setting Up the Docker Environment @@ -176,20 +177,20 @@ Files generated during building are stored in the **out/{device_name}/** direc hpm init -t @ohos/docker_dist ``` -2. Modify the **publishAs** field. +2. Modify the **publishAs** field. - The obtained bundle is of the template type. Open the **bundle.json** file in the current directory and change the value of **publishAs** from **template** to **distribution** as needed. + The obtained bundle is of the template type. Open the **bundle.json** file in the current directory and change the value of **publishAs** from **template** to **distribution** as needed. ### Obtaining and Building Source Code Start building. Docker can be automatically installed only in Ubuntu. If you are using any other operating system, manually install Docker before pulling the image. -- **Automatically Installing Docker \(Ubuntu\)** +- **Automatically Installing Docker \(Ubuntu\)** Running the following command will automatically install Docker, pull the Docker image, and start the pulling and building of the corresponding solution in the container. - **Method 1:** + **Method 1:** Add a parameter to specify the solution. For example: @@ -197,9 +198,9 @@ Start building. Docker can be automatically installed only in Ubuntu. If you are hpm run docker solution={product} ``` - **\{product\}** indicates the solution, for example, **@ohos/hispark\_taurus**, **@ohos/hispark\_aries**, and **@ohos/hispark\_pegasus**. + **\{product\}** indicates the solution, for example, **@ohos/hispark\_taurus**, **@ohos/hispark\_aries**, and **@ohos/hispark\_pegasus**. - **Method 2:** + **Method 2:** Set an environment variable to specify the solution, and then run the build command. @@ -209,7 +210,7 @@ Start building. Docker can be automatically installed only in Ubuntu. If you are export solution={product} ``` - **\{product\}** indicates the solution, for example, **@ohos/hispark\_taurus**, **@ohos/hispark\_aries**, and **@ohos/hispark\_pegasus**. + **\{product\}** indicates the solution, for example, **@ohos/hispark\_taurus**, **@ohos/hispark\_aries**, and **@ohos/hispark\_pegasus**. 2. Obtain and build the source code. @@ -217,7 +218,7 @@ Start building. Docker can be automatically installed only in Ubuntu. If you are hpm run docker ``` - This example uses the **@ohos/hispark\_taurus** solution for illustration. If the execution is successful, the output is as follows: + This example uses the **@ohos/hispark\_taurus** solution for illustration. If the execution is successful, the output is as follows: ``` ... @@ -226,7 +227,7 @@ Start building. Docker can be automatically installed only in Ubuntu. If you are ``` -- **Manually Installing Docker \(Non-Ubuntu\)** +- **Manually Installing Docker \(Non-Ubuntu\)** Perform the following operations to install Docker: diff --git a/zh-cn/readme/figures/build_framework_ZN.png b/zh-cn/readme/figures/build_framework_ZN.png deleted file mode 100644 index 03f4d6f6cffc9d3552f86f197230d01a50e2860e..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 16551 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