Android ConstraintLayout詳解(from jianshu)

来源:https://www.cnblogs.com/2eggs/archive/2018/08/23/9521584.html
-Advertisement-
Play Games

Android ConstraintLayout詳解 https://www.jianshu.com/p/a8b49ff64cd3 1. 概述 在本篇文章中,你會學習到有關ConstraintLayout -- 一種構建於彈性Constraints(約束)系統的新型Android Layout。最終 ...


Android ConstraintLayout詳解

 https://www.jianshu.com/p/a8b49ff64cd3

1. 概述

   

在本篇文章中,你會學習到有關ConstraintLayout -- 一種構建於彈性Constraints(約束)系統的新型Android Layout。最終你將會在Android Studio中編輯與構建一個相對複雜的Layout。

收穫
  • 新Layout Manager所使用的Constraints系統
  • 創建Constraints來構建彈性高效的Layouts
  • 新Layout編輯器的各種功能
需求

2. 獲取示例代碼

$ git clone https://github.com/googlecodelabs/constraint-layout.git

3. 運行示例代碼

  1. 打開Android Studio,選擇 File>New>Import Project,選擇步驟2下載的示例代碼的文件夾constraint-layout-start
  2. 點擊Gradle sync按鈕。
  3. Project�面板內打開 res/layout/activity_main_done.xml
  4. 選擇Design選項顯示最終的layout編輯界面
  5. 在編輯器左上角選擇Virtual Device to render the layout withNexus 5x
  6. 完工

4. Constraints 系統概覽

Layout引擎使用Contraints指定每個widget來決定他們在layout中的位置。你可以使用Android Studio Layout編輯器界面來手動或者自動指定約束。要更好的理解他,需要我們瞭解一下他對一個選中的widget的基本控鍵。

Constraints

Constraints幫助你保持widgets對齊。你可以使用箭頭來決定各widgets的對齊規則。例如(�圖示 A),從button 2左側控鍵設置一個constraint到button 1的右側控鍵意味著:button 2會放置於button 1右側56dp

  圖示 A
控鍵類型
  圖示 B:不同類型的控鍵
  • 調整尺寸控鍵 - 類似於其他設計/繪圖應用,該控鍵允許你調整widget尺寸

       

     

  • 側約束控鍵 - 該控鍵讓你指定widget的位置。例如,你可以使用widget的左側控鍵到其他widget的右側控鍵相隔24dp

       

     

  • 基線約束控鍵 - 該控鍵幫助你對齊任意兩個widget的文字部分,與widget的大小無關。例如你有兩個不同尺寸的widget但是你想要他們的文字部分對齊。

       

     


《ConstraintLayout從入門到放棄》

太長;別讀

5. ConstraintLayout應用

一)開啟

現在,讓我們開始來構建你自己的Constraint Layout。

從左側導航欄打開 res/layout/activity_main_start.xml

  • 載入constraint-layout依賴
    constraint-layout依賴構建在一個分離的支持庫里,該依賴支持從Android2.3(Gingerbread)到最新的版本。這個項目在app/build.gradle里已經包含了該依賴
dependencies {
  ...
  compile 'com.android.support.constraint:constraint-layout:1.0.0-alpha2'
}
  • **回到 res/layout/activity_main_start.xml **

    該layout已經有了一個空的ConstraintLayout

<?xml version="1.0" encoding="utf-8"?>
<android.support.constraint.ConstraintLayout
    xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    android:layout_width="match_parent"
    android:layout_height="match_parent">

</android.support.constraint.ConstraintLayout>

在編輯器底部轉換到Design選項

   

 

  • 添加ImageView
    添加一個ImageView到layout。在編輯器內,找到ImageView拖到layout內。

 

   
