idea下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/

總結

到此這篇關於idea下Android各目錄所代表含義的文章就介紹到這瞭,更多相關idea Android各目錄含義內容請搜索WalkonNet以前的文章或繼續瀏覽下面的相關文章希望大傢以後多多支持WalkonNet!

推薦閱讀: