Android开发 |
您所在的位置:网站首页 › toolbarmenu › Android开发 |
本篇笔记用来记录常用的Toolbar设置,如Toolbar颜色设置,显示返回按钮,显示右边三个点按钮 之前Android 使用的ActionBar,Android5.0开始,谷歌官方推荐使用Toolbar来代替ActionBar 最近慢慢开始使用上kotlin了,贴出的代码可能是kotlin的代码,见谅,如果有Java基础的,其实还蛮简单上手的,可以参考一下我的kotlin学习笔记 Kotlin学习笔记 1.使用Toolbar替换ActionBar我们首先将主题设置为NoActionBar,之后在布局xml文件添加ToolBar 由Android Manifest文件进入Theme,修改Theme
布局xml文件,添加Toolbar 之后,在Activity代码中,使用setSupportToolbar,把toolbar设置进去 setContentView(R.layout.activity_main); //findviewbyid找到toolbar实例 setSupportToolbar(toolbar);之后运行就可以看到结果了 2.修改标题文字默认的Toolbar显示的文字其实就是你当前APP项目的label,我们到AndroidManifest文件修改Activity的label属性,就可以达到修改文字的效果 上图中,我的APP有两个Activity,其中,MainActivity中的toolbar没有定义label属性,所以,默认label属性等于项目名,所有显示的是“星之小说下载器” 而另外的那个SettingActivity则有label属性,所有,显示的文字就是“设置” PS:如果不想要显示文字,则通过getSupportActionBar().setDisplayShowTitleEnabled(false)实现(在setSupportToolbar方法之后) 3.修改颜色 修改背景色修改背景颜色通过修改toolbar的background属性达到效果 修改标题文字颜色修改titleTextColor属性,需要引入app命名空间 4.显示左边返回按钮通过代码的方式显示左边的返回按钮 setSupportActionBar(toolbar) getSupportActionBar().setHomeButtonEnabled(true) getSupportActionBar().setDisplayHomeAsUpEnabled(true)Activity中还需要重写onOptionsItemSelected方法,点击返回按钮达到返回的效果 override fun onOptionsItemSelected(item: MenuItem?): Boolean { if(item.itemId == android.R.id.home){ finish() } return super.onOptionsItemSelected(item) }如果需要标题和返回按钮为白色,在toolbar控件添加下面的两行属性 app:theme="@style/ThemeOverlay.AppCompat.Dark.ActionBar" app:popupTheme="@style/ThemeOverlay.AppCompat.Light" 5.显示Toolbar的菜单按钮 1.创建menu.xml在res目录下创建一个menu的文件夹,之后在menu文件夹中新建一个menu.xml title 标题 icon 图标 showAsAction 此属性有几个选择 always:这个值会使菜单项一直显示在Action Bar上。 ifRoom:如果有足够的空间,这个值会使菜单项显示在Action Bar上。 never:这个值使菜单项永远都不出现在Action Bar上。 withText:这个值使菜单项和它的图标,菜单文本一起显示。 2.重写onCreateMenu方法重写Activity中的onCreateMenu的方法,把menu.xml文件装载到APP中 override fun onCreateOptionsMenu(menu: Menu?): Boolean { menuInflater.inflate(R.menu.menu,menu) return true } 3.重写opOptionSelect方法设置每个菜单的点击事件,与设置监听器操作类似 override fun onOptionsItemSelected(item: MenuItem?): Boolean { if (item?.itemId ==R.id.menu_setting) { startActivity(SettingActivity::class.java) } return false } 4.setSupportToolbar和之前的步骤一样 |
CopyRight 2018-2019 办公设备维修网 版权所有 豫ICP备15022753号-3 |