欧美一级特黄大片做受成人-亚洲成人一区二区电影-激情熟女一区二区三区-日韩专区欧美专区国产专区

ToolBar使用方法詳解

ToolBar的出現(xiàn)是為了替換之前的ActionBar的各種不靈活使用方式,相反,ToolBar的使用變得非常靈活,因為它可以讓我們自由往里面添加子控件.低版本要使用的話,可以添加support-v7包.

站在用戶的角度思考問題,與客戶深入溝通,找到大田網(wǎng)站設(shè)計與大田網(wǎng)站推廣的解決方案,憑借多年的經(jīng)驗,讓設(shè)計與互聯(lián)網(wǎng)技術(shù)結(jié)合,創(chuàng)造個性化、用戶體驗好的作品,建站類型包括:成都網(wǎng)站設(shè)計、成都網(wǎng)站制作、外貿(mào)網(wǎng)站建設(shè)、企業(yè)官網(wǎng)、英文網(wǎng)站、手機端網(wǎng)站、網(wǎng)站推廣、主機域名、網(wǎng)頁空間、企業(yè)郵箱。業(yè)務(wù)覆蓋大田地區(qū)。

今天要實現(xiàn)的效果如下:

ToolBar使用方法詳解

由上圖可以看到,toolBar的布局還是相對豐富的.要使用toolBar,首先為了兼容低版本,需要在gradle中引入支持庫

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


其次,我們還需要隱藏默認的ActionBar,否則會報如下錯誤:

Caused by: java.lang.IllegalStateException: This Activity already has an action bar
supplied by the window decor. Do not request Window.FEATURE_SUPPORT_ACTION_BAR and set
windowActionBar to false in your theme to use a Toolbar instead.

可以在res/value/style.xml中設(shè)置:

<resources>

  <!-- Base application theme. -->
  <style name="AppTheme" parent="AppTheme.Base"></style>

  <style name="AppTheme.Base" parent="Theme.AppCompat">
    <!--將ActionBar隱藏,這里使用ToolBar-->
    <item name="windowActionBar">false</item>
    <!-- 使用 API Level 22以上編譯的話,要拿掉前綴字 -->
    <item name="windowNoTitle">true</item>
    <!--colorPrimaryDark對應(yīng)狀態(tài)欄的顏色-->
    <item name="colorPrimaryDark">@color/statusColor</item>
    <!--colorPrimary 對應(yīng)ToolBar的顏色-->
    <item name="colorPrimary">@color/toolBarColor</item>
    <!--colorAccent 對應(yīng)EditText編輯時、RadioButton選中、CheckBox等選中時的顏色。-->
    <item name="colorAccent">@color/editColor</item>
    <!--窗口的顏色-->
    <item name="android:windowBackground">@color/widowColor</item>

  </style>

  <!--Status bar color-->
  <color name="statusColor">#ff0000</color>
  <!-- toolBar color -->
  <color name="toolBarColor">#0000ff</color>
  <!--EditText,RadioButton,CheckBox color-->
  <color name="editColor">#FD87A9</color>
  <!--Window color-->
  <color name="widowColor">#ffffff</color>

</resources>

從上面的style文件中,可以知道,手機狀態(tài)欄的顏色和ToolBar的顏色也是可以在style中配置的.然后在清單文件的application節(jié)點下需要確認使用的style是Android:theme=”@style/AppTheme”

ok,樣式配置完后,接著在res/layout/activity_main.xml中加入Toolbar控件.

<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
  xmlns:tools="http://schemas.android.com/tools"
  android:layout_width="match_parent"
  android:layout_height="match_parent"
  android:orientation="vertical"
  tools:context=".MainActivity">

  <!--
  ?attr/actionBarSize:表示根據(jù)屏幕的分辨率采用系統(tǒng)默認的高度
  如果低版本也要使用的話,則需要使用v7包的,否則只有api21上才能有效
  -->
  <android.support.v7.widget.Toolbar
    android:id="@+id/toolbar"
    android:layout_width="match_parent"
    android:layout_height="?attr/actionBarSize"
    android:background="?attr/colorPrimary">
    <!--添加Toolbar的子控件-->
    <Button
      android:id="@+id/btn_diy"
      android:layout_width="60dp"
      android:layout_height="wrap_content"
      android:layout_gravity="right"
      android:background="#80ffffff"
      android:text="自定義按鈕"
      android:textColor="#000000"
      android:textSize="11sp" />

    <TextView
      android:id="@+id/tv_title"
      android:layout_width="wrap_content"
      android:layout_height="match_parent"
      android:layout_gravity="center"
      android:gravity="center"
      android:text="首頁"
      android:textColor="@android:color/black"
      android:textSize="20sp" />
  </android.support.v7.widget.Toolbar>

  <TextView
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:gravity="center"
    android:text="@string/hello_world"
    android:textColor="@android:color/black"
    android:textSize="30sp" />


</LinearLayout>

再來看看MainActivity的代碼:

package blog.csdn.net.mchenys.toolbardemo;

