使用toobar实现知乎首页样式(新特性
效果
图片来自http://www.jianshu.com/p/79604c3ddcae
ToolBar简介
ToolBar是Android
5.0推出的一个新的导航控件用于取代之前的ActionBar,由于其高度的可定制性、灵活性、具有MaterialDesign风格等优点,越来越多的应用也用上了ToolBar,比如常用的知乎软件其顶部导航栏正是使用ToolBar。官方考虑到仍有一部分用户的手机版本号低于5.0,所以,ToolBar也放进了supportv7包内,使得低版本的系统也能使用上ToolBar。本文将使用supportv7支持包的ToolBar来进行讲解,包括其基本用法、样式定制等知识点。
使用方式
1,引入support v7支持包
在你项目的build.gradle内输入如下代码,即能引入支持包,该支持包内有能向下兼容的ToolBar:
dependencies {
compile fileTree(dir: 'libs', include: ['*.jar'])
compile 'com.android.support:appcompat-v7:23.1.1'
}
2,在布局中添加
`
android:id="@+id/toolbar"
android:layout_width="match_parent"
android:layout_height="?attr/actionBarSize"
android:background="?attr/colorPrimary">
`
3,在activity进行设置
public class ToolbarActivity extends AppCompatActivity {
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_toolbar);
Toolbar toolbar = (Toolbar) findViewById(R.id.toolbar);
setSupportActionBar(toolbar);
getSupportActionBar().setDisplayShowTitleEnabled(false);
toolbar.setTitle("主标题");
toolbar.setTitleTextColor(getResources().getColor(R.color.colorPrimaryDark));
toolbar.setSubtitle("副标题");
toolbar.setLogo(R.mipmap.ic_launcher);
toolbar.setOnLongClickListener(new View.OnLongClickListener() {
@Override
public boolean onLongClick(View v) {
Toast.makeText(ToolbarActivity.this, "logo", Toast.LENGTH_SHORT).show();
return false;
}
});
toolbar.setNavigationIcon(android.R.drawable.ic_input_delete);
toolbar.setNavigationOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
Toast.makeText(ToolbarActivity.this, "图标点击", Toast.LENGTH_SHORT).show();
}
});
}
@Override
public boolean onCreateOptionsMenu(Menu menu) {
// Inflate the menu; this adds items to the action bar if it is present.
getMenuInflater().inflate(R.menu.menu_main, menu);
return true;
}
@Override
public boolean onOptionsItemSelected(MenuItem item) {
switch (item.getItemId()) {
case R.id.action_edit:
Toast.makeText(this, "查找按钮", Toast.LENGTH_SHORT).show();
break;
case R.id.action_share:
Toast.makeText(this, "分享按钮", Toast.LENGTH_SHORT).show();
break;
}
return false;
}
}
具体实现请访问giithub链接https://github.com/yxwandroid/AndroidSummary/blob/master/ToolBar5/app/src/main/java/willson/activity/ToolbarActivity.java
参考