android 共享元素 监听,Android共享元素

先放一个效果图

73920a7e7425

GIF.gif

Android共享元素属于Android 5.0的新属性

这里实现的是一个Imagview的缩放

我们先看一下RecycleView的Imageview的界面

android:id="@+id/abstract_item__img"

android:layout_width="0dp"

android:layout_height="120dp"

android:layout_weight="1"

android:scaleType="centerCrop"

tools:src="@mipmap/ic_launcher_round"

android:transitionName="image"

/>

这个是扩大后的ImageView的内容

android:id="@+id/healthy_news_detali_image"

android:layout_width="match_parent"

android:layout_height="match_parent"

android:fitsSystemWindows="true"

android:scaleType="centerCrop"

android:src="@drawable/ic_account_info"

android:transitionName="image"

app:layout_collapseMode="parallax"/>

他们之间的共同点就是 android:transitionName="image" 代码

这时候我们只需要在启动Acitivity的时候加几行代码就可以实现了;

intent.putExtra("NewsBean", ((NewsBean) adapter.getItem(position)));

if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.LOLLIPOP) {

/*startActivity(intent, ActivityOptions.makeSceneTransitionAnimation(getActivity()).toBundle());*/

startActivity(intent, ActivityOptions.makeSceneTransitionAnimation(getActivity(),

Pair.create(view.findViewById(R.id.abstract_item__img), "image"),

Pair.create(view.findViewById(R.id.abstract_item__title), "title"))

.toBundle());

} else {

startActivity(intent);

}

你以为就到此为止了吗 错了

有时候使用Glide加载Activity在第一次这张图片时候在图片周围会出现一些边界就是图片没有完全覆盖整个界面,而这个是因为动画加载完成了,Glide还没加载完成,就会出现以上情况,这时候解决只需要使用到Glide的Targe,在OnResourceReady的时候再去设置图片。

先暂停动画

if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.LOLLIPOP) {

postponeEnterTransition();

}

Glide加载图片

Glide.with(this)

.load(mImageUrl)

.asBitmap()

.centerCrop()

.diskCacheStrategy(DiskCacheStrategy.ALL)

.into(new SimpleTarget() {

@Override

public void onResourceReady(Bitmap resource, GlideAnimation super Bitmap> glideAnimation) {

imageView.setImageBitmap(resource);

scheduleStartPostponedTransition(imageView);

}

});

scheduleStartPostponedTransition的代码如下

private void scheduleStartPostponedTransition(final View sharedElement) {

sharedElement.getViewTreeObserver().addOnPreDrawListener(

new ViewTreeObserver.OnPreDrawListener() {

@TargetApi(Build.VERSION_CODES.LOLLIPOP)

@Override

public boolean onPreDraw() {

sharedElement.getViewTreeObserver().removeOnPreDrawListener(this);

startPostponedEnterTransition();

return true;

}

});

}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值