成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

HarmonyOS應用配置文件config.json

系統 OpenHarmony
 一個工程中的配置文件有兩種,一種是主模塊entry的配置文件config.json,另一種是應用程序環境的配置文件build.gradle。

[[417431]]

想了解更多內容,請訪問:

51CTO和華為官方合作共建的鴻蒙技術社區

https://harmonyos.51cto.com

一個工程中的配置文件有兩種,一種是主模塊entry的配置文件config.json,另一種是應用程序環境的配置文件build.gradle。其中config.json至少有2個,一個位于entry下,另一個位于應用根目錄下。每增加一個feature模塊,也會相應增加一個build.gradle文件。

1.config.json

DevEco Studio提供了兩種編輯“config.json”文件的方式。在“config.json”的編輯窗口中,可在右上角切換代碼編輯視圖或可視化編輯視圖(如下圖所示)。

HarmonyOS應用配置文件config.json-鴻蒙HarmonyOS技術社區

 “config.json”由“app”、“deviceConfig”和“module”三個部分組成,各部分含義如下表所示。

(1)app屬性對象的內部結構說明如下:

​ bundleName: 表示應用的包名,用于標識應用的唯一性。包名是由字母、數字、下劃線(_)和點號(.)組成的字符串,必須以字母開頭。支持的字符串長度為7~127字節。通常采用反域名形式表示。

​ vendor: 表示對應用開發廠商的描述。字符串長度不超過255字節。

​ version: 表示應用的版本信息。

​ apiVersion:(可不設置)表示應用依賴的HarmonyOS的API版本。compatible表示應用運行需要的API最小版本。取值為大于零的整數。(一旦添加了APIVersion屬性,則該子屬性不可缺省)。target表示應用運行需要的API目標版本。取值為大于零的整數。可缺省。releaseType表示應用運行需要的API目標版本的類型。取值為“CanaryN”(受限發布的版本)、“BetaN”(公開發布的Beta版本)或者“Release”(公開發布的正式版本),其中,N代表大于零的整數。

app屬性定義示例如下所示:

  1. "app": { 
  2.  
  3. ​    "bundleName""com.huawei.hiworld.example",  
  4.  
  5. ​    "vendor""huawei",  
  6.  
  7. ​    "version": { 
  8.  
  9. ​        "code": 2,  
  10.  
  11. ​        "name""2.0" 
  12.  
  13. ​    }, 
  14.  
  15. ​    "apiVersion": { 
  16.  
  17. ​        "compatible": 3,  
  18.  
  19. ​        "target": 3, 
  20.  
  21. ​        "releaseType""Beta1" 
  22.  
  23. ​    } 
  24.  

(2)deviceConfig屬性對象設置包含在具體設備上的應用配置信息,可以包含default、phone、tablet、tv、car、wearable、liteWearable和smartVision等屬性。default標簽內的配置是適用于所有設備通用,其他設備類型如果有特殊的需求,則需要在該設備類型的標簽下通過default(所有設備)、phone(手機)、tablet(平板)、tv(智慧屏)、car(車機)、wearable(智能穿戴設備)、liteWearable(輕量級智能穿戴設備)和smartVision(智能攝像頭)等子屬性對象進行配置。如果沒有對設備的特殊需求,可以設置該屬性對象為空,即"deviceConfig": {}。deviceConfig屬性對象的內部屬性結構說明如下:

default、phone、tablet、tv、car、wearable、liteWearable和smartVision等對象的內部結構說明如下所示:

其中network對象的內部屬性結構說明如下:

securityConfig對象的內部屬性結構說明如下:

deviceConfig屬性定義示例如下所示,該示例中主要對應用的進程名、是否支持備份、網絡安全進行配置。

  1. "deviceConfig": { 
  2.  
  3. ​    "default": { 
  4.  
  5. ​        "process""com.huawei.hiworld.example",  
  6.  
  7. ​        "supportBackup"false
  8.  
  9. ​        "network": { 
  10.  
  11. ​            "cleartextTraffic"true,  
  12.  
  13. ​            "securityConfig": { 
  14.  
  15. ​                "domainSettings": { 
  16.  
  17. ​                    "cleartextPermitted"true,  
  18.  
  19. ​                    "domains": [ 
  20.  
  21. ​                        { 
  22.  
  23. ​                            "subdomains"true,  
  24.  
  25. ​                            "name""example.ohos.com" 
  26.  
  27. ​                        } 
  28.  
  29. ​                    ] 
  30.  
  31. ​                } 
  32.  
  33. ​            } 
  34.  
  35. ​        } 
  36.  
  37. ​    } 
  38.  

(3)module屬性對象包含HAP包的配置信息,其常用子屬性對象及含義說明如下:

1)mainAbility: 表示HAP包的入口ability名稱。

2)package: 表示HAP的包結構名稱,在應用內應保證唯一性。反向域名格式。

 3)name: 表示HAP的類名。采用反向域名方式表示,前綴需要與同級的package標簽指定的包名一致,也可采用“.”開頭的命名方式。字符串長度不超過255字節。

