您的位置:58脚本 > 鸿蒙编译环境 鸿蒙OS 编译构建前配置

鸿蒙编译环境 鸿蒙OS 编译构建前配置

2023-03-17 04:32 鸿蒙OS开发文档

鸿蒙编译环境 鸿蒙OS 编译构建前配置

鸿蒙编译环境

鸿蒙编译环境是一个开源的、可扩展的、可定制的编译环境,它可以帮助开发者快速构建出高性能、低功耗的应用。它是一个全新的软件开发平台,旨在提供一个全新的软件开发体验,使开发者能够快速构建出高性能、低功耗的应用。

鸿蒙编译环境采用了一套先进的工具链,包括LLVM、Clang、GCC、GDB等,这些工具都是业界最新最好的工具,能够帮助开发者快速构建出优化后的代码。此外,它还提供了一套定制化工具,使得开发者能够根据不同平台或不同应用场景来定制自己所需要的特性。

#include  
int main() 
{ 
    printf("Hello World!"); 
    return 0; 
} 

鸿蒙OS 编译构建前配置

在进行 HarmonyOS 应用的编译构建前,需要对工程和编译构建的 Module 进行设置,请根据实际情况进行修改。

  • build.gradle:HarmonyOS 应用依赖 gradle 进行构建,需要通过 build.gradle 来对工程编译构建参数进行设置。build.gradle 分为工程级和模块级两种类型,其中工程根目录下的工程级 build.gradle 用于工程的全局设置,各模块下的 build.gradle 只对本模块生效。
  • config.json:应用清单文件,用于描述应用的全局配置信息、在具体设备上的配置信息和HAP的配置信息。

工程级 build.gradle

  • apply plugin:在工程级 Gradle 中引入打包 app 的插件,不需要修改。

  apply plugin: "com.huawei.ohos.hap"

  • ohos 闭包:工程配置,包括如下配置项:

  • compileSdkVersion:依赖的 SDK 版本。

    compileSdkVersion 3    //应用编译构建的目标 SDK 版本
         defaultConfig {
             compatibleSdkVersion 3    //应用兼容的最低 SDK 版本
     }

  • signingConfigs:发布 APP 时的签名信息,在编译构建生成 APP中进行设置后自动生成。

  • buildscript 闭包:Gradle 脚本执行依赖,包括 Maven 仓地址和插件。

  buildscript {
      repositories {   
          maven {
              url "https://mirrors.huaweicloud.com/repository/maven/"
          }
          maven {
              url "https://developer.huawei.com/repo/"
          }      
          jcenter()
      }
         dependencies {
           classpath "com.huawei.ohos:hap:2.0.0.6"
      }
  }

  • allprojects 闭包:工程自身所需要的依赖,比如引用第三方库的Maven仓库和依赖包。

  allprojects {
      repositories {
         maven {
              url "https://mirrors.huaweicloud.com/repository/maven/"
         }
         maven {
              url "https://developer.huawei.com/repo/"
         }      
         jcenter()
      }
  }

模块级 build.gradle

  • apply plugin:在模块级 Gradle 中引入打包 hap 和 library 的插件,无需修改。

  apply plugin: "com.huawei.ohos.hap"   //打包hap包的插件
  apply plugin: "com.huawei.ohos.library"    //将HarmonyOS Library打包为har的插件
  apply plugin: "com.huawei.ohos.java-library"    //将Java Library打包为jar的插件

  • ohos闭包:模块配置,包括如下配置项:

  • compileSdkVersion:依赖的SDK版本。

    compileSdkVersion 3    //应用编译构建的目标 SDK 版本
         defaultConfig {
             compatibleSdkVersion 3    //应用兼容的最低SDK版本
     }

  • signingConfigs:在编译构建生成 HAP 中进行设置后自动生成。

  • externalNativeBuild:C/C++ 编译构建代码设置项。

    externalNativeBuild {
        path "src/main/cpp/CMakeLists.txt"   //CMake配置入口,提供CMake构建脚本的相对路径
        arguments "-v"    //传递给CMake的可选编译参数
        abiFilters "arm64-v8a"     //用于设置本机的ABI编译环境
        cppFlags ""   //设置C++编译器的可选参数

  • entryModules:该 Feature 模块关联的 Entry 模块。

    entryModules "entry"    

  • mergeJsSrc:跨设备的应用编译构建,是否需要合并 JS 代码。Wearable 和 Lite Wearable 共用一个工程,如下图所示。当进行编译构建时,将 Wearable/Lite Wearable 目录下的 JS 文件与 pages 目录(Wearable 和 Lite Wearable 共用的源码)下的 JS 文件进行合并打包。

 

点击放大

    mergejssrc true    //合并JS代码打包时,请在ohos闭包下手动添加,true表示需要合并JS代码,false表示不需要合并JS代码。

  • annotationEnabled:支持数据库注释。

    compileOptions{ 
             annotationEnabled true   //true表示支持,false表示不支持

  • dependencies闭包:该模块所需的依赖项。

  dependencies {
      entryImplementation project(":entry")    //该Feature模块依赖的Entry模块
      implementation fileTree(dir: "libs", include: ["*.jar","*.har"])    //该模块依赖的本地库,支持jar和har包
      testCompile"junit:junit:4.12"    //测试用例框架,无需修改
  }

config.json 清单文件

HarmonyOS 应用的每个模块下包含一个 config.json 清单文件,在编译构建前,需要对照检查和修改 config.json 文件,详情请参考 config.json 清单文件介绍

阅读全文
以上是58脚本为你收集整理的鸿蒙编译环境 鸿蒙OS 编译构建前配置全部内容。
声明:本站所有文章资源内容,如无特殊说明或标注,均为采集网络资源。如若本站内容侵犯了原著者的合法权益,可联系本站删除。
相关文章
© 2024 58脚本 58jiaoben.com 版权所有 联系我们
桂ICP备12005667号-28 Powered by CMS