flexboxlayout

来源:http://www.cnblogs.com/dyryy/archive/2016/12/29/6232541.html
-Advertisement-
Play Games

提到FlexboxLayout大家估計有點模糊,它是谷歌最近開源的一個android排版庫,它的前身Flexbox是2009年W3C提出了一種新的佈局,可以簡便、完整、響應式的實現頁面佈局,Flexbox 是屬於web前端領域CSS的一種佈局方案。 首先:我們看一下它的屬性。 flexDirecti ...


      提到FlexboxLayout大家估計有點模糊,它是谷歌最近開源的一個android排版庫,它的前身Flexbox是2009年W3C提出了一種新的佈局,可以簡便、完整、響應式的實現頁面佈局,Flexbox 是屬於web前端領域CSS的一種佈局方案。

首先:我們看一下它的屬性。

 flexDirection:

     flexDirection屬性是決定主軸的方向。好比LinearLayout的vertical(垂直) 和 horizontal(水平)方向。

     flexDirection有四個可選值:

  • row:一般為預設值,主軸為水平方向,起點在左端。
  • row-reverse: 主軸為水平方向,起點在右端。
  • column:主軸為垂直方向,起點在上沿。
  • column-reverse:主軸為垂直方向,起點在下沿。

   如圖:

  row:

  row-reverse:

  column:

  column-reverse:

 

 flexWrap:

     預設情況下是不支持換行排列。

  • nowrap:不換行。
  • wrap: 正常方向換行。
  • wrap-reverse: 反方向換行。     

   如圖:

wrap:

 

wrap-reverse:

 

 

 justifyContent:

     指定了項目在主軸上的對齊方式。

  • flex-start: 預設值為左對齊。
  • flex-end: 右對齊。
  • center: 居中。
  • space-between: 兩端對齊,其間間距相等。
  • space-around: 兩側間距相等。

 如圖:

space-around:

 

alignltems:

     指定項目在副軸軸上的對齊方式。

  • flex-start: 交叉軸的起點對齊。(上)
  • flex-end:  交叉軸的終點對齊。(下)
  • center:     交叉軸的中點對齊。(中間線)
  • baseline:  第一行文字的基線對齊。()
  • stretch:   預設值是占滿整個容器的高度,在未設置高度或者為auto。 

     如圖:

     flex-start:

    

     flex-end:

    

   center:

   

   baseline:基線跟圖一類似

   

   stretch:預設

   

    alignContent:

    指定多根軸線的對齊方式,如果只有一條軸,該屬性不起任何作用。

  • flex-start: 與交叉軸的起點對齊。
  • flex-end:  與交叉軸的終點對齊。
  • center:     與交叉軸的中點對齊。
  • space-between:  與交叉軸的兩端對齊,軸線之間的間隔分佈均勻。
  • space-around:   每根軸線兩側的間隔相等。 
  • stretch: 預設值為軸線占滿整個交叉軸。   

子元素的屬性:

      layout_order:預設情況下子元素的排列方式按照文檔流的順序依次排序,而order可以控制排列的順序,負值在前,正直災後,按照從小到大的順序一次排列。

     

      layout_flexGrow:指定項目的放大比例,預設為0,如果存在剩餘空間,也不放大。如果為1,等分剩餘空間。

 

      layout_flexShrink:縮小比例,預設為1,空間不足,項目縮小。如果屬性都為1,空間不足時,將等比縮小。負值無效。

 

      layout_alignSelf:允許單個子元素與其它子元素有不一樣的對齊方式,可覆蓋alignltems屬性,預設值為auto,表示繼承父元素的alignltems屬性,如沒有父元素,則等同於stretch。

      該屬性有6個值,除了auto,其它都與align-items屬性一樣。

      layout_flexBasisPercent:指定了在分配多餘空間之前,子元素占據的main size主軸空間,瀏覽器根據這個屬性,計算主軸是否有多餘空間。預設值為auto,即子元素的本來大小。圖片後續附上。

   activity_main.xml

<com.google.android.flexbox.FlexboxLayout
    xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    xmlns:tools="http://schemas.android.com/tools"
    android:id="@+id/flexbox_layout"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    app:alignContent="flex_start"
    app:alignItems="flex_start"
    app:flexWrap="wrap"
    app:layout_behavior="@string/appbar_scrolling_view_behavior"
    tools:showIn="@layout/activity_main">


    <TextView
        android:id="@+id/textview1"
        style="@style/FlexItem"
        android:layout_width="@dimen/flex_item_length2"
        android:layout_height="@dimen/flex_item_length"
        android:text="@string/one" />

    <TextView
        android:id="@+id/textview2"
        style="@style/FlexItem"
        android:layout_width="@dimen/flex_item_length3"
        android:layout_height="@dimen/flex_item_length"
        android:text="@string/two" />

    <TextView
        android:id="@+id/textview3"
        style="@style/FlexItem"
        android:layout_width="@dimen/flex_item_length"
        android:layout_height="@dimen/flex_item_length"
        android:text="@string/three" />

</com.google.android.flexbox.FlexboxLayout>

添加依賴:

compile 'com.google.android:flexbox:0.1.2'

 

源碼git上有,大家可以去git上下載。

 


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

-Advertisement-
Play Games
更多相關文章
  • 屬於轉載 http status code:200:成功,伺服器已成功處理了請求,通常這表示伺服器提供了請求的網頁 404:未找到,伺服器未找到 201-206都表示伺服器成功處理了請求的狀態代碼,說明網頁可以正常訪問。 200(成功) 伺服器已成功處理了請求。通常,這表示伺服器提供了請求的網頁。 ...
  • 現在的css3真是強大,之前很多動畫都是用jq來實現,但是css3製作的動畫要比jq實現起來簡單很多,今天呢,我自己也寫了一個css旋轉動畫和大家分享。效果如下麵的圖片 思路:1.製作之前呢,我們先來整理一下思路,這個圓軸軌跡上一共有八個圓。 仔細看的話,你會發現一個規律,那就是一個月是360度的, ...
  • 前言 昨日,我請了一天假去考科目三,結果第一把掛在了沒完全關閉燈光上,第二把掛在轉彎時沒有觀察後方車輛,當聽到師傅一句“下去”的時候,我那是悲痛的面紅耳赤,這讓我很鬱悶,晚上也就不想回去上班了,回家後仍然有點低沉,在這種情況下,不寫點毒雞湯,好像已經不能好好的調節心情了,看看時間年底了,便寫寫今年的 ...
  • 學習 Activity 生命周期時希望通過 Dialog 主題測試 onPause() 和 onStop() 的區別。 點擊按鈕跳轉 Activity 時報錯: 找到最有用的一句話,說明所使用的 theme 和當前 Activity 不匹配。 AndroidManifest.xml 中 activi ...
  • 以下內容為原創,歡迎轉載,轉載請註明 來自天天博客: 使用Dagger 2進行依賴註入 Producers 原文: 本文是在Android中使用Dagger 2框架進行依賴註入的系列文章中的一部分。今天我們將探索下Dagger Producers 使用Java實現非同步依賴註入的Dagger2的一個擴 ...
  • 12.29日,小程式服務範圍做了重大更新,增對富媒體和工具類型的小程式,增加了很多細分領域 富媒體:增加資訊,FM電臺,有聲讀物等,媒體平臺可上小程式了 工具:信息查詢,網路代理,健康,企業管理等 ,更多查詢服務可以上線,企業辦公也可上了 商業服務:新增法律服務,不需要資格證書 ,線上法律咨詢可以上 ...
  • 由[OpenDigg](http://www.opendigg.com/) 出品的iOS開源項目周報第三期來啦。我們的iOS開源周報集合了OpenDigg一周來新收錄的優質的iOS開發方面的開源項目,方便iOS開發人員便捷的找到自己需要的項目工具等。 ...
  • 摘要:我們來瞭解一下MVVM模式與Databinding ,MVVM是一種模式,Databinding 是一種框架。DataBinding是一個實現數據和UI綁定的框架。而ViewModel和View可以通過DataBinding來實現單向綁定和雙向綁定,這套UI和數據之間的動態監聽和動態更新的框架 ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...