4)description: 表示HAP的描述信息。字符串長度不超過255字節。如果字符串超出長度或者需要支持多語言,可以采用資源索引的方式添加描述內容。

5)supportedModes: 表示應用支持的運行模式。當前只定義了駕駛模式(drive)。該標簽僅適用于車機。

6)deviceType: 表示允許Ability運行的設備類型。系統預定義的設備類型包括:phone(手機)、tablet(平板)、tv(智慧屏)、car(車機)、wearable(智能穿戴)、liteWearable(輕量級智能穿戴)等。

7)distro: 表示HAP發布的具體描述。

deliveryWithInstall:表示當前HAP是否支持隨應用安裝。true:支持隨應用安裝。false:不支持隨應用安裝(可能導致最終應用上架應用市場異常)。

 moduleName: 表示當前HAP的名稱。

moduleType: 表示當前HAP的類型,包括兩種類型:entry和feature。

8)abilities: 表示當前模塊內的所有Ability的配置信息。采用對象數組格式,其中每個元素表示一個Ability對象。其內部子屬性說明如下:

name:表示Ability名稱。取值可采用反向域名方式表示,由包名和類名組成。

description:表示對Ability的描述。取值可以是描述性內容,也可以是對描述性內容的資源索引,以支持多語言。

icon:表示Ability圖標資源文件的索引。如果在該Ability的“skills”屬性中,“actions”的取值包含 “action.system.home”,“entities”取值中包含“entity.system.home”,則該Ability的icon將同時作為應用的icon。如果存在多個符合條件的Ability,則取位置靠前的Ability的icon作為應用的icon。

label:表示Ability對用戶顯示的名稱。取值可以是Ability名稱,也可以是對該名稱的資源索引,以支持多語言。如果在該Ability的“skills”屬性中,“actions”的取值包含 “action.system.home”,“entities”取值中包含“entity.system.home”,則該Ability的label將同時作為應用的label。如果存在多個符合條件的Ability,則取位置靠前的Ability的label作為應用的label。

uri:表示Ability的統一資源標識符。格式為:

HarmonyOS應用配置文件config.json-鴻蒙HarmonyOS技術社區

launchType:表示Ability的啟動模式,支持“standard”、“singleMission”和“singleton”三種模式:

standard:表示該Ability可以有多實例。“standard”模式適用于大多數應用場景。

singleMission:表示此Ability在每個任務棧中只能有一個實例。

singleton:表示該Ability在所有任務棧中僅可以有一個實例。例如,具有全局唯一性的呼叫來電界面即采用“singleton”模式。

shortcuts: (可缺省)表示應用的快捷方式信息。采用對象數組格式,其中的每個元素表示一個快捷方式對象。

visible:表示Ability是否可以被其他應用調用。

true:可以被其他應用調用。

false:不能被其他應用調用。

permissions:表示其他應用的Ability調用此Ability時需要申請的權限。通常采用反向域名格式,取值可以是系統預定義的權限,也可以是開發者自定義的權限。如果是自定義權限,取值必須與“defPermissions”標簽中定義的某個權限的“name”標簽值一致。

