AndroidCollapsingToolbarLayout-仿BiliBili视频页

效果图:

这里写图片描述

coordinatorLayout.xml布局

<?xml version="1.0" encoding="utf-8"?>
<android.support.design.widget.CoordinatorLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    xmlns:tools="http://schemas.android.com/tools"
    android:id="@+id/main_content"
    android:layout_width="match_parent"
    android:layout_height="match_parent">


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

        <android.support.design.widget.CollapsingToolbarLayout
            android:id="@+id/collaps"
            android:layout_width="match_parent"
            android:layout_height="@dimen/tab_height"
            app:contentScrim="#FA7199"
            app:layout_scrollFlags="scroll|exitUntilCollapsed"
            app:statusBarScrim="@android:color/transparent">

            <ImageView
                android:layout_width="match_parent"
                android:layout_height="match_parent"
                android:scaleType="fitXY"
                android:src="@mipmap/meizhi"
                app:layout_collapseMode="parallax" />

            <android.support.v7.widget.Toolbar
                android:id="@+id/toolbar1"
                android:layout_width="match_parent"
                android:layout_height="48dp"
                android:layout_marginTop="20dp"
                app:collapseIcon="@mipmap/ic_book_list"
                app:layout_collapseMode="pin"
                app:navigationIcon="@mipmap/navigation_back_white"
                app:popupTheme="@style/ThemeOverlay.AppCompat.Light"
                app:title="@string/app_name"
                app:titleTextColor="@color/white">
                <!--自定义带图片的立即播放按钮-->
                <LinearLayout
                    android:id="@+id/playButton"
                    android:layout_width="match_parent"
                    android:layout_height="match_parent"
                    android:gravity="center"
                    android:orientation="horizontal"
                    android:visibility="gone">

                    <ImageView
                        android:layout_width="30dp"
                        android:layout_height="30dp"
                        android:src="@mipmap/ic_book_list" />

                    <TextView
                        android:layout_width="wrap_content"
                        android:layout_height="wrap_content"
                        android:layout_marginLeft="5dp"
                        android:text="立即播放"
                        android:textColor="#ffffff" />
                </LinearLayout>


            </android.support.v7.widget.Toolbar>


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

        <include layout="@layout/common_toolbar_with_tab" />


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


    <android.support.v4.view.ViewPager
        android:id="@+id/viewpager"
        android:layout_width="match_parent"
        android:layout_height="510dp"
        android:layout_weight="1"
        app:layout_behavior="@string/appbar_scrolling_view_behavior"
        tools:layout_editor_absoluteY="257dp" />


    <android.support.design.widget.FloatingActionButton
        android:id="@+id/fab"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_gravity="end|bottom"
        android:layout_margin="@dimen/fab_margin"
        app:fabSize="mini"
        android:src="@mipmap/add" />

    <android.support.design.widget.FloatingActionButton
        android:id="@+id/fab2"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_marginBottom="25dp"
        android:layout_marginRight="15dp"
        android:src="@mipmap/ic_book_list"
        app:elevation="6dp"

        app:layout_anchor="@+id/appbar"
        app:layout_anchorGravity="bottom|right" />
</android.support.design.widget.CoordinatorLayout>

监听AppBarLayout.OnOffsetChangedListener来判断伸缩状态

 appbar.addOnOffsetChangedListener(new AppBarLayout.OnOffsetChangedListener() {
            @Override
            public void onOffsetChanged(AppBarLayout appBarLayout, int verticalOffset) {
                if (verticalOffset == 0) {
                    if (state != CollapsingToolbarLayoutState.EXPANDED) {
                        state = CollapsingToolbarLayoutState.EXPANDED;
                        collaps.setTitle(getString(R.string.app_name));
                    }
                } else if (Math.abs(verticalOffset) >= appBarLayout.getTotalScrollRange()) {

                    if (state != CollapsingToolbarLayoutState.COLLAPSED) {
                        collaps.setTitle("");//设置title不显示
                        fab2.setVisibility(View.VISIBLE);//隐藏播放按钮
                        state = CollapsingToolbarLayoutState.COLLAPSED;//修改状态标记为折叠

                    }
                } else {

                    if (state != CollapsingToolbarLayoutState.INTERNEDIATE) {

                        if (state == CollapsingToolbarLayoutState.COLLAPSED) {
                            fab2.setVisibility(View.GONE);//由折叠变为中间状态时隐藏播放按钮
                        }

                        collaps.setTitle(getString(R.string.app_name));//设置title为INTERNEDIATE
                        state = CollapsingToolbarLayoutState.INTERNEDIATE;//修改状态标记为中间
                    }
                }


            }
        });

github地址:https://github.com/hushendian/CollapsingToolbarLayoutDemo.git

原文地址:http://www.jianshu.com/p/06c0ae8d9a96
http://www.jianshu.com/p/ac56f11e7ce1
http://www.jianshu.com/p/f09723b7e887

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Vue仿Bilibili视频播放器是一个使用Vue.js框架开发的仿Bilibili播放器的项目。该播放器具有类似于Bilibili的界面设计和功能,可以实现视频的播放、弹幕、评论、点赞等功能。 该项目使用了Vue.js的组件化开发思想,将播放器分为多个组件,包括视频播放组件、弹幕组件、评论组件等。每个组件都有独立的功能和样式,可以高度复用。通过Vue.js的数据双向绑定和事件机制,实现了组件之间的数据传递和交互。 在实现视频播放功能时,使用了第三方库video.js,该库提供了强大的视频播放功能和跨平台兼容性。通过使用video.js,可以实现Bilibili播放器中的全屏、倍速播放、画面质量切换等功能。 为了实现弹幕功能,使用了第三方库danmaku.js。该库可以实现弹幕的发送、显示和管理。用户可以通过输入框发送弹幕,同时视频播放器会实时显示其他用户发送的弹幕。 评论功能使用了Vue.js的表单验证机制和axios库进行数据的提交和请求。用户可以输入评论内容,并提交给服务器进行保存。同时,用户可以查看其他用户的评论,并对其进行点赞或回复。 项目中的样式采用了Bilibili的设计风格,使用了CSS3的动画效果和过渡效果,使播放器更加流畅和美观。 总结起来,Vue仿Bilibili视频播放器是一个基于Vue.js框架开发的仿Bilibili播放器的项目,具备了视频播放、弹幕、评论、点赞等功能,通过使用Vue.js的组件化开发思想和相关插件,实现了类似Bilibili播放器的界面和功能。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值