仿QQ5.0缩放式侧滑栏的实现

有人跟我说,QQ5.0的侧滑栏动画很有趣。有趣的东西当然不能放过,于是就来模仿一下。

个人比较支持官方的东西,侧滑栏就使用了v4包里的SlidingPaneLayout。动画是使用Property Animation实现的,不考虑3.0以下,如要支持,请使用NineOldAndroids。

好了,废话不多说。直接上效果图:


下面来讲实现的过程,思路就是实现一个SlidingPaneLayout,并在PanelSlideListener的onPanelSlide函数中设置当前动画播放的位置即可。

SlidingPanelLayout的布局文件:

<span style="font-size:18px;"><android.support.v4.widget.SlidingPaneLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    android:id="@+id/slidingpane"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    tools:context="com.sogoe.slidingpane.MainActivity" >

    <RelativeLayout
        android:id="@+id/back_view"
        android:layout_width="160dp"
        android:layout_height="match_parent" >

        <include layout="@layout/menu" />
    </RelativeLayout>

    <RelativeLayout
        android:id="@+id/main_view"
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:background="#ffffff" >

        <TextView
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_centerInParent="true"
            android:text="@string/hello_world" />
    </RelativeLayout>

</android.support.v4.widget.SlidingPaneLayout></span>

在Activity中为两个View创建动画:

<span style="font-size:18px;">private void initAnimations() {
	PropertyValuesHolder scaleX = PropertyValuesHolder.ofFloat("scaleX", 1.0f, 0.75f);
	PropertyValuesHolder scaleY = PropertyValuesHolder.ofFloat("scaleY", 1.0f, 0.75f);
	mainAnim = ObjectAnimator.ofPropertyValuesHolder(main, scaleX, scaleY).setDuration(DURATION);
	
	PropertyValuesHolder fade = PropertyValuesHolder.ofFloat("alpha", 0.2f, 1.f);
	PropertyValuesHolder scaleX_back = PropertyValuesHolder.ofFloat("scaleX", 0.75f, 1.f);
	PropertyValuesHolder scaleY_back = PropertyValuesHolder.ofFloat("scaleY", 0.75f, 1.f);
	PropertyValuesHolder translationX_back = PropertyValuesHolder.ofFloat("translationX", -100.f, 0.f);
	backAnim = ObjectAnimator.ofPropertyValuesHolder(back, scaleX_back, scaleY_back, translationX_back, fade).setDuration(DURATION);
	
}</span>

最后给SlidingPaneLayout设置PenelSlideLinstener,PenelSlideLinstener有三个函数onPanelSlide,onPanelOpened,onPanelClosed。onPanelSlide会在滑动的过程中调用,第二参数传进来是0到1之间的一个浮点数,代表滑动过程的阶段。

<span style="font-size:18px;">@Override
public void onPanelSlide(View view, float offset) {
	mainAnim.setCurrentPlayTime((long) (offset * DURATION));
	backAnim.setCurrentPlayTime((long) (offset * DURATION));
}
</span>

尴尬第一次发CSDN,编辑得有点乱啊



  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值