skills:表示Ability能夠接收的Intent的特征。

deviceCapability:表示Ability運行時要求設備具有的能力,采用字符串數組的格式表示。

metaData:表示Ability的元信息。

調用Ability時調用參數的元信息,例如:參數個數和類型。

Ability執行完畢返回值的元信息,例如:返回值個數和類型。

type:表示Ability的類型。取值范圍如下:

page:表示基于Page模板開發的FA,用于提供與用戶交互的能力。

service:表示基于Service模板開發的PA,用于提供后臺運行任務的能力。

data:表示基于Data模板開發的PA,用于對外部提供統一的數據訪問抽象。

CA:表示支持其他應用以窗口方式調起該Ability。

orientation:示該Ability的顯示模式。該標簽僅適用于page類型的Ability。取值范圍如下:

unspecified:由系統自動判斷顯示方向。

landscape:橫屏模式。

portrait:豎屏模式。

followRecent:跟隨棧中最近的應用。

backgroundModes:表示后臺服務的類型,可以為一個服務配置多個后臺服務類型。該標簽僅適用于service類型的Ability。取值范圍如下:

dataTransfer:通過網絡/對端設備進行數據下載、備份、分享、傳輸等業務。

audioPlayback:音頻輸出業務。

audioRecording:音頻輸入業務。

pictureInPicture:畫中畫、小窗口播放視頻業務。

voip:音視頻電話、VOIP業務。

location:定位、導航業務。

bluetoothInteraction:藍牙掃描、連接、傳輸業務。

wifiInteraction:WLAN掃描、連接、傳輸業務。

screenFetch:錄屏、截屏業務。

multiDeviceConnection:多設備互聯業務。

readPermission:表示讀取Ability的數據所需的權限。該標簽僅適用于data類型的Ability。取值為長度不超過255字節的字符串。

writePermission:表示向Ability寫數據所需的權限。該標簽僅適用于data類型的Ability。取值為長度不超過255字節的字符串。

mission:表示Ability指定的任務棧。該標簽僅適用于page類型的Ability。默認情況下應用中所有Ability同屬一個任務棧。

targetAbility:表示當前Ability重用的目標Ability。該標簽僅適用于page類型的Ability。如果配置了targetAbility屬性,則當前Ability(即別名Ability)的屬性中僅name、icon、label、visible、permissions、skills生效,其它屬性均沿用targetAbility中的屬性值。目標Ability必須與別名Ability在同一應用中,且在配置文件中目標Ability必須在別名之前進行聲明。

multiUserShared:表示Ability是否支持多用戶狀態進行共享,該標簽僅適用于data類型的Ability。配置為“true”時,表示在多用戶下只有一份存儲數據。需要注意的是,該屬性會使visible屬性失效。

supportPipMode:表示Ability是否支持用戶進入PIP模式(用于在頁面最上層懸浮小窗口,俗稱“畫中畫”,常見于視頻播放等場景)。該標簽僅適用于page類型的Ability。

formsEnabled:表示Ability是否支持卡片(forms)功能。該標簽僅適用于page類型的Ability。

true:支持卡片能力。

false:不支持卡片能力。

resizeable:表示Ability是否支持多窗口特性。

forms:表示服務卡片的屬性。該標簽僅當“formsEnabled”為“true”時,才能生效。該屬性有一系列子屬性詳細設置卡片的類型、主題樣式、外觀規格等;

9)js: (可缺省)表示基于JS UI框架開發的JS模塊集合,其中的每個元素代表一個JS模塊的信息。

10)reqPermissions: 表示應用運行時向系統申請的權限。

11)defPermissions: 表示應用定義的權限。應用調用者必須申請這些權限,才能正常調用該應用。

12)colorMode:表示應用自身的顏色模式。

dark:表示按照深色模式選取資源。

light:表示按照淺色模式選取資源。

auto:表示跟隨系統的顏色模式值選取資源。

