安卓介面之Toolbar上手
阿新 • • 發佈:2019-01-05
一.在配置檔案採用自定義Style方法去除Actionbar
<resources> <style name="MyTheme" parent="Theme.AppCompat.Light.DarkActionBar"> <!-- Customize your theme here. --> <item name="colorPrimary">@color/colorPrimary</item> <item name="colorPrimaryDark">@color/colorPrimaryDark</item> <item name="colorAccent">@color/colorAccent</item> <!--去除Actionbar--> <item name="windowActionBar">false</item> <item name="windowNoTitle">true</item> <!--toolbar選單顏色設定--> <item name="android:textColorSecondary">#ffff</item> </style> </resources>
二.XML檔案中新增Toolbar
<android.support.v7.widget.Toolbar android:id="@+id/tb_id" android:layout_width="match_parent" android:layout_height="?android:attr/actionBarSize" android:background="?attr/colorPrimary" app:titleTextColor="@color/colorwhite" ></android.support.v7.widget.Toolbar>
三.在java程式碼中新增Toolbar
public class MainActivity extends AppCompatActivity { @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); initTools(); } //新增Toolbar private void initTools() { android.support.v7.widget.Toolbar mtoolbar=findViewById(R.id.tb_id);
//設定Toolbar選單點選事件 mtoolbar.setOnMenuItemClickListener(new Toolbar.OnMenuItemClickListener() { @Override public boolean onMenuItemClick(MenuItem menuItem) { switch (menuItem.getItemId()) { case R.id.one: { Toast.makeText(MainActivity.this, "我是1", Toast.LENGTH_SHORT).show(); break; } case R.id.two: { Toast.makeText(MainActivity.this, "我是2", Toast.LENGTH_SHORT).show(); break; } case R.id.three: { Toast.makeText(MainActivity.this, "我是3", Toast.LENGTH_SHORT).show(); break; } } return true; } }); setSupportActionBar(mtoolbar); }
// 建立Toolbar選單
//R.menu.menu是一個定義選單選項的XMl檔案,在第四步中說明 @Override public boolean onCreateOptionsMenu(Menu menu) { getMenuInflater().inflate(R.menu.menu,menu); return super.onCreateOptionsMenu(menu); }
}
四.menu選項選單選項設定
通過在res目錄下新建menu目錄,並在該目錄下新增Menu resourse file(其實就是一個XML檔案),然後就可以定義想要的選項.
<?xml version="1.0" encoding="utf-8"?> <menu xmlns:android="http://schemas.android.com/apk/res/android" > <item android:id="@+id/one" android:title="one" /> <item android:id="@+id/two" android:title="two" /> <item android:id="@+id/three" android:title="three" /> </menu>