import android.graphics.Color;
import android.graphics.Rect;
import android.graphics.drawable.ColorDrawable;
import android.os.Bundle;
import android.support.v7.app.AppCompatActivity;
import android.support.v7.widget.Toolbar;
import android.view.Gravity;
import android.view.Menu;
import android.view.MenuItem;
import android.view.View;
import android.view.ViewGroup;
import android.widget.PopupWindow;
import android.widget.Toast;
/**
 * Created by mChenys on 2016/5/29.
 */
public class MainActivity extends AppCompatActivity implements View.OnClickListener {

  Toolbar mToolbar;
  Toast mToast;
  PopupWindow mPopupWindow;

  @Override
  protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_main);
    mToast = Toast.makeText(this, "", Toast.LENGTH_SHORT);
    mToast.setGravity(Gravity.CENTER, 0, 0);

    mToolbar = (Toolbar) findViewById(R.id.toolbar);
    // App Logo
//    mToolbar.setLogo(R.drawable.app_icon);
    // 主標題,默認為app_label的名字
    mToolbar.setTitle("Title");
    mToolbar.setTitleTextColor(Color.YELLOW);
    // 副標題
    mToolbar.setSubtitle("Sub title");
    mToolbar.setSubtitleTextColor(Color.parseColor("#80ff0000"));
    //側(cè)邊欄的按鈕
    mToolbar.setNavigationIcon(R.drawable.back);
    //取代原本的actionbar
    setSupportActionBar(mToolbar);
    //設(shè)置NavigationIcon的點擊事件,需要放在setSupportActionBar之后設(shè)置才會生效,
    //因為setSupportActionBar里面也會setNavigationOnClickListener
    mToolbar.setNavigationOnClickListener(new View.OnClickListener() {
      @Override
      public void onClick(View v) {
        mToast.setText("click NavigationIcon");
        mToast.show();
      }
    });
    //設(shè)置toolBar上的MenuItem點擊事件
    mToolbar.setOnMenuItemClickListener(new Toolbar.OnMenuItemClickListener() {
      @Override
      public boolean onMenuItemClick(MenuItem item) {
        switch (item.getItemId()) {
          case R.id.action_edit:
            mToast.setText("click edit");
            break;
          case R.id.action_share:
            mToast.setText("click share");
            break;
          case R.id.action_overflow:
            //彈出自定義overflow
            popUpMyOverflow();
            return true;
        }
        mToast.show();
        return true;
      }
    });
    //ToolBar里面還可以包含子控件
    mToolbar.findViewById(R.id.btn_diy).setOnClickListener(new View.OnClickListener() {
      @Override
      public void onClick(View v) {
        mToast.setText("點擊自定義按鈕");
        mToast.show();
      }
    });
    mToolbar.findViewById(R.id.tv_title).setOnClickListener(new View.OnClickListener() {
      @Override
      public void onClick(View v) {
        mToast.setText("點擊自定義標題");
        mToast.show();
      }
    });
  }

  //如果有Menu,創(chuàng)建完后,系統(tǒng)會自動添加到ToolBar上
  @Override
  public boolean onCreateOptionsMenu(Menu menu) {
    super.onCreateOptionsMenu(menu);
    getMenuInflater().inflate(R.menu.menu_main, menu);
    return true;
  }

  /**
   * 彈出自定義的popWindow
   */
  public void popUpMyOverflow() {
    //獲取狀態(tài)欄高度
    Rect frame = new Rect();
    getWindow().getDecorView().getWindowVisibleDisplayFrame(frame);
    //狀態(tài)欄高度+toolbar的高度
    int yOffset = frame.top + mToolbar.getHeight();
    if (null == mPopupWindow) {
      //初始化PopupWindow的布局
      View popView = getLayoutInflater().inflate(R.layout.action_overflow_popwindow, null);
      //popView即popupWindow的布局,ture設(shè)置focusAble.
      mPopupWindow = new PopupWindow(popView,
          ViewGroup.LayoutParams.WRAP_CONTENT,
          ViewGroup.LayoutParams.WRAP_CONTENT, true);
      //必須設(shè)置BackgroundDrawable后setOutsideTouchable(true)才會有效
      mPopupWindow.setBackgroundDrawable(new ColorDrawable());
      //點擊外部關(guān)閉。
      mPopupWindow.setOutsideTouchable(true);
      //設(shè)置一個動畫。
      mPopupWindow.setAnimationStyle(android.R.style.Animation_Dialog);
      //設(shè)置Gravity,讓它顯示在右上角。
      mPopupWindow.showAtLocation(mToolbar, Gravity.RIGHT | Gravity.TOP, 0, yOffset);
      //設(shè)置item的點擊監(jiān)聽
      popView.findViewById(R.id.ll_item1).setOnClickListener(this);
      popView.findViewById(R.id.ll_item2).setOnClickListener(this);
      popView.findViewById(R.id.ll_item3).setOnClickListener(this);
    } else {
      mPopupWindow.showAtLocation(mToolbar, Gravity.RIGHT | Gravity.TOP, 0, yOffset);
    }

  }

  @Override
  public void onClick(View v) {
    switch (v.getId()) {
      case R.id.ll_item1:
        mToast.setText("哈哈");
        break;
      case R.id.ll_item2:
        mToast.setText("呵呵");
        break;
      case R.id.ll_item3:
        mToast.setText("嘻嘻");
        break;
    }
    //點擊PopWindow的item后,關(guān)閉此PopWindow
    if (null != mPopupWindow && mPopupWindow.isShowing()) {
      mPopupWindow.dismiss();
    }
    mToast.show();
  }
}

