android開發-界面設計基本知識

来源:http://www.cnblogs.com/wlandwl/archive/2016/03/18/android.html
-Advertisement-
Play Games

一個好的APP不僅有美觀,好看的界面,更需要良好的性能和穩定性。作為一名開發人員,需要理解界面設計原則並寫出優秀的界面設計代碼。 本章主要講述基本控制項的使用,界面佈局及一些常用的界面設計屬性。 (1) LinearLayout 相對佈局 android:android:layout_weight=”


一個好的APP不僅有美觀,好看的界面,更需要良好的性能和穩定性。作為一名開發人員,需要理解界面設計原則並寫出優秀的界面設計代碼。

本章主要講述基本控制項的使用,界面佈局及一些常用的界面設計屬性。

1.常用佈局

(1) LinearLayout 相對佈局

android:android:layout_weight=”1”      //百分比屬性
android:layout_above                        //表示與某個元素綁定後,在某個元素之上
android:layout_toLeftOf                     // 表示與某個元素綁定後,在某個元素左邊
android:layout_alignLeft                     //依賴於某個元素的左邊(平行對齊)
android:layout_margin                       //表示與邊界的距離,沒有方向的margin是與四邊的距離
android:padding                                           //是內邊距

android:orientation=”vertical”             //垂直展示子控制項列表

android:orientation=”horizontal”         //水平展示子控制項列表

控制項可見性設置:

設置成gone為隱藏(完全不在,不占用空間)

設置成invisible不可見(看不見,但還存在,占用空間)

 

(2) RelativeLayout
android:layout_alignParentRight          //相對於父控制項;
android:layout_toRightOf                //相對於xx控制項
android:alighLeft                           //控制項左邊和某控制項的左邊平行

(3)FrameLayout 幀佈局

控制項會一直疊加在一起

 

(4)AbsoluteLayout(很少用)

android不建議用,因為android屏幕很多

(5)TableLayout(很少用)

2.佈局技巧及優化

  1. Android佈局官方建議不超過10層。
  2. 佈局儘量用相對佈局,儘量使用layout_above、layout_toLeftOf、layout_alignLeft、layout_margin、padding等方法達到想要的佈局效果。
  3. 重用佈局文件
  4. 減少視圖層級,替換相應的層級開頭,並不會改變層級的結構
  5. 需要時才載入
  6. 不要嵌套多個使用layout_weight屬性的LinearLayout
  7. <include /> 重用佈局文件
  8. <merge /> 減少視圖層級

兩個小工具:

  1. Android lint:刪除無用的資源、佈局、文件、引用、類、控制項。
  2. HierarchyViewer:分析佈局層級

巧用LayoutInflater

LayoutInflater(載入資源文件格式)

LayoutInflater 是一個抽象類。LayoutInflater這個類,它的作用類似於findViewById(); 不同點是LayoutInflater是用來找res/layout/下的xml佈局文件,並且實例化;而 findViewById()是找xml佈局文件下的具體widget控制項。

在文檔中如下聲明: public abstract class LayoutInflater extends Object

    1. LayoutInflater inflater = getLayoutInflater();//調用Activity的getLayoutInflater()
    2. LayoutInflater inflater = LayoutInflater.from(context);
    3. LayoutInflater inflater = (LayoutInflater)context.getSystemService
      (Context.LAYOUT_INFLATER_SERVICE);

layoutInflater在項目中的使用實例代碼:

LayoutInflater inflater = (LayoutInflater)getSystemService(LAYOUT_INFLATER_SERVICE);       

View view = inflater.inflate(R.layout.custom, (ViewGroup)findViewById(R.id.test));       

EditText editText = (EditText)view.findViewById(R.id.content);

對於上面代碼,指定了第二個參數 ViewGroup root,當然你也可以設置為 null 值。

View復用