ImageView一旦拖到layout中,UI會提示需要resource。constraint-layout-start已經包含了resources,請選擇@drawable/singaporeresource。
一旦選中ImageView,你可以點擊並按住調整尺寸控鍵來調整圖片大小。
   

 

  • 添加TextView
    找到TextView並拖到layout內。
       
    我們會看到一些警告,因為在ImageView以及TextView內沒有contentDescription屬性。內容描述(Content Description)屬性對於構建可訪問應用非常重要。讓我們為該屬性添加@string/dummy
    在右側,Inspector面板可以改變已選擇widget的各種屬性。
   
  1. 選擇ImageView並添加@string/dummycontentDescription屬性
  2. 在Inspector面板,你可以看到ImageView的其他屬性。修改scaleTypecenterCrop
  3. 接著,我們選擇TextView,使用該面板修改text值為@string/singapore

二)手動創建Constraints

創建一個約束,你需要在widget的某個控鍵上點擊並按住,然後拖到兩一個widget的約束控鍵內。一旦顯示綠色,你就可以鬆手了最終約束就會被創建。

   

註意:該部分講有關手動創建約束的,需要將左上角的自動創建約束按鈕關閉


   

在開始之前,確保ImageViewTextView在layout內。我們的目標是在容器、ImageView以及TextView之間創建約束。

假設我們想要TextView置於ImageView下方。我們可以在TextView的頂部控鍵與ImageView的底部控鍵創建一個約束,如圖:

   

 

移除約束:移除某個約束只需點擊指定約束的控鍵;移除全部約束需要點擊如下按鈕:


   

下一步,創建ImageView跟容器頂部的約束

   

 

最後,創建ImageView左右兩側的約束

  89f057b3a8ea3e0b.png

 

創建基線約束 - 連接widget的基線控鍵到另一個的基線


   

三)熟悉Inspector

在此部分,我們會瞭解一下Inspector。它在UI編輯器的右側。附帶有已選擇widget的各種相關屬性,而且還顯示了該視圖是如何對齊與約束的。

  • 移除TextView
  • 添加ImageView底部約束

此時,UI構建起如下圖:


   

以下部分描述了不同的元素和他們的使用方法:

Margins - widget的外圍上下左右為margins。你可以點擊按鈕設置不同的值來改變margins。在上邊截圖中,margins設置為16dp

移除constraint - 在Inspector內點擊連接widget與container的線,可以移除約束。當然也可以點擊已設置約束的控鍵來移除。

相對於約束來放置widget - 當在一個widget有至少兩個相對的連接,比如說頂部和底部,或者左側和右側,然後就可以使用滑動條來調節widget在鏈接中的位置。你還可以改變屏幕方向來進一步調整方位。

   

 

控制widget內部尺寸 - Inspector內部的線讓你可以控制widget內部尺寸。

   
  **Fixed** - 可以調整widget的寬度和高度

 

  **AnySize** - 使得widget占據所有可用的控鍵來滿足約束   **AnySize**應用之前
  **AnySize**應用之後   **Wrap Content** - 含有text或者drawable的widget擴大到填滿整個容器

四)自動創建Constraints

Autoconnect自動創建widgets之間的連接。開始之前

  • 打開res/layout/activity_main_autoconnect.xml
  • 開啟Autoconnect(譯註:小磁鐵圖標)

接下來,選中ImageView並且拖到layout的中心,如下圖所示:

   

 

下一步,下方的動圖展示了以下幾個步驟


  10210fd273ea1a86.png
  1. ImageView對齊頂部並使用Inspector(AnySize)來確保他擴展到兩側
  2. 放置兩個button在右下角。使用Inspector面板來修改最右邊button的text@string/upload以及左側改為@string/discard
  3. 將一個TextView和一個Plain Text放到layout中。
  4. 調整TextViewPlain Text48dp。並自動創建約束。
  5. 同樣的選中上傳button放置到右側。
  6. 最後放置取消button離上傳button32dp的位置

五)使用Inference創建Constraints

(譯註:待更新)