另外,我們的ToolBar控件還用到了menu item,下面是/res/menu/menu_main.xml的內(nèi)容:

<?xml version="1.0" encoding="utf-8"?>
<menu 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"
  tools:context=".MainActivity">

  <item
    android:id="@+id/action_edit"
    android:icon="@drawable/edit"
    android:orderInCategory="80"
    android:title="@string/action_edit"
    app:showAsAction="ifRoom" />

  <item
    android:id="@+id/action_share"
    android:icon="@drawable/share"
    android:orderInCategory="90"
    android:title="@string/action_share"
    app:showAsAction="ifRoom" />

  <item
    android:id="@+id/action_overflow"
    android:orderInCategory="100"
    android:title="@string/action_more"
    android:icon="@drawable/more"
    app:showAsAction="always" />


</menu>

還有PopWindow的布局,在/res/layout/action_overflow_popwindow.xml,內(nèi)容如下:

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
  android:layout_width="wrap_content"
  android:layout_height="wrap_content"
  android:background="#274B5E"
  android:orientation="vertical"
  android:padding="10dp">

  <LinearLayout
    android:id="@+id/ll_item1"
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    android:gravity="center">

    <ImageView
      android:layout_width="wrap_content"
      android:layout_height="wrap_content"
      android:src="@drawable/app_icon" />

    <TextView
      android:layout_width="wrap_content"
      android:layout_height="wrap_content"
      android:layout_marginLeft="10dp"
      android:text="哈哈"
      android:textColor="#ffffff"
      android:textSize="20sp" />
  </LinearLayout>

  <LinearLayout
    android:id="@+id/ll_item2"
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    android:gravity="center">

    <ImageView
      android:layout_width="wrap_content"
      android:layout_height="wrap_content"
      android:src="@drawable/app_icon" />

    <TextView
      android:layout_width="wrap_content"
      android:layout_height="wrap_content"
      android:layout_marginLeft="10dp"
      android:text="呵呵"
      android:textColor="#ffffff"
      android:textSize="20sp" />
  </LinearLayout>

  <LinearLayout
    android:id="@+id/ll_item3"
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    android:gravity="center">

    <ImageView
      android:layout_width="wrap_content"
      android:layout_height="wrap_content"
      android:src="@drawable/app_icon" />

    <TextView
      android:layout_width="wrap_content"
      android:layout_height="wrap_content"
      android:layout_marginLeft="10dp"
      android:text="嘻嘻"
      android:textColor="#ffffff"
      android:textSize="20sp" />
  </LinearLayout>
</LinearLayout>

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持創(chuàng)新互聯(lián)。

當前名稱:ToolBar使用方法詳解
文章網(wǎng)址:http://aaarwkj.com/article18/pdegdp.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站制作、網(wǎng)站建設(shè)、網(wǎng)站設(shè)計、標簽優(yōu)化移動網(wǎng)站建設(shè)、網(wǎng)站設(shè)計公司

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)

成都app開發(fā)公司
日本人妻伦理在线播放| 国产欧美色日韩综合在线| 国产精品青青在线观看爽香蕉| 国产黄色一区二区三区,| 日韩一区精品视频一区二区| 国产亚洲精品视频热| 九九精品在线观看视频| 日本一区二区欧美在线| 国产情色自拍在线观看| 成人黄色一级电影免费看| 九九在线视频免费观看精品视频| 不卡视频一区中文字幕| 成人av高清在线观看| 亚洲精品成人久久av| 亚洲性视频日韩性视频| 亚洲综合激情一区二区| 欧美精品亚洲精品日韩| 午夜射精视频在线观看| 五月综合丁香婷婷久久| 伊人亚洲一区二区三区| 亚洲av十八禁在线播放| 亚洲av毛片在线网站| 国产亚洲综合区成人国产| 久久精品久久黄色片看看| 91精品国产91久久综合桃花| 中文成人无字幕乱码精品| 欧美日韩国产精品久久乐播| 亚洲国产日本一区自拍| 日韩av黄色大片在线播看| 日韩欧美国产一区二区精品 | 麻豆专区一区二区三区| 午夜精品三级一区二区三区| 蜜臀av一区二区在线观看| 日韩精品人妻一区二区网站| 1区2区3区精品视频| 日韩有码一区在线观看| 中文欧美一区二区精品| 欧美精品熟妇乱黑人最大| 九九免费在线视频观看| 亚洲精品一区二区免费看| 黄色亚洲大片免费在线观看|