CoordinatorLayout AppBarLayout 标题渐变 悬浮

先直接上图看效果:

WeChat_20170916214217_20170916214334.gif

项目需求:

滑动的时候标题渐变颜色,并且左右两边的图片渐变切换。并且Toolbar能够悬浮置顶,查阅了一些资料有用ScrollView实现 有用CoordinatorLayout +AppBarLayout +CollapsingToolbarLayout +Toolbar 实现,没错我用的就是后者,其实实现了也就是这么回事,蛮简单的。

所以写下博客,一个是帮助其他小伙伴,另外一个是记录下自己的菜鸟成长之路吧。也决定之后有空了,把自己过去在项目中遇到的问题都记录下来,做成笔记。

实现原理:

为什么要用CoordinatorLayout CollapsingToolbarLayout是用来对Toolbar进行再次包装的ViewGroup,主要是用于实现折叠(其实就是看起来像伸缩~)的App Bar效果。它需要放在AppBarLayout布局里面,并且作为AppBarLayout的直接子View。就不做过多解释了不懂的可以看下这边文章 玩转AppBarLayout更酷炫的顶部栏

贴上代码:

<?xml version="1.0" encoding="utf-8"?>
<layout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto">

    <data>

        <variable
            name="ShopDetailsAcitvity"
            type="com.example.youjia.shopping.MainActivity" />
    </data>

    <LinearLayout
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:orientation="vertical">

        <android.support.design.widget.CoordinatorLayout
            android:layout_width="match_parent"
            android:layout_height="0dp"
            android:layout_weight="1">

            <android.support.design.widget.AppBarLayout
                android:id="@+id/app_bar"
                android:layout_width="match_parent"
                android:layout_height="wrap_content">

                <android.support.design.widget.CollapsingToolbarLayout
                    android:id="@+id/toolbar_layout"
                    android:layout_width="match_parent"
                    android:layout_height="wrap_content"
                    android:background="#f7f7f7"
                    app:contentScrim="?attr/colorPrimary"
                    app:layout_scrollFlags="scroll|exitUntilCollapsed">


                    <RelativeLayout
                        android:layout_width="match_parent"
                        android:layout_height="wrap_content"
                        android:background="@color/view"
                        android:orientation="vertical">


                        <RelativeLayout
                            android:id="@+id/banner_layout"
                            android:layout_width="match_parent"
                            android:layout_height="264dp"
                            android:orientation="vertical">

                            <com.youth.banner.Banner
                                android:id="@+id/banner"
                                android:layout_width="match_parent"
                                android:layout_height="match_parent"
                                app:image_scale_type="center_crop"
                                app:indicator_drawable_selected="@mipmap/banner_red"
                                app:indicator_drawable_unselected="@mipmap/banner_grey"
                                app:indicator_height="9dp"
                                app:indicator_margin="3dp"
                                app:indicator_width="9dp"
                                app:is_auto_play="true" />

                            <View
                                style="@style/View"
                                android:layout_alignParentBottom="true" />
                        </RelativeLayout>

                        <RelativeLayout
                            android:id="@+id/relativelayout_goods"
                            android:layout_width="match_parent"
                            android:layout_height="wrap_content"
                            android:layout_below="@+id/banner_layout"
                            android:background="@color/white"
                            android:gravity="center_vertical"
                            android:paddingBottom="12dp"
                            android:paddingLeft="13.3dp"
                            android:paddingRight="13.3dp"
                            android:paddingTop="12dp">

                            <TextView
                                android:text="禄福来精品翡翠"
                                android:id="@+id/shop_details_1"
                                android:layout_width="wrap_content"
                                android:layout_height="wrap_content"
                                android:lineSpacingExtra="5dp"
                                android:textColor="#282828"
                                android:textSize="16sp" />

                            <TextView
                                android:text="¥399.00"
                                android:id="@+id/shop_details_2"
                                android:layout_width="wrap_content"
                                android:layout_height="wrap_content"
                                android:layout_below="@+id/shop_details_1"
                                android:layout_marginTop="10dp"
                                android:textColor="#e75446"
                                android:textSize="16sp" />

                            <TextView
                                android:text="原价¥500.00"
                                android:id="@+id/shop_details_3"
                                android:layout_width="wrap_content"
                                android:layout_height="wrap_content"
                                android:layout_below="@+id/shop_details_2"
                                android:layout_marginTop="10dp"
                                android:textColor="#999999"
                                android:textSize="12sp" />
                            <!--android:layout_alignBottom="@+id/shop_details_2"-->
                            <TextView
                                android:text="月销8238笔"
                                android:id="@+id/sumSotre"
                                android:layout_width="wrap_content"
                                android:layout_height="wrap_content"
                                android:layout_alignParentBottom="true"
                                android:layout_alignParentRight="true"
                                android:textColor="#656565"
                                android:textSize="14sp" />


                        </RelativeLayout>



                        <LinearLayout
                            android:id="@+id/linearLayout_goods"
                            android:layout_width="match_parent"
                            android:layout_height="46.3dp"
                            android:layout_alignParentStart="true"
                            android:layout_below="@+id/relativelayout_goods"
                            android:layout_marginTop="19dp"
                            android:background="@drawable/ripple_item_white_bg"
                            android:gravity="center_vertical"
                            android:orientation="vertical">

                            <TextView
                                android:layout_width="wrap_content"
                                android:layout_height="wrap_content"
                                android:layout_marginLeft="13dp"
                                android:layout_weight="1"
                                android:gravity="center_vertical"
                                android:text="选择:商品规格"
                                android:textColor="#282828"
                                android:textSize="15.3sp" />

                            <View style="@style/View" />

                        </LinearLayout>


                    </RelativeLayout>
                    <android.support.v7.widget.Toolbar
                        android:id="@+id/toolbaretail"
                        android:layout_width="match_parent"
                        android:layout_height="70dp"
                        app:layout_collapseMode="pin"
                        android:fitsSystemWindows="true"
                        android:paddingTop="15dp"
                        app:popupTheme="@style/ThemeOverlay.AppCompat.Dark" >

                        <ImageView
                            android:src="@mipmap/share_shop"
                            android:id="@+id/share_img"
                            android:layout_gravity="center|right"
                            android:layout_marginRight="15dp"
                            android:layout_marginTop="5dp"
                            android:layout_width="wrap_content"
                            android:layout_height="match_parent" />
                    </android.support.v7.widget.Toolbar>
                </android.support.design.widget.CollapsingToolbarLayout>

                <android.support.design.widget.TabLayout
                    android:id="@+id/infoPhoneTabLayou"
                    app:tabTextColor="#989898"
                    app:tabSelectedTextColor="#e91b04"
                    app:tabIndicatorColor="@color/tablayout"
                    app:tabBackground="@drawable/ripple_tab_bg"
                    android:layout_width="match_parent"
                    android:layout_height="wrap_content"  >

                </android.support.design.widget.TabLayout>

                <View
                    android:background="@color/view"
                    android:layout_width="match_parent"
                    android:layout_height="1dp"/>
            </android.support.design.widget.AppBarLayout>


            <android.support.v4.widget.NestedScrollView
                android:id="@+id/NestedScrollView"
                android:layout_width="match_parent"
                android:layout_height="match_parent"
                android:overScrollMode="always"
                app:layout_behavior="@string/appbar_scrolling_view_behavior">



                    <com.example.youjia.shopping.WrapContentHeightViewPager
                        android:id="@+id/infoPhone_Fragment_pager"
                        android:layout_width="match_parent"
                        android:layout_height="wrap_content"
                        />


            </android.support.v4.widget.NestedScrollView>


        </android.support.design.widget.CoordinatorLayout>

        <LinearLayout
            android:layout_width="match_parent"
            android:layout_height="50dp"
            android:layout_alignParentBottom="true"
            android:background="@color/white"
            android:gravity="center_vertical"
            android:orientation="horizontal">

            <TextView
                android:layout_width="match_parent"
                android:layout_height="wrap_content"
                android:layout_weight="1.2"
                android:background="@drawable/ripple_item_white_bg"
                android:drawablePadding="2dp"
                android:drawableTop="@mipmap/shop_details_3"
                android:gravity="center_horizontal"
                android:text="店铺"
                android:textColor="#656565"
                android:textSize="10sp" />

            <TextView
                android:layout_width="match_parent"
                android:layout_height="wrap_content"
                android:layout_weight="1.2"
                android:background="@drawable/ripple_item_white_bg"
                android:drawablePadding="2dp"
                android:drawableTop="@mipmap/shop_details_4"
                android:gravity="center_horizontal"
                android:text="进货单"
                android:textColor="#656565"
                android:textSize="10sp" />

            <TextView
                android:layout_width="match_parent"
                android:layout_height="match_parent"
                android:layout_gravity="center_vertical"
                android:layout_weight="1"
                android:background="#ff6554"
                android:drawablePadding="5dp"
                android:gravity="center"
                android:text="加入进货单"
                android:textColor="#ffffff" />

            <TextView
                android:layout_width="match_parent"
                android:layout_height="match_parent"
                android:layout_gravity="center_vertical"
                android:layout_weight="1"
                android:background="#ff334c"
                android:drawablePadding="5dp"
                android:gravity="center"
                android:text="立即采购"
                android:textColor="#ffffff" />
        </LinearLayout>
    </LinearLayout>