module屬性對象定義示例如下所示:

  1. "module": { 
  2.  
  3. ​    "mainAbility""MainAbility"
  4.  
  5. ​    "package""com.example.myapplication.entry",  
  6.  
  7. ​    "name"".MyOHOSAbilityPackage",  
  8.  
  9. ​    "description""$string:description_application",  
  10.  
  11. ​    "supportedModes": [ 
  12.  
  13. ​        "drive" 
  14.  
  15. ​    ],  
  16.  
  17. ​    "deviceType": [ 
  18.  
  19. ​        "car" 
  20.  
  21. ​    ],  
  22.  
  23. ​    "distro": { 
  24.  
  25. ​        "deliveryWithInstall"true,  
  26.  
  27. ​        "moduleName""ohos_entry",  
  28.  
  29. ​        "moduleType""entry" 
  30.  
  31. ​    },  
  32.  
  33. ​    "abilities": [ 
  34.  
  35. ​        ... 
  36.  
  37. ​    ],  
  38.  
  39. ​    "shortcuts": [ 
  40.  
  41. ​        ... 
  42.  
  43. ​    ], 
  44.  
  45. ​    "js": [ 
  46.  
  47. ​        ... 
  48.  
  49. ​    ],  
  50.  
  51. ​    "reqPermissions": [ 
  52.  
  53. ​        ... 
  54.  
  55. ​    ],  
  56.  
  57. ​    "defPermissions": [ 
  58.  
  59. ​        ... 
  60.  
  61. ​    ], 
  62.  
  63. ​    "colorMode""light" 
  64.  

想了解更多內容,請訪問:

51CTO和華為官方合作共建的鴻蒙技術社區

https://harmonyos.51cto.com

 

責任編輯:jianghua 來源: 鴻蒙社區
相關推薦

2023-04-07 09:20:55

2015-06-17 14:18:50

ASP.NET

2021-07-13 05:47:40

GroovyJSON軟件開發

2009-07-29 14:23:08

ASP.NET配置文件

2010-02-24 14:10:54

WCF修改App.co

2024-04-25 12:35:14

JSONC#開發

2023-08-07 15:18:29

游戲開發鴻蒙Arkts

2011-04-19 14:35:58

ASP.NETWeb.config

2022-05-20 07:36:02

LiveTerm工具

2010-02-23 14:17:20

WCF配置文件

2010-03-18 18:17:01

Python 配置文件

2011-09-08 16:07:13

Widget配置文件

2009-09-14 09:17:43

.settings配置

2022-12-26 11:24:28

鴻蒙Stage模型

2022-01-11 17:23:12

配置Node.jsNode

2011-01-19 14:00:21

2011-01-13 16:27:26

Linux配置文件

2023-08-04 08:19:02

2010-12-28 16:35:32

Outlook 配置文

2009-06-23 18:19:32

單元測試Hibernate配置
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 中文字幕日韩在线 | 久久综合一区二区三区 | 看av在线 | 偷拍自拍网站 | 99re在线观看 | 一区二区三区免费 | 91激情视频 | 欧美一区二区三区在线观看 | 色呦呦在线 | 午夜精品久久久久久久99黑人 | 成人精品一区二区三区中文字幕 | 国产精品美女久久久久久免费 | 久久久综合网 | 日本免费一区二区三区视频 | 久久综合伊人 | 黄色精品| 日韩在线观看一区 | 久久99网 | 国产一区 | 中文字幕一二三区 | 亚洲视频一区二区 | 一区二区在线看 | 亚洲精品久久久久久久久久久久久 | 精品综合在线 | 亚洲人成人一区二区在线观看 | 在线播放一区二区三区 | 欧美8一10sex性hd | 国产精品久久久久久一区二区三区 | 日韩欧美三级电影在线观看 | 午夜精品久久久久久久久久久久久 | 91精品综合久久久久久五月天 | 成人精品在线视频 | 精品亚洲一区二区 | 国产精品久久国产精品久久 | 男女在线免费观看 | 久久免费大片 | 亚洲一区久久 | 不卡av电影在线播放 | 精品综合| 国产美女自拍视频 | 亚洲精品久久久蜜桃网站 |