在實際開發中,經常需要對tableView或者collectionView執行更新數據源的操作,reloadData是一個常見的方法。這是 UITableView 和 UICollectionView 提供的一個方法,用於重新載入視圖的所有可見行(或項)。 當調用 reloadData 方法時,UI ...
三、主要文件種類
1.Activity
一個界面的顯示往往由Acitivity,佈局文件,清單文件共同完成。
Activity是用於控制可視化的界面,其使用需要使用AppCompatActivity作為基類。該類中常用的方法包括但不限於:onCreate(), initView(), onDestroy(), onResume();這幾個方法會隨著該類的狀態改變而被調用。
setContentView()用於裝載佈局文件,即確定該Acitivity所控制的界面。
若要實現自定義的界面,則需要對該基類中的一些方法進行重寫。
2.佈局文件
xml文件,用於設計和美化界面顯示。
xml文件的設計主要有設計模式和代碼模式兩種,在設計模式中可以對控制項進行拖拽,併在對應的屬性框中選擇或輸入相應的屬性值。在代碼模式中則使用代碼的方式對佈局文件進行設計,建議在設計的過程中打開預覽,隨時觀察代碼對佈局文件的影響。
佈局文件的設計可以自行選擇自己熟悉和順手的方式進行設計__。
3.清單文件
AndroidManifest文件
該文件將指定程式的packagename,用於系統辨識app的唯一標識。
該文件中將指定程式中的activity的類型,併在意圖過濾器中設定app的主應用程式,以及app的圖標等屬性。
例:
<activity android:name="cn.com.TestActivity.ui.WelcomeActivity" android:exported="true" android:theme="@style/SimpleTaskAppTheme"> <intent-filter> <action android:name="android.intent.action.MAIN" /> <category android:name="android.intent.category.LAUNCHER" /> </intent-filter> </activity>
Tips:
1.如果在原應用的基礎上對應用進行更新,清單文件中的部分修改可能不會隨之更新,需要將原應用卸載後重新安裝方能生效!!!!!
四、UI佈局
佈局是指對界面結構的全面規劃和安排,通過api中提供的各種佈局能夠快速的完成對界面的設計。
添加佈局的方式有兩種:使用xml文件聲明,使用java文件設計view(強烈不建議)。將流程邏輯與界面設計分開進行管理是更加清晰的方式。
1.線性佈局LinearLayout
在res文件夾下的layout文件夾內新建layout文件,文件根元素類型選擇LinearLayout,完成文件的新建。
線性佈局中常用的佈局指令:
android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_marginTop="100dp" android:layout_gravity="right" android:layout_weight="0.5"
用layout_magin指令控制控制項與其他控制項之間的距離
用padding控制邊框與自己父控制項之間的邊距
<!--layout_weight表示該模塊中所占的剩餘空間的比重,其中剩餘空間是指在分配完各模塊所占用的空間大小後,父模塊剩餘的空白區域的尺寸-->
2.相對佈局RelativeLayout
文件的創建方式與線性佈局類似
部分常用的佈局指令:(部分指令中使用的Left和Right應替換成Start和End,舊版本中的)
主要分成兩個大類,相對於父控制項的指令和相對於其他控制項的指令
相對於父控制項:
android:layout_alignParentTop="true"
android:layout_aligncenterInParent="true"
android:layout_alignParentLeft
android:layout_alignParentRight
android:layout_alignParentTop
android:layout_alignParentBottom
相對於其他控制項:
(在參照物的某邊)
android:layout_toStartOf=
android:layout_toEndOf=
android:layout_above=
android:layout_below=
(與參照物的某邊線對齊)
android:layout_alignTop=
android:layout_alignBottom=
android:layout_alignStart=
android:layout_alignEnd=