ToolBar封装策略

作者: TheShy_ | 来源:发表于2018-04-03 15:52 被阅读123次

效果:


执行效果

策略一: 使用原生toolbar进行封装

流程:

* 1所有的类都继承此AppToolBarActivity.

* 2打气筒加载一个布局到根布局(即layout_toolbar),此布局包含ToolBar+Framelayout.

* 3getContentView()为抽象方法,返回一个View 将此View add到framelayout中.

* 4做一些ToolBar的初始化操作.

* 5使用
    @Override
    protected void onCreate(@Nullable Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        View view = LayoutInflater.from(this).inflate(R.layout.layout_toolbar, (ViewGroup) getWindow().getDecorView().getRootView(), false);
        mContent_frame = view.findViewById(R.id.content_frame);
        if(getContentView() != null){
            mContent_frame.addView(getContentView());
        }
        setContentView(view);

        ButterKnife.bind(this);
        steepTitle();
        setSupportActionBar(mToolbar);
        getSupportActionBar().setTitle("");
        getSupportActionBar().setDisplayHomeAsUpEnabled(true);
        getSupportActionBar().setDisplayShowHomeEnabled(true);
        setTitle(getTitle());

        initWidget();
        initData();
    }
  • 处理ToolBar的返回事件:
    //style.xml中
    <item name="android:homeAsUpIndicator">@mipmap/back_white</item>
    //AppToolBarActivity中
    @Override
    public boolean onOptionsItemSelected(MenuItem item) {
        if(item.getItemId() == android.R.id.home){
            onBackPressed();
        }
        return super.onOptionsItemSelected(item);
    }
  • 处理中间Title 重写setTitle()
    //bar 中间标题
    @Override
    public void setTitle(CharSequence title) {
        mToolbar_tv_title.setText(title);
        mRadioGroup.setVisibility(View.GONE);
    }   
  • 处理右侧可能是文字或图片按钮 中间可能是多按钮
    //bar右侧是文字
    protected void setRightTextButtonEnable(@StringRes int rid, View.OnClickListener onClickListener) {
        mTv_title_right.setText(rid);
        mTv_title_right.setOnClickListener(onClickListener);
        mTv_title_right.setVisibility(View.VISIBLE);
    }
    
    //bar右侧是图标
    protected void setRightImageButtonEnable(@DrawableRes int rid, View.OnClickListener onClickListener) {
        mIv_title_right.setImageResource(rid);
        mIv_title_right.setOnClickListener(onClickListener);
        mIv_title_right.setVisibility(View.VISIBLE);
        mTv_title_right.setVisibility(View.GONE);

    }

    //bar中间是多按钮
    protected void setCenterRadioGroupEnable(String btnLefttext,String btnRighttext, RadioGroup.OnCheckedChangeListener onClickListener) {
        mRadioBtnLeft.setText(btnLefttext);
        mRadioBtnRight.setText(btnRighttext);
        mRadioGroup.setOnCheckedChangeListener(onClickListener);
        mRadioGroup.setVisibility(View.VISIBLE);
        mToolbar_tv_title.setVisibility(View.GONE);
    }
    
  • 处理所谓的沉浸式
    //加载沉浸式状态栏
    public void steepTitle() {
        if (Build.VERSION.SDK_INT >= 21) {
            getWindow().addFlags(WindowManager.LayoutParams.FLAG_DRAWS_SYSTEM_BAR_BACKGROUNDS);
            //注意要清除 FLAG_TRANSLUCENT_STATUS flag
            getWindow().clearFlags(WindowManager.LayoutParams.FLAG_TRANSLUCENT_STATUS);
            getWindow().setStatusBarColor(getResources().getColor(R.color.maincolor));
        }
    }
   
  • 最后使用超简单:
    @Override
    protected View getContentView() {
        return initRId(R.layout.activity_main);
    }

    @Override
    protected void initWidget() {
        setBackEnable(false);
        setTitle("主页");
    }

github地址传送门

策略2:自己写一个Bar 使用重载方法初始化

  • 核心代码:
    protected void initAppBar() {
        initAppBar(true, false, -1, -1);
    }

    protected void initAppBar(boolean isBack) {
        initAppBar(isBack, false, -1, -1);
    }

    protected void initAppBar(boolean isBack, boolean isRightText) {
        initAppBar(isBack, isRightText, -1, -1);
    }

    protected void initAppBar(boolean isBack, boolean isRightText, @ColorRes int bgColor, @ColorRes int textColor) {
        //动态添加appbar 这样无需在每个xml中includ进去appbar的布局
        //如果不写这四行 需要在每个xml中incloud进去bar布局
        ViewGroup view = getWindow().getDecorView().findViewById(android.R.id.content);
        ViewGroup inflate = (ViewGroup) view.getChildAt(0);
        View barView = getLayoutInflater().inflate(R.layout.common_appbar, inflate,false);
        inflate.addView(barView,0);

        RelativeLayout layout = findViewById(R.id.common_appbar_rl);
        if (layout == null) {
            return;
        }
        invadeStatusBar();
        if (bgColor != -1) {
            layout.setBackgroundResource(bgColor);
        }
        LinearLayout.LayoutParams layoutParams = (LinearLayout.LayoutParams) layout.getLayoutParams();
        if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.LOLLIPOP) {
            layoutParams.setMargins(0, getStatusBarHeight(), 0, 0);
        } else {
            layoutParams.setMargins(0, 0, 0, 0);
        }
        layout.setLayoutParams(layoutParams);
        ImageView iconIV = findViewById(R.id.common_appbar_iv);
        if (!isBack) {
            iconIV.setVisibility(View.GONE);
        } else {
            iconIV.setVisibility(View.VISIBLE);
            iconIV.setOnClickListener(new View.OnClickListener() {
                @Override
                public void onClick(View v) {
                    finish();
                }
            });
        }
        TextView centerTV = findViewById(R.id.common_appbar_center_tv);
        if (textColor != -1) {
            centerTV.setTextColor(getResources().getColor(textColor));
        }
        centerTV.setText(TypeUtil.isBlank(setAppBarTitle()) ? "" : setAppBarTitle());
        TextView rightTV = findViewById(R.id.common_appbar_right_tv);
        if (!isRightText) {
            rightTV.setVisibility(View.GONE);
        } else {
            rightTV.setVisibility(View.VISIBLE);
            if (textColor != -1) {
                centerTV.setTextColor(getResources().getColor(textColor));
            }
            rightTV.setText(TypeUtil.isBlank(setAppBarRightTitle()) ? "" : setAppBarRightTitle());
            rightTV.setOnClickListener(new View.OnClickListener() {
                @Override
                public void onClick(View v) {
                    onAppBarRightClick();
                }
            });
        }
    }
  • 重载方法:
    protected abstract String setAppBarTitle();

    protected abstract String setAppBarRightTitle();

    protected abstract void onAppBarRightClick();
  • 使用:
  initAppBar(true,true);

  @Override
    protected String setAppBarTitle() {
        return "Tactics2";
    }

    @Override
    protected String setAppBarRightTitle() {
        return "更多";
    }

    @Override
    protected void onAppBarRightClick() {
        ToastUtil.showToast("更多");
    }

最后安利一个小技巧:

  • Activity跳转时候,可以这么写,更舒服:
    //只需要在目标Activity敲下start 就会出现自带的方法,可以传递一些数据:
    public static void start(Context context, String id) {
        Intent starter = new Intent(context, TacticsOneActivity.class);
        starter.putExtra("id", id);
        context.startActivity(starter);
    }

    //在执行跳转的某按钮处,只需简短一句:
    XxxActivity.start(this,"1");
  • 同理Fragment:
    //只需要在目标Fragment敲下newI :
    public static ChargeRecordFragment newInstance(int type,String coinName,String coinDetailName) {
        Bundle args = new Bundle();
        args.putInt("type",type);
        args.putString("coinName",coinName);
        args.putString("coinDetailName",coinDetailName);
        ChargeRecordFragment fragment = new ChargeRecordFragment();
        fragment.setArguments(args);
        return fragment;
    }
    //Activity的某处拿到实例并传递数据:
    ChargeRecordFragment.newInstance(0,mCoinName,mCoinDetailName);

相关文章

  • ToolBar封装策略

    效果: 策略一: 使用原生toolbar进行封装 流程: 处理ToolBar的返回事件: 处理中间Title 重写...

  • Design之Toolbar的使用

    ToolBar封装在BaseActivity(包括菜单menu) Toolbar中修改menu菜单字体大小和颜色 ...

  • AppCompatActivity与toolbar的结合,封装B

    转载:toolbar结合BaseActivity简单封装github下载地址 AppCompatActivity与...

  • ToolBar 的封装

    ToolBar的封装主要是利用ViewGroup把自定义的 View一个个加进去。首先我们先定义一个Toobar....

  • ToolBar项目封装使用

    欢迎大家访问我的博客:博客地址 概述 继承关系: 其实toolbar就是一个封装好的ViewGroup,其主要五大...

  • Android-4 Kotlin封装Toolbar

    上篇文章实现了Tab选项卡,那么本篇文章就封装下Toolbar,至于Toolbar是什么,能做什么大家可以去看看D...

  • Toolbar消除默认左边距

    最近在项目中用Toolbar封装标题栏,替换之前的Linearlayout,遇到了设置Navigationicon...

  • Android 自定义Toolbar

    封装下基本功能:返回键,title,功能键等。 CustomToolbar Alias toolbar.xml 自...

  • Android资源 - 收藏集 - 掘金

    我一行代码都不写实现Toolbar!你却还在封装BaseActivity? - 掘金原文地址: https://j...

  • toolbar总结及简单封装

    Android3.0之后,Google引入了ActionBar,想统一安卓应用的导航栏样式。但由于ActionBa...

网友评论

    本文标题:ToolBar封装策略

    本文链接:https://www.haomeiwen.com/subject/faqchftx.html