Android 笔记:AndroidTrain , Lint , build(1),只需一篇文章吃透Android多线程技术

简介: Android 笔记:AndroidTrain , Lint , build(1),只需一篇文章吃透Android多线程技术
// Set a slide in animation by getting an Animation from the Resources object
mFlipper.setInAnimation(AnimationUtils.loadAnimation(this,
R.anim.hyperspace_in));

引用样式属性

您可以通过样式属性资源在当前应用的风格主题中引用某个属性的值。 通过引用样式属性,您可以不采用为 UI 元素提供硬编码值这种方式,而是通过为 UI 元素设置样式,使其匹配当前风格主题提供的标准变型来定制这些元素的外观。引用样式属性的实质作用是,“在当前风格主题中使用此属性定义的样式”。

要引用样式属性,名称语法几乎与普通资源格式完全相同,只不过将 at 符号 (@) 改为问号 (?),资源类型部分为可选项。 例如:

?[<package_name>:][<resource_type>/]<resource_name>

例如,您可以通过以下代码引用一个属性,将文本颜色设置为与系统风格主题的“主要”文本颜色匹配:

<EditText id=“text”
android:layout_width=“fill_parent”
android:layout_height=“wrap_content”
android:textColor=“?android:textColorSecondary”
android:text=“@string/hello_world” />

在以上代码中,android:textColor 属性表示当前风格主题中某个样式属性的名称。Android 现在会使用应用于 android:textColorSecondary 样式属性的值作为 android:textColor 在这个小工具中的值。由于系统资源工具知道此环境中肯定存在某个属性资源,因此您无需显式声明类型(类型应为 ?android:attr/textColorSecondary)— 您可以将 attr 类型排除在外。

使用Lint排除潜在的问题


Lint是Google专门为Android推出的代码检查工具,可以在编译期发现APP中潜在的问题。

菜单栏中Analyze -> Inspect Code 开始检查代码,项目越大耗时越长。

检查完成会自动打开Inspection窗口并显示结果,如下图所示:

我们重点来看一下Android Lint:

build.gradle文件


build.gradle文件结构

AS中APP所有的配置尽在一个build.gradle文件中,打包的时候也是解析build.gralde文件来打包的。结构如下所示:

  1. apply plugin 用来指定用的是哪个插件
  • com.android.application:Android APP插件(打包得到的是.apk文件)
  • com.android.library:Android库插件(打包得到的是.aar文件)
  1. android 用来指定Android打包插件的相关属性
  • compileSdkVersion(apiLevel):设置编译时用的Android版本
  • buildToolsVersion(buildToolsVersionName):设置编译时使用的构建工具的版本
  • defaultConfig:设置一些默认属性,其可用属性是 buildTypesProductFlavors 之和
  • sourceSets:配置相关源文件的位置,当你的项目的目录结构跟默认的有区别但又不想改的时候sourceSets就派上用场了
  • aidl 设置aidi的目录
  • assets 设置assets资源目录
  • compileConfigurationName The name of the compile configuration for this source set.
  • java Java 源代码目录
  • jni JNI代码目录
  • jniLibs 已编译好的JNI库目录
  • manifest 指定清单文件
  • name The name of this source set.
  • packageConfigurationName The name of the runtime configuration for this source set.
  • providedConfigurationName The name of the compiled-only configuration for this source set.
  • renderscript Renderscript源代码目录
  • res 资源目录
  • setRoot(path) 根目录
  • signingConfigs:配置签名信息
  • keyAlias 签名的别名
  • keyPassword 密码
  • storeFile 签名文件的路径
  • storePassword 签名密码
  • storeType 类型
  • buildTypes:配置构建类型,可打出不同类型的包。默认有 debugrelease 两种,你还可以在增加N种。
  • applicationIdSuffix 用于修改 applicationId,在默认 applicationId 的基础上加后缀。在 buildType 中修改 applicationId 时只能加后缀,不能完全修改。
  • debuggable 设置是否生成debug版的APK
  • jniDebuggable 设置生成的APK是否支持调试本地代码
  • minifyEnabled 设置是否执行混淆
  • multiDexEnabled Whether Multi-Dex is enabled for this variant.
  • renderscriptDebuggable 设置生成的APK是否支持调试RenderScript代码
  • renderscriptOptimLevel 设置RenderScript优化级别
  • signingConfig 设置签名信息
  • versionNameSuffix 修改版本名称,在默认版本名称的基础上加后缀。在buildType中修改版本名称时只能加后缀,不能完全修改
  • zipAlignEnabled 设置是否对APK包执行ZIP对齐优化
  • proguardFile(proguardFile) 添加一个混淆文件
  • proguardFiles(proguardFileArray) 添加多个混淆文件
  • setProguardFiles(proguardFileIterable) 设置多个混淆文件
  • productFlavors:配置不同风格的APP,在buildTypes的基础上还可以让每一个类型的APP拥有不同的风格,所以最终打出的APK的数量就是buildTypes乘以productFlavors
  • applicationId 设置应用ID
  • multiDexEnabled Whether Multi-Dex is enabled for this variant.signingConfig Signing config used by this product flavor.
  • testApplicationId 设置测试时的应用ID
  • testFunctionalTest See instrumentation.
  • testHandleProfiling See instrumentation.
  • testInstrumentationRunner Test instrumentation runner class name.
  • versionCode 设置版本号
  • versionName 设置版本名称
  • minSdkVersion(int minSdkVersion) 设置兼容的最小SDK版本
  • minSdkVersion(String minSdkVersion) 设置兼容的最小版本
  • proguardFile(proguardFile) 添加一个混淆文件
  • proguardFiles(proguardFileArray) 添加多个混淆文件
  • setProguardFiles(proguardFileIterable) 设置多个混淆文件
  • targetSdkVersion(int targetSdkVersion) 设置目标SDK版本
  • targetSdkVersion(String targetSdkVersion) 设置目标SDK版本
  • testOptions:设置测试相关属性
  • reportDir 设置测试报告的目录
  • resultsDir 设置测试结果的目录
  • aaptOptions:设置AAPT的属性
  • failOnMissingConfigEntry Forces aapt to return an error if it fails to find an entry for a configuration.
  • ignoreAssets Pattern describing assets to be ignore.
  • noCompress Extensions of files that will not be stored compressed in the APK.
  • useNewCruncher Whether to use the new cruncher.
  • lintOptions:设置Lint的属性
  • dexOptions
  • compileOptions:设置编译的相关属性
  • packagingOptions:设置APK包的相关属性
  • splits:设置如何拆分APK(比如你想拆分成arm版和x86版)
  1. dependencies:配置依赖