View復用可以有效的提高頁面載入的速度,從而提高整體程式的性能。View復用舉例如下:

 1 public View getView(int i, View view, ViewGroup viewGroup) {
 2         LayoutInflater inflater = (LayoutInflater) mContext.getSystemService(Context.LAYOUT_INFLATER_SERVICE);
 3 
 4         ViewHolder viewHolder;
 5         //1、view復用:只有當view為空時,才讀取xml佈局文件;不為空則繼續使用view,取控制項。
 6         if (view == null) {
 7             view = inflater.inflate(R.layout.item_listview, null);
 8             viewHolder = new ViewHolder();
 9             viewHolder.avatarImageView = (ImageView) view.findViewById(R.id.avatar_imageview);
10             viewHolder.nameTextView = (TextView) view.findViewById(R.id.item_name);
11             viewHolder.ageTextView = (TextView) view.findViewById(R.id.item_age);
12 
13             //打標簽
14             view.setTag(viewHolder);
15         } else {
16             viewHolder = (ViewHolder) view.getTag();
17         }
18 
19         viewHolder.avatarImageView.setImageResource(R.drawable.avatar);
20         viewHolder.nameTextView.setText(mUserInfo.get(i).getName());
21         viewHolder.ageTextView.setText(mUserInfo.get(i).getAge() + "");
22 
23         return view;
24     }
25 }
26 //2、創建一個類,用於緩存控制項。
27 class ViewHolder {
28     ImageView avatarImageView;
29     TextView nameTextView;
30     TextView ageTextView;
31 }
ViewDemo

 

3.常用數據控制項

android中常用的數據控制項包括,ScrollView,GridView,ListView。作為數據交互,一般會結合adapter使用。

Adapter是連接後端數據和前端顯示的適配器介面,是數據和UI(View)之間一個重要的紐帶。在常見的View(ListView,GridView) 等地方都需要用到Adapter。如下圖直觀的表達了Data、Adapter、View三者的關係:

您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • UICollectionView在眾多控制項中也算是比較常用的了,像淘寶在瀏覽寶貝時採用的就是UICollectionView,對於UICollectionView->UICollectionViewFlowLayout當然也是必不可少的了,還是老樣子結合代碼進行簡單介紹,首先看一下UICollect
  • 在用到fragment時無法使用.this來指定當前context內容,android開發中fragment獲取context,可以使用getActivity().getApplicationContext(),來獲取context內容;
  • 轉載:http://blog.csdn.net/luohai859/article/details/39347583 關於為什麼只顯示一行,個人理解是:如果單獨使用GridView和ListView,裡面的內容是固定的,底層系統很容易計算出控制項要占用的寬高,當外面嵌套一層ScrollView後,就能
  • 本文介紹了app歡迎頁的簡單實現。只有第一次運行程式時才說會出現,其餘時間不會出現。下麵是效果圖。 代碼如下:(如有不明白的可以評論我,我會詳細講解)
  • 繼承和類設計 oc是一門面向對象的語言,面向對象編程有三大特性:封裝、繼承、多態 一.封裝 【註】封裝就是把某些解決一些問題的代碼進行模塊化,對外部暴露一個介面。我們都稱為封裝了一個方法; 【優點】 1.封裝可以增強代碼的復用度。 2.封裝可以有效提高開發速度。 二.繼承 子類擁有了父類的方法和屬性
  • 什麼是Quartz2D? Quartz 2D是一個二維圖形繪製引擎,支持ios環境和Mac OS X環境。我們可以使用Quartz 2D API來實現許多功能如基本 路徑的繪製、透明度、描影、繪製陰影、透明層、顏色管理、反鋸齒、PDF文檔生成和PDF元數據訪問。在需要的時候,Quartz 2D 還可
  • 在這個網路橫行的時代......... 有沒有小說的感覺,哈哈😄。 言歸正傳,之前我寫過XML的網路解析,但是現在的app開發很少有用到XML解析的了,主流的則是JSON。(有時間我會對其進行總結)三方更是讓json解析更加簡便,由於代碼過於簡單,請大家做好心理準備。不要被嚇到哦。
  • Activity的啟動模式有四種,分別是standard、singleTop、singleTask、singleInstance。 Android是通過回退棧的模式來管理Activity實例的。棧是一種先進後出的集合。比如我們打開一個Activity,當前顯示的就是在棧的最頂端,當用戶點擊後退或者是
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...