</layout>



package com.example.youjia.shopping;

import android.databinding.DataBindingUtil;
import android.graphics.Color;
import android.graphics.Paint;
import android.support.design.widget.AppBarLayout;
import android.support.design.widget.TabLayout;
import android.support.v4.app.Fragment;
import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.view.Gravity;


import com.example.youjia.shopping.databinding.ActivityMainBinding;

import java.util.ArrayList;
import java.util.List;


public class MainActivity extends AppCompatActivity {
    private ActivityMainBinding mBinding;
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
         mBinding  = DataBindingUtil.setContentView(this,R.layout.activity_main);
        mBinding.setShopDetailsAcitvity(this);
        mBinding.shopDetails3.getPaint().setFlags(Paint. STRIKE_THRU_TEXT_FLAG);
        TabLayout();
        initBanner();
        setToolBar();
    }

    /**
     * 初始化轮播图
     */
    private void initBanner() {
        List<Integer> integers = new ArrayList<>();
        integers.add(R.drawable.img1);
        integers.add(R.drawable.img2);
        integers.add(R.drawable.img3);
//        integers.add(R.drawable.img4);
//        integers.add(R.drawable.img5);
//        integers.add(R.drawable.img6);
//        integers.add(R.drawable.img7);

        mBinding.banner.startAutoPlay();
        mBinding.banner.setDelayTime(2000);
        mBinding.banner.setImages(integers).setImageLoader(new GlideImageLoader()).start();
    }

    /**
     * 初始化setToolBar
     */
    private void setToolBar(){
        setSupportActionBar(mBinding.toolbaretail);
        mBinding.toolbaretail.setTitleTextColor(Color.WHITE);
        mBinding.toolbarLayout.setTitleEnabled(false);
        mBinding.toolbarLayout.setExpandedTitleGravity(Gravity.CENTER);//设置展开后标题的位置
        mBinding.toolbarLayout.setCollapsedTitleGravity(Gravity.CENTER);//设置收缩后标题的位置
        mBinding.toolbarLayout.setExpandedTitleColor(Color.WHITE);//设置展开后标题的颜色
        mBinding.toolbarLayout.setCollapsedTitleTextColor(Color.WHITE);//设置收缩后标题的颜色
        mBinding.appBar.addOnOffsetChangedListener(new AppBarLayout.OnOffsetChangedListener() {
            @Override
            public void onOffsetChanged(AppBarLayout appBarLayout, int verticalOffset) {
                //verticalOffset  当前偏移量 appBarLayout.getTotalScrollRange() 最大高度 便宜值
                int Offset = Math.abs(verticalOffset); //目的是将负数转换为绝对正数;
                //标题栏的渐变
                mBinding.toolbaretail.setBackgroundColor(changeAlpha(getResources().getColor(R.color.redcustom)
                        , Math.abs(verticalOffset * 1.0f) / appBarLayout.getTotalScrollRange()));

                /**
                 * 当前最大高度便宜值除以2 在减去已偏移值 获取浮动 先显示在隐藏
                 */
                if (Offset < appBarLayout.getTotalScrollRange() / 2) {
                    mBinding.toolbaretail.setTitle("");
                    mBinding.toolbaretail.setAlpha((appBarLayout.getTotalScrollRange() / 2 - Offset * 1.0f) / (appBarLayout.getTotalScrollRange() / 2));
                    mBinding.shareImg.setAlpha((appBarLayout.getTotalScrollRange() / 2 - Offset * 1.0f) / (appBarLayout.getTotalScrollRange() / 2));
                    mBinding.shareImg.setImageDrawable(getResources().getDrawable(R.mipmap.share_shop));
                    mBinding.toolbaretail.setNavigationIcon(R.mipmap.shop_details_2);
                    /**
                     * 从最低浮动开始渐显 当前 Offset就是  appBarLayout.getTotalScrollRange() / 2
                     * 所以 Offset - appBarLayout.getTotalScrollRange() / 2
                     */
                } else if (Offset > appBarLayout.getTotalScrollRange() / 2) {
                    float floate = (Offset - appBarLayout.getTotalScrollRange() / 2) * 1.0f / (appBarLayout.getTotalScrollRange() / 2);
                    mBinding.toolbaretail.setAlpha(floate);
                    mBinding.shareImg.setAlpha(floate);
                    mBinding.toolbaretail.setNavigationIcon(R.mipmap.image_left);
                    mBinding.shareImg.setImageDrawable(getResources().getDrawable(R.mipmap.img_share));
                    mBinding.toolbaretail.setTitle("禄福来精品翡翠");
                    mBinding.toolbaretail.setAlpha(floate);
                }
            }
        });
    }

    /**
     * 根据百分比改变颜色透明度
     */
    public int changeAlpha(int color, float fraction) {
        int alpha = (int) (Color.alpha(color) * fraction);
        return Color.argb(alpha, 0, 128, 0);
    }

    /**TabLayout
     * 初始化
     */
    private void TabLayout(){
        List<String>list_Title = new ArrayList<>();
        list_Title.add("图文详情");
        list_Title.add("规格参数");

        List<Fragment> fragmentList = new ArrayList<>();
        fragmentList.add(new Fragment1());
        fragmentList.add(new Fragment2());

        mBinding.infoPhoneFragmentPager.setAdapter(new HomeFragmentPageAdapter(getSupportFragmentManager(),fragmentList,list_Title,2));
        mBinding.infoPhoneTabLayou.setTabMode(TabLayout.MODE_FIXED);
        mBinding.infoPhoneTabLayou.setupWithViewPager(mBinding.infoPhoneFragmentPager);
    }
}

渐变核心实现AppBarLayout.addOnOffsetChangedListener监听
通过verticalOffset 拿到当前的当前偏移量,appBarLayout.getTotalScrollRange() 是最大高度 偏移值 有了这两个参数我们就可以计算 浮度

是不是感觉很简单呢到此就结束了,在此奉上源码点击下载
有更好的方式或者需要改进的地方请给我留言,大家共同学习进步。
图片是一个做微商朋友提供的,要是需要玉的话可以给我留言。就当给他推广推广啦

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 210,914评论 6 490
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 89,935评论 2 383
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 156,531评论 0 345
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,309评论 1 282
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,381评论 5 384
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 49,730评论 1 289
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,882评论 3 404
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,643评论 0 266
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,095评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,448评论 2 325
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,566评论 1 339
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,253评论 4 328
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,829评论 3 312
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,715评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,945评论 1 264
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,248评论 2 360
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,440评论 2 348

推荐阅读更多精彩内容