新特性:

Google在用Gradle最为Android打包工具的时候引入了 applicationId 的概念,这是为了 打多个不同ID的APK包 准备的。

applicationId 可以和清单文件中的 packageName 不一样,我们在代码中通过 getPackageName() 方法拿到的是 applicationId ,而清单文件中配置的packageName则仅作为 R.javaBuildConfig.java 的存放目录。

这样一来通过 Class.forName(getPackageName()+”.R”) 来获取 R 类的方式就行不通了,一定要注意。

打包

build.gradle 文件配置完成后,打开终端,进入项目目录下,执行 gradle build 即可打包,打包结束后在相应module的 build/outputs/apk/ 目录下可以看到 .apk 文件。

如果你是在项目目录下执行的打包命令,那么会对项目中所有的 module 都打包,进入某个module目录下执行打包命令就只对当前module打包,每个module打包生成的APK或AAR都才存放在mudule的 build/outputs 目录下。

使用第三方库


1) 指定libs目录为jar库

目录的配置就是在build.gradle文件中,如下图所示:

2) Module之间的依赖

现在假如项目中有两个Module,一个 library 一个 sample ,现在sample要依赖library:

只需在 samplebuild.gradle 文件中添加 compile project(':library’) 即可,如下图所示:

这里有个限制就是library必须library module,那么如何决定一个Module是不是library module呢,区别就在于build.gradle文件的apply plugin参数,例如:

sample的apply plugin参数的值是 com.android.application ,就说明这是个app

library的apply plugin参数的值是 com.android.library,就说明这是个library

需要注意的是从1.0开始library module的build.gradle不再需要 applicationId 参数,如果有的请删除

3) 使用AAR

第三方的库无外乎两种情况:

  • 一些基础功能库,例如图片加载、网络请求等,这些库只有一个jar文件

使用的时候就很方便了直接放到libs目录下就可以了。

  • 一些UI组件库,既包含有Java文件又有资源文件 eclipse里我们要么把第三方库弄成一个library项目(在studio中就是把第三方库弄成一个library Module)然后引用,要么就把第三方库里的所有文件融合到我们的项目中。这样很不方便,也很难维护。

Android官方在开发Android Studio的时候就发布了一种独有的格式AAR,专门用于打包UI组件库。与jar相比其多了一些UI组件用到的属性、图片等一系列文件,它的好处在于你不需要再多创建一个Library Module,只需引用这个AAR文件即可,Android Sudio会自动把AAR包里的文件跟你的项目融合。

