欢迎来到代码驿站!

Android代码

当前位置:首页 > 移动开发 > Android代码

idea下Android各目录所代表的含义介绍

时间:2022-06-01 11:24:56|栏目:Android代码|点击:

1.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/

总结

上一篇:Android开发Jetpack组件WorkManager用例详解

栏    目:Android代码

下一篇:没有了

本文标题:idea下Android各目录所代表的含义介绍

本文地址:http://www.codeinn.net/misctech/203428.html

推荐教程

广告投放 | 联系我们 | 版权申明

重要申明:本站所有的文章、图片、评论等,均由网友发表或上传并维护或收集自网络,属个人行为,与本站立场无关。

如果侵犯了您的权利,请与我们联系,我们将在24小时内进行处理、任何非本站因素导致的法律后果,本站均不负任何责任。

联系QQ:914707363 | 邮箱:codeinn#126.com(#换成@)

Copyright © 2020 代码驿站 版权所有