FAQ: (感謝Little_Mango提供的問題)

  1. 兄弟控制項對齊方式只有top left bottom right,無x,y中心點對齊,這樣兩個View依然無法做到水平方向中點對齊。
    使用chains

  2. 父子控制項間寬高約束過於簡單,只有wrap_content,fixed,match,即包裹內容,匹配父容器,和絕對數值,無法做到類似子控制項的寬度等於父控制項的寬度的的1/4的需求。
    使用Guidelines(新版的指南好像沒有介紹)

  3. 兄弟、父子之間寬高屬性之間無約束,比如A控制項寬度等於屏幕寬度的1/4,A控制項的高度等於自身的寬度。B控制項的寬等於A控制項的寬度,B控制項的高度等於A控制項的高度的1/2.
    a. 參考 2
    b. 使用ratios
    c. 參考 b

  4. 不清楚是否能通過代碼動態修改約束,如果不支持這種操作,那麼類似容器垂直方向圖片張數不一致這種需求也無法動態修改。
    使用 barriers

  5. 這個佈局是否有佈局的動畫支持?如果沒有,那麼動畫如何修改?通過修改控制項的height和width是否會和約束衝突?
    動畫支持


原文鏈接:Using ConstraintLayout to design your views


  • 如有翻譯有誤或者不理解的地方,請評論指正
  • 待更新的譯註之後會做進一步修改翻譯
  • 翻譯:田浩浩
  • 郵箱:[email protected]


作者:llitfk_DockOne
鏈接:https://www.jianshu.com/p/a8b49ff64cd3
來源:簡書
簡書著作權歸作者所有,任何形式的轉載都請聯繫作者獲得授權並註明出處。
您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 在安裝完資料庫後,使用漢字插入到表中,會報錯,需要修改字元集類型,如下圖所示: 如下圖所示: character_set_database=iatin1 需要改成utf8或gbk 打開my.cnf文件,修改參數,再重啟 重啟後,再查看SHOW VARIABLES LIKE 'character%'。 ...
  • 歡迎大家前往 "騰訊雲+社區" ,獲取更多騰訊海量技術實踐乾貨哦~ 本文由 "騰訊雲實驗室" 發表於 "雲+社區專欄" 騰訊雲提供了 "開發者實驗室" 教你搭建 PySpider 爬蟲服務,教程內容如下,用戶可以點擊 "開發者實驗室" 快速上機完成實驗。 環境準備 任務時間:5min ~ 10min ...
  • 1.用戶管理 1.1用戶的定義 用戶名+主機域 select user,host,authentication_string from mysql.user; ...
  • --Oracle使用的是用戶管理模式--意味著,Oracle的數據使用用戶來分割 --以後開發,我們需要每個項目都需要使用一個用戶 --所以:一個數據文件是可以放多個用戶的數據的。但是我們開發從數據的維護而已,是不希望--一個文件放多個用戶的數據的。這樣會導致相互影響 --數據文件是通過表空間來創建 ...
  • [toc] 問題 MySQL5.6 新建本地可以登錄的用戶,但在本地始終登錄不上,不存在的用戶卻能登錄成功 分析 1、本是以ip地址進行登錄的,錯誤信息報的是Access denied for user 'admin'@'slave58',自動進行了DNS解析,解析成了主機名,skip name r ...
  • Code: 參考(轉載): https://blog.csdn.net/qq_36663951/article/details/73176103 ...
  • 開發都離不開數據,對資料庫的熟悉程度可以為我們省去很多麻煩,我們必須先瞭解一下資料庫。 一個事務本質上有四個特點ACID: Atomicity原子性 Consistency一致性 Isolation隔離性 Durability耐久性 悲觀鎖和樂觀鎖的區別 悲觀鎖(Pessimistic Lock): ...
  • 簡述在Windows操作系統下搭建ADT和eclipse安卓(Android)開發環境的方法。 ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...