idea Android各目录含义 idea下Android各目录所代表的含义介绍
像畜生一样思考 人气:01.Project模式结构模式
1、.gradle和.idea
这两个目录下都是AndroidStudio自动生成的文件。
2、app
项目中的代码、资源等内容几乎都是放置在这个目录下
3、build
这个目录包含了一些在编译时自动生成的文件。
4、gitignore
这个文件是用来将制定的目录或文件排除在版本控制之外的。
5、build.gradle
这是项目全局的gradle构造脚本
6、gradle.properties
这是项目全局的gradle配置文件
7、gradlew和gradlew.bat
这两个文件是用来在命令行界面中执行gradle命令的,gralew(Linux或Mac),gradlew.bat(Windows)
2.App目录下的结构模式
1、Build
这个目录包含了一些在编译时自动生成的文件
2、libs
如果项目中使用到第三方的Jar包,就需要把这些jar包放在libs目录下
3、androidText
项目自动化测试
4、java
放置JAVA
5、res
图片、布局、字符串等资源
6、androidManifest.xml
Android的配置文件
7、test
自动化测试的另一种方式
3.res目录下的结构模式
1、drawable
drawable文件夹一般不放置图片资源,存放一些动画文件、选择器文件、图形配置文件,drawable-mdip/hdip/xhdip文件夹放置图片资源
2、drawable-v24
当我们放入图片在drawable-v24文件夹时,在该文件夹引用该图片时会导致模拟器无法运行。图片资源放到drawable-v24里面,导致7.0以下不能找到图片。不同的drawable文件夹用于为设备兼容性和不同的Android版本提供不同的屏幕密度。同理mipmap-anydpi-v26 API 26(安卓8.0)也是一样的道理,注意不同的文件对应的不同的版本。
3、layout
存放所有的布局文件,主要是用于排列不同的显示组件,在Android程序中要读取此配置。
4、mipmap-anydpi-v26
同理mipmap-anydpi-v26 API 26(安卓8.0)也是一样的道理,注意不同的文件对应的不同的版本。
5、mipmap-mdpi
320*480
一般只把app的启动logo放在mipmap中,把其他资源图片放在drawable中。
如果为目标分辨率构建APK,那么Android资源打包工具AAPT,会从drawable文件夹中去掉你不需要的其他分辨率,即不打包进apk中,但是如果在mipmap中,不管分辨率如何,这些资源都会保留在APK中。
6、mipmap-hdpi
480*800
7、mipmap-xhdpi
780*1820
8、mipmap-xxhdpi
1080*1920
9、mipmap-xxxhdpi
2k屏
10、values
values文件夹是负责app字符串、颜色、主题、样式等渲染(这个词是我的理解)的目录。
- **colors.xml:**负责所有控件等需要使用颜色的中心刻画文件
- **strings.xml:**负责所有文本需要显示的文字集合,所有需要展示文本的地方都可以在这里进行定义
- **styles.xml:**负责app所有活动或者碎片部分的主题样式,有无标题栏等都是在这里进行设置
4.AndroidManifest.xml详解
1.AndroidManifest是什么?
AndroidManifest官方解释是应用清单(manifest意思是货单),每个应用的根目录中都必须包含一个,并且文件名必须一模一样。这个文件中包含了APP的配置信息,系统需要根据里面的内容运行APP的代码,显示界面。
2.AndroidManifest的作用是什么?
第一条:提供软件包名。这就是我们的apk的名字,通常我们的名字都是类似"com.android.gles3jni"这种,和Java类名类似,目的是确定使其成为一个唯一值。
第二条:描述应用的各个组件。这是用来定义四大组件用的。我们最常用的就是Activity组件。它需要定义组件的表现形式(组件名、主题、启动类型),组件可以响应的操作(例如某个启动意图)等。
第三条:声明最低API级别。这个级别在build.gradle文件中也能定义,字段是minSdkVersion。在AndroidManifest.xml文件中定义的情况比较少。
第四条:列出必要的lib库。这东西在3.0以后的Android Studio似乎也没什么功能,因为在3.0以后编译用的是CMakeLists.txt文件,以及build.gradle文件来指定库。
详情请见链接:https://www.jianshu.com/p/3b5b89d4e154
3.一份真实的AndroidManifest.xml文件
<?xml version="1.0" encoding="utf-8"?> <manifest xmlns:android="http://schemas.android.com/apk/res/android" package="com.computer"> <!-- 首先,所有的xml都必须包含<manifest>元素。这是文件的根节点。 它必须要包含<application>元素,并且指明xmlns:android和package属性。--> <!-- <manifest>元素中的属性--> <!-- xmlns:android 这个属性定义了Android命名空间。必须设置成"http://schemas.android.com/apk/res/android"。不要手动修改。--> <!-- package--> <!-- 这是一个完整的Java语言风格包名。包名由英文字母(大小写均可)、数字和下划线组成。每个独立的名字必须以字母开头。--> <!-- 构建APK的时候,构建系统使用这个属性来做两件事:--> <!-- 1、生成R.java类时用这个名字作为命名空间(用于访问APP的资源)--> <!-- 比如:package被设置成com.sample.teapot,那么生成的R类就是:com.sample.teapot.R--> <!-- 2、用来生成在manifest文件中定义的类的完整类名。比如package被设置成com.sample.teapot, 并且activity元素被声明成<activity android:name=".MainActivity">, 完整的类名就是com.sample.teapot.MainActivity。--> <!-- 包名也代表着唯一的application ID,用来发布应用。但是,要注意的一点是:在APK构建过程的最后一步, package名会被build.gradle文件中的applicationId属性取代。 如果这两个属性值一样,那么万事大吉,如果不一样,那就要小心了。--> <!-- <application>元素--> <!-- 此元素描述了应用的配置。这是一个必备的元素,它包含了很多子元素来描述应用的组件, 它的属性影响到所有的子组件。许多属性(例如icon、label、permission、process、taskAffinity和allowTaskReparenting) 都可以设置成默认值。--> <application android:allowBackup="true" android:icon="@mipmap/data" android:label="@string/app_name" android:roundIcon="@mipmap/data" android:supportsRtl="true" android:theme="@style/AppTheme"> <!-- allowBackup: 表示是否允许APP加入到备份还原的结构中。如果设置成false,那么应用就不会备份还原。默认值为true。--> <!-- icon: APP的图标,以及每个组件的默认图标。可以在组价中自定义图标。 这个属性必须设置成一个引用,指向一个可绘制的资源,这个资源必须包含图片。 系统不设置默认图标。例如mipmap/data引用的就是下面的资源,data就是启动图标的图标名--> <!-- label: 一个用户可读的标签,以及所有组件的默认标签。子组件可以用他们的label属性定义自己的标签, 如果没有定义,那么就用这个标签。标签必须设置成一个字符串资源的引用。 这样它们就能和其他东西一样被定位,比如@string/app_name。当然,为了开发方便,你也可以定义一个原始字符串。 eg: 在res/values/strings.xml : <string name="app_name">数据传递</string> --> <!-- roundIcon: 现在Android新建项目后会自动设置两个图标,icon和roundicon。 一个是普通图标,一个是圆形图标。比如Android自带模拟器调试时显示用的图标就是圆形图标。--> <!-- supportaRtl: 从Android 4.2开始,Android SDK支持一种从右到左(RTL,Right-to-Left)UI布局的方式, 尽管这种布局方式经常被使用在诸如阿拉伯语、希伯来语等环境中,中国用户很少使用。 不过在某些特殊用途中还是很方便的。Rtl: Right-to-left --> <!-- theme: 该属性定义了应用使用的主题的,它是一个指向style资源的引用。各个activity也可以用自己的theme属性设置自己的主题。 在res/values/styles.xml文件中: <style name="AppTheme" parent="Theme.AppCompat.Light.DarkActionBar"> </style> --> <activity android:name=".MainActivity"> <intent-filter> <action android:name="android.intent.action.MAIN"/> <category android:name="android.intent.category.LAUNCHER"/> </intent-filter> </activity> <!--name:Activity类的名称,是Activity类的子类。 该属性值为完全限定类名称,例如com.computer.MainActivity。 为了方便起见,如果第一个字符是点('.'),就需要加上<manifest>元素中的包名。应用一旦发布,不应更改该名称。 --> <!-- <intent-filter>元素 指明这个activity可以以什么样的意图(intent)启动。该元素有几个子元素可以包含。我们先介绍遇到的这两个: <action>元素 表示activity作为一个什么动作启动,android.intent.action.MAIN表示作为主activity启动。 <category>元素 这是action元素的额外类别信息,android.intent.category.LAUNCHER表示这个activity为当前应用程序优先级最高的Activity。 --> <activity android:name=".activity.Success"> </activity> <!--name:Activity类的名称,是Activity类的子类。 该属性值为完全限定类名称,例如com.computer.activity.Success。 --> </application> </manifest>
官网:https://developer.android.google.cn/
总结
加载全部内容