1)) AAR包的内部文件结构
/AndroidManifest.xml (mandatory)
/classes.jar (mandatory)
/res/ (mandatory)
/R.txt (mandatory)
/assets/ (optional)
/libs/*.jar (optional)
/jni/<abi>/*.so (optional)
/proguard.txt (optional)
/lint.jar (optional)
2)) 优缺点

优点:使用方便,提升编译速度

缺点:不能方便的对AAR进行修改,Eclipse不支持AAR

  • 因为AAR是Google在开发Android Studio的时候推出的,并且Google正在抛弃Eclipse转向Android Studio .
3)) 生成AAR包

在你的项目中创建一个library Module然后在终端中执行 grade build,然后到 build/outputs/aar 目录下就能看到你的AAR文件。

4)) 使用本地AAR

recyclerview-v7-21.0.0.aar 为例,首先将AAR包放到libs文件夹下:


相关文章
|
1月前
|
安全 Android开发 iOS开发
Android vs. iOS:构建生态差异与技术较量的深度剖析###
本文深入探讨了Android与iOS两大移动操作系统在构建生态系统上的差异,揭示了它们各自的技术优势及面临的挑战。通过对比分析两者的开放性、用户体验、安全性及市场策略,本文旨在揭示这些差异如何塑造了当今智能手机市场的竞争格局,为开发者和用户提供决策参考。 ###
|
27天前
|
安全 Android开发 iOS开发
安卓与iOS的较量:技术深度对比
【10月更文挑战第18天】 在智能手机操作系统领域,安卓和iOS无疑是两大巨头。本文将深入探讨这两种系统的技术特点、优势以及它们之间的主要差异,帮助读者更好地理解这两个平台的独特之处。
44 0
|
17天前
|
安全 搜索推荐 Android开发
揭秘安卓与iOS系统的差异:技术深度对比
【10月更文挑战第27天】 本文深入探讨了安卓(Android)与iOS两大移动操作系统的技术特点和用户体验差异。通过对比两者的系统架构、应用生态、用户界面、安全性等方面,揭示了为何这两种系统能够在市场中各占一席之地,并为用户提供不同的选择。文章旨在为读者提供一个全面的视角,理解两种系统的优势与局限,从而更好地根据自己的需求做出选择。
42 2
|
19天前
|
安全 搜索推荐 Android开发
揭秘iOS与安卓系统的差异:一场技术与哲学的较量
在智能手机的世界里,iOS和Android无疑是两大巨头,它们不仅定义了操作系统的标准,也深刻影响了全球数亿用户的日常生活。本文旨在探讨这两个平台在设计理念、用户体验、生态系统及安全性等方面的本质区别,揭示它们背后的技术哲学和市场策略。通过对比分析,我们将发现,选择iOS或Android,不仅仅是选择一个操作系统,更是选择了一种生活方式和技术信仰。
|
24天前
|
安全 Android开发 iOS开发
iOS与安卓:技术生态的双雄争霸
在当今数字化时代,智能手机操作系统的竞争愈发激烈。iOS和安卓作为两大主流平台,各自拥有独特的技术优势和市场地位。本文将从技术架构、用户体验、安全性以及开发者支持四个方面,深入探讨iOS与安卓之间的差异,并分析它们如何塑造了今天的移动技术生态。无论是追求极致体验的苹果用户,还是享受开放自由的安卓粉丝,了解这两大系统的内在逻辑对于把握未来趋势至关重要。
|
25天前
|
安全 搜索推荐 Android开发
揭秘iOS与Android系统的差异:一场技术与哲学的较量
在当今数字化时代,智能手机操作系统的选择成为了用户个性化表达和技术偏好的重要标志。iOS和Android,作为市场上两大主流操作系统,它们之间的竞争不仅仅是技术的比拼,更是设计理念、用户体验和生态系统构建的全面较量。本文将深入探讨iOS与Android在系统架构、应用生态、用户界面及安全性等方面的本质区别,揭示这两种系统背后的哲学思想和市场策略,帮助读者更全面地理解两者的优劣,从而做出更适合自己的选择。
|
29天前
|
安全 Android开发 iOS开发
安卓vs iOS:探索两种操作系统的独特魅力与技术深度###
【10月更文挑战第16天】 本文旨在深入浅出地探讨安卓(Android)与iOS这两种主流移动操作系统的特色、优势及背后的技术理念。通过对比分析,揭示它们各自如何塑造了移动互联网的生态,并为用户提供丰富多彩的智能体验。无论您是科技爱好者还是普通用户,都能从这篇文章中感受到技术创新带来的无限可能。 ###
49 2
|
29天前
|
机器学习/深度学习 人工智能 Android开发
安卓与iOS:技术演进的双城记
【10月更文挑战第16天】 在移动操作系统的世界里,安卓和iOS无疑是两个最重要的玩家。它们各自代表了不同的技术理念和市场策略,塑造了全球数亿用户的移动体验。本文将深入探讨这两个平台的发展历程、技术特点以及它们如何影响了我们的数字生活,旨在为读者提供一个全面而深入的视角,理解这两个操作系统背后的哲学和未来趋势。
32 2
|
1月前
|
调度 Android开发 开发者
构建高效Android应用:探究Kotlin多线程优化策略
【10月更文挑战第11天】本文探讨了如何在Kotlin中实现高效的多线程方案,特别是在Android应用开发中。通过介绍Kotlin协程的基础知识、异步数据加载的实际案例,以及合理使用不同调度器的方法,帮助开发者提升应用性能和用户体验。
46 4
|
1月前
|
Java Android开发 Swift
掌握安卓与iOS应用开发:技术比较与选择指南
在移动应用开发领域,谷歌的安卓和苹果的iOS系统无疑是两大巨头。它们不仅塑造了智能手机市场,还影响了开发者的日常决策。本文深入探讨了安卓与iOS平台的技术差异、开发环境及工具、以及市场表现和用户基础。通过对比分析,旨在为开发者提供实用的指导,帮助他们根据项目需求、预算限制和性能要求,做出最合适的平台选择。无论是追求高度定制的用户体验,还是期望快速进入市场,本文都将为您的开发旅程提供有价值的见解。

热门文章

最新文章