转载请注明出处:http://blog.csdn.net/guolin_blog/article/details/26365683
经过前面两篇文章的学习,我想大家对ActionBar都已经有一个相对较为深刻的理解了。唯一欠缺的是,前面我们都只是学习了理论知识而已,虽然知识点已经掌握了,但是真正投入到项目实战当中时会不会掉链子还很难说。那么不用担心,本篇文章我就将带领大家一起进入ActionBar的应用实战,将理论和实践完美结合到一起。
如果你还没有看过我的前两篇文章,建议先去阅读一下 Android ActionBar完全解析,使用官方推荐的最佳导航栏(上) 和 Android ActionBar完全解析,使用官方推荐的最佳导航栏(下) 。
相信大家都会认定微信是在手机上最火的应用程序了,几乎每个人的手机上都有安装它。微信除了功能非常强大之外,界面也是做得相当美观,它的ActionBar让人看着有一种赏心悦目的感觉,如下图所示:
作为手机应用程序中的技术标杆,我们自然应该多多向微信学习,那么今天实战的主题,就是模仿微信主界面的实现。
首先新建一个Android项目,起名叫作WeChatSample。既然是要实现ActionBar,那么第一步当然就是编辑menu目录下的main.xml文件了,代码如下所示:
- <menu xmlns:android="http://schemas.android.com/apk/res/android"
- xmlns:tools="http://schemas.android.com/tools"
- tools:context="com.example.wechatsample.MainActivity" >
- <item
- android:id="@+id/action_search"
- android:actionViewClass="android.widget.SearchView"
- android:icon="@drawable/actionbar_search_icon"
- android:showAsAction="ifRoom|collapseActionView"
- android:title="@string/action_search"/>
- <item
- android:id="@+id/action_plus"
- android:actionProviderClass="com.example.wechatsample.PlusActionProvider"
- android:icon="@drawable/actionbar_add_icon"
- android:showAsAction="ifRoom"
- android:title="@string/action_plus"/>
- <item
- android:id="@+id/action_album"
- android:icon="@drawable/ofm_photo_icon"
- android:title="@string/action_album"/>
- <item
- android:id="@+id/action_collection"
- android:icon="@drawable/ofm_collect_icon"
- android:title="@string/action_collection"/>
- <item
- android:id="@+id/action_card"
- android:icon="@drawable/ofm_card_icon"
- android:title="@string/action_card"/>
- <item
- android:id="@+id/action_settings"
- android:icon="@drawable/ofm_setting_icon"
- android:title="@string/action_settings"/>
- <item
- android:id="@+id/action_feed"
- android:icon="@drawable/ofm_feedback_icon"
- android:title="@string/action_feed"/>
- </menu>
观察上面的main.xml,你会发现里面有一个自定义的Action Provider,叫作PlusActionProvider。这个主要是用于模拟微信中那个加号的子菜单的,下面我们就来实现这个类:
- public class PlusActionProvider extends ActionProvider {
- private Context context;
- public PlusActionProvider(Context context) {
- super(context);
- this.context = context;
- }
- @Override
- public View onCreateActionView() {
- return null;
- }
- @Override
- public void onPrepareSubMenu(SubMenu subMenu) {
- subMenu.clear();
- subMenu.add(context.getString(R.string.plus_group_chat))
- .setIcon(R.drawable.ofm_group_chat_icon)
- .setOnMenuItemClickListener(new OnMenuItemClickListener() {
- @Override
- public boolean onMenuItemClick(MenuItem item) {
- return true;
- }
- });
- subMenu.add(context.getString(R.string.plus_add_friend))
- .setIcon(R.drawable.ofm_add_icon)
- .setOnMenuItemClickListener(new OnMenuItemClickListener() {
- @Override
- public boolean onMenuItemClick(MenuItem item) {
- return false;
- }
- });
- subMenu.add(context.getString(R.string.plus_video_chat))
- .setIcon(R.drawable.ofm_video_icon)
- .setOnMenuItemClickListener(new OnMenuItemClickListener() {
- @Override
- public boolean onMenuItemClick(MenuItem item) {
- return false;
- }
- });
- subMenu.add(context.getString(R.string.plus_scan))
- .setIcon(R.drawable.ofm_qrcode_icon)
- .setOnMenuItemClickListener(new OnMenuItemClickListener() {
- @Override
- public boolean onMenuItemClick(MenuItem item) {
- return false;
- }
- });
- subMenu.add(context.getString(R.string.plus_take_photo))
- .setIcon(R.drawable.ofm_camera_icon)
- .setOnMenuItemClickListener(new OnMenuItemClickListener() {
- @Override
- public boolean onMenuItemClick(MenuItem item) {
- return false;
- }
- });
- }
- @Override
- public boolean hasSubMenu() {
- return true;
- }
- }
接着修改MainActivity中的代码,如下所示:
- public class MainActivity extends Activity {