国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 系統 > Android > 正文

Android構建Material Design應用詳解

2020-02-21 17:22:12
字體:
來源:轉載
供稿:網友

Android的用戶界面并不漂亮,所以在很多IT公司在界面設計上,為了保證兩個平臺的統一,強烈要求Android端的界面風格必須與IOS端的一致,本文是武林技術頻道小編介紹的Android構建Material Design應用詳解,大家一起好好學習吧。

1.Toolbar

1.基本的Toolbar

Toolbar 控件是由 appcompat-v7 庫提供的,使用需要添加依賴:

compile 'com.android.support:appcompat-v7:25.3.1'

我們使用Toolbar來替代ActionBar,因此需要指定一個不帶ActionBar的主題,通常有Theme.AppCompat.NoActionBar (深色) 主題或者Theme.AppCompat.Light.NoActionBar (淡色) 主題這兩種主題可選。

Theme:

<!-- Base application theme. --><style name="AppTheme" parent="Theme.AppCompat.Light.NoActionBar"> <!-- Toolbar的顏色 --> <item name="colorPrimary">@color/colorPrimary</item> <!-- 通知欄的顏色 --> <item name="colorPrimaryDark">@color/colorPrimaryDark</item> <!-- 懸浮圖標等顏色,更多的表達了一種強調的意思,比如一些控件的選中狀態也會使用該顏色 --> <item name="colorAccent">@color/colorAccent</item></style>

Layout:

<android.support.design.widget.AppBarLayout android:layout_width="match_parent" android:layout_height="wrap_content" android:theme="@style/ThemeOverlay.AppCompat.Dark.ActionBar">  <android.support.v7.widget.Toolbar  android:id="@+id/toolbar"  android:layout_width="match_parent"  android:layout_height="?attr/actionBarSize"  android:background="?attr/colorPrimary"  android:theme="@style/ThemeOverlay.AppCompat.Dark.ActionBar"  app:popupTheme="@style/ThemeOverlay.AppCompat.Light"/>  </android.support.design.widget.AppBarLayout>

AppBarLayout 是一個垂直方向的 LinearLayout,它在內部做了很多滾動事件的封裝,并應用了一些 Material Design 的設計理念,AppBarLayout 解決了 在 FrameLayout 中 Toolbar 被遮擋的問題。

Activity:

Toolbar toolbar = (Toolbar) findViewById(R.id.toolbar);setSupportActionBar(toolbar);

2.RecyclerView向上滾動隱藏Toolbar

Toolbar 添加一行代碼 app:layout_scrollFlags="scroll|enterAlways|snap" 即可。

Layout:

<android.support.design.widget.AppBarLayout android:layout_width="match_parent" android:layout_height="wrap_content" android:theme="@style/ThemeOverlay.AppCompat.Dark.ActionBar"> <android.support.v7.widget.Toolbar  android:id="@+id/toolbar"  android:layout_width="match_parent"  android:layout_height="?attr/actionBarSize"  android:background="?attr/colorPrimary"  android:theme="@style/ThemeOverlay.AppCompat.Dark.ActionBar"  app:popupTheme="@style/ThemeOverlay.AppCompat.Light"  app:layout_scrollFlags="scroll|enterAlways|snap"/></android.support.design.widget.AppBarLayout><android.support.v7.widget.RecyclerView android:id="@+id/recycler_view" android:layout_width="match_parent" android:layout_height="match_parent" app:layout_behavior="@string/appbar_scrolling_view_behavior"/>

app:layout_behavior="@string/appbar_scrolling_view_behavior" 屬性則保證了 RecyclerView 遮擋 Toolbar 的問題。

2.懸浮按鈕和可交互提示

1.FloatingActionButton

FloatingActionButton 是由 design support 庫提供的,使用需要添加依賴:

compile 'com.android.support:design:25.3.1'

Layout:

<android.support.design.widget.FloatingActionButton android:id="@+id/fab" android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_gravity="bottom|end" android:layout_margin="16dp" android:src="@drawable/ic_circle"/>

2.Snackbar

Snackbar 是由 design support 庫提供的。Snackbar 的第一個參數需要傳入一個View,可以是當前界面布局的任意一個View,然后會使用這個View來自動查找最外層的布局,用于展示Snackbar。

Activity:

Snackbar.make(view, "This is Snackbar.", Snackbar.LENGTH_SHORT)  // 設置動作  .setAction("ok", new View.OnClickListener() {   @Override   public void onClick(View view) {    Toast.makeText(context, "onClick", Toast.LENGTH_SHORT);   }  }).show();

不過有一個bug,Snackbar和懸浮按鈕同時使用并且懸浮按鈕在界面右下角時,彈出的Snackbar會將懸浮按鈕給遮住,這種用戶體驗是不友好的,要解決這個問題只需要借助 CoordinatorLayout 就可以輕松解決。

3.CoordinatorLayout

Snackbar 是由 design support 庫提供的,CoordinatorLayout 可以說是加強版的 FrameLayout,CoordinatorLayout 可以監聽其所有子控件的各種事件,然后自動幫我們做出最為合理的響應,就比如剛才說的 Snackbar 那個bug,借助 CoordinatorLayout,就可以使得 Snackbar 向上偏移,從而確保不會被 Snackbar 遮擋住。

Layout:

<android.support.design.widget.CoordinatorLayout android:layout_width="match_parent" android:layout_height="match_parent"> <android.support.v7.widget.Toolbar  android:id="@+id/toolbar"  android:layout_width="match_parent"  android:layout_height="?attr/actionBarSize"  android:background="?attr/colorPrimary"  android:theme="@style/ThemeOverlay.AppCompat.Dark.ActionBar"  app:popupTheme="@style/ThemeOverlay.AppCompat.Light"/> <android.support.design.widget.FloatingActionButton  android:id="@+id/fab"  android:layout_width="wrap_content"  android:layout_height="wrap_content"  android:layout_gravity="bottom|end"  android:layout_margin="16dp"  android:src="@drawable/ic_circle"/></android.support.design.widget.CoordinatorLayout>

另外,由于 CoordinatorLayout 本身就是 加強版的 FrameLayout,所以替換 FrameLayout 也不會有任何的副作用。

3.卡片式布局

1.CardView

CardView 控件是由 cardview-v7 庫提供的,用于實現一個立體的卡片,提供了圓角、陰影等效果。使用需要添加依賴:

compile 'com.android.support:cardview-v7:25.3.1'

Layout:

<android.support.v7.widget.CardView android:layout_width="match_parent" android:layout_height="wrap_content" app:cardCornerRadius = "10dp" app:elevation="5dp" app:cardBackgroundColor="#71C3DE"> <TextView  android:layout_width="match_parent"  android:layout_height="wrap_content"  android:layout_gravity="center"  android:layout_margin="20dp"  android:text="CardView控件,可以設置陰影和圓角效果"/></android.support.v7.widget.CardView>

運行后效果圖如下:

4.全透明狀態欄

需要 Android 5.0及以上。

public class MainActivity extends AppCompatActivity { @Override protected void onCreate(Bundle savedInstanceState) {  super.onCreate(savedInstanceState);  if(Build.VERSION.SDK_INT >= Build.VERSION_CODES.LOLLIPOP) {   Window window = getWindow();   window.clearFlags(WindowManager.LayoutParams.FLAG_TRANSLUCENT_STATUS     | WindowManager.LayoutParams.FLAG_TRANSLUCENT_NAVIGATION);   window.getDecorView().setSystemUiVisibility(View.SYSTEM_UI_FLAG_LAYOUT_FULLSCREEN     | View.SYSTEM_UI_FLAG_LAYOUT_HIDE_NAVIGATION     | View.SYSTEM_UI_FLAG_LAYOUT_STABLE);   window.addFlags(WindowManager.LayoutParams.FLAG_DRAWS_SYSTEM_BAR_BACKGROUNDS);   window.setStatusBarColor(Color.TRANSPARENT);   window.setNavigationBarColor(Color.TRANSPARENT);  }  setContentView(R.layout.activity_main); }}

5.Material效果Dialog

1.AlertDialog

樣式效果向下兼容到 Android 2.1

new android.support.v7.app.AlertDialog.Builder(context)  .setTitle("AlertDialog")  .setMessage("Something important.")  .setCancelable(false) //設置點擊Dialog以外的界面不消失,按返回鍵也不起作用  .setPositiveButton("OK", new android.content.DialogInterface.OnClickListener() {   @Override   public void onClick(android.content.DialogInterface dialogInterface, int i) {   }  })  .setNegativeButton("Cancel", null)  .show();

2.ProgressDialog

樣式效果向下兼容到 Android 5.0

ProgressDialog progressDialog = new ProgressDialog(context);progressDialog.setTitle("ProgressDialog");progressDialog.setMessage("Loading..");progressDialog.setCancelable(true);progressDialog.show();

3.ripple_drawable資源

Android5.0 推出的 “水波漣漪”效果:

以上就是武林技術頻道小編介紹的關于Android構建Material Design應用詳解,建議大家好好品讀,相信對你是有用的。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 黑河市| 板桥市| 星子县| 仙居县| 类乌齐县| 伊春市| 津市市| 宁津县| 永胜县| 宁乡县| 闽侯县| 麻江县| 页游| 宿州市| 天柱县| 甘洛县| 涞水县| 特克斯县| 商都县| 和林格尔县| 常州市| 十堰市| 天门市| 如皋市| 黎平县| 阳泉市| 华蓥市| 天长市| 靖边县| 东至县| 阿荣旗| 延寿县| 曲阜市| 永年县| 涡阳县| 乌恰县| 平果县| 枞阳县| 开江县| 福海县| 汝南县|