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
  • 前言 本文介紹一款使用 C# 與 WPF 開發的音頻播放器,其界面簡潔大方,操作體驗流暢。該播放器支持多種音頻格式(如 MP4、WMA、OGG、FLAC 等),並具備標記、實時歌詞顯示等功能。 另外,還支持換膚及多語言(中英文)切換。核心音頻處理採用 FFmpeg 組件,獲得了廣泛認可,目前 Git ...
  • OAuth2.0授權驗證-gitee授權碼模式 本文主要介紹如何筆者自己是如何使用gitee提供的OAuth2.0協議完成授權驗證並登錄到自己的系統,完整模式如圖 1、創建應用 打開gitee個人中心->第三方應用->創建應用 創建應用後在我的應用界面,查看已創建應用的Client ID和Clien ...
  • 解決了這個問題:《winForm下,fastReport.net 從.net framework 升級到.net5遇到的錯誤“Operation is not supported on this platform.”》 本文內容轉載自:https://www.fcnsoft.com/Home/Sho ...
  • 國內文章 WPF 從裸 Win 32 的 WM_Pointer 消息獲取觸摸點繪製筆跡 https://www.cnblogs.com/lindexi/p/18390983 本文將告訴大家如何在 WPF 裡面,接收裸 Win 32 的 WM_Pointer 消息,從消息裡面獲取觸摸點信息,使用觸摸點 ...
  • 前言 給大家推薦一個專為新零售快消行業打造了一套高效的進銷存管理系統。 系統不僅具備強大的庫存管理功能,還集成了高性能的輕量級 POS 解決方案,確保頁面載入速度極快,提供良好的用戶體驗。 項目介紹 Dorisoy.POS 是一款基於 .NET 7 和 Angular 4 開發的新零售快消進銷存管理 ...
  • ABP CLI常用的代碼分享 一、確保環境配置正確 安裝.NET CLI: ABP CLI是基於.NET Core或.NET 5/6/7等更高版本構建的,因此首先需要在你的開發環境中安裝.NET CLI。這可以通過訪問Microsoft官網下載並安裝相應版本的.NET SDK來實現。 安裝ABP ...
  • 問題 問題是這樣的:第三方的webapi,需要先調用登陸介面獲取Cookie,訪問其它介面時攜帶Cookie信息。 但使用HttpClient類調用登陸介面,返回的Headers中沒有找到Cookie信息。 分析 首先,使用Postman測試該登陸介面,正常返回Cookie信息,說明是HttpCli ...
  • 國內文章 關於.NET在中國為什麼工資低的分析 https://www.cnblogs.com/thinkingmore/p/18406244 .NET在中國開發者的薪資偏低,主要因市場需求、技術棧選擇和企業文化等因素所致。歷史上,.NET曾因微軟的閉源策略發展受限,儘管後來推出了跨平臺的.NET ...
  • 在WPF開發應用中,動畫不僅可以引起用戶的註意與興趣,而且還使軟體更加便於使用。前面幾篇文章講解了畫筆(Brush),形狀(Shape),幾何圖形(Geometry),變換(Transform)等相關內容,今天繼續講解動畫相關內容和知識點,僅供學習分享使用,如有不足之處,還請指正。 ...
  • 什麼是委托? 委托可以說是把一個方法代入另一個方法執行,相當於指向函數的指針;事件就相當於保存委托的數組; 1.實例化委托的方式: 方式1:通過new創建實例: public delegate void ShowDelegate(); 或者 public delegate string ShowDe ...