I have two Activities, both of which contain an image. I am using Fresco to load the image in one activity and Picasso to load image in another activity. Here are the relevant parts of my code:
Image in first activity
<com.facebook.drawee.view.SimpleDraweeView
android:id="@+id/imageView102"
android:transitionName="image"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_gravity="center_horizontal"
android:layout_marginLeft="9dp"
android:layout_marginRight="9dp"
android:layout_marginTop="10dp"
fresco:actualImageScaleType="centerCrop"
fresco:placeholderImage="@color/wait_color"
fresco:placeholderImageScaleType="fitCenter"
fresco:viewAspectRatio="1.33"
android:layout_marginBottom="10dp" />
Image in second activity
<uk.co.senab.photoview.PhotoView
android:id="@+id/zoomable"
android:transitionName="image"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:layout_centerInParent="true" />
I am using PhotoView in second activity to zoom in and zoom out the image.
First Activity
Uri uri = Uri.parse(photoUrl);
ImageRequest request = ImageRequestBuilder.newBuilderWithSource(uri)
.setProgressiveRenderingEnabled(true)
.build();
DraweeController controller = Fresco.newDraweeControllerBuilder()
.setImageRequest(request)
.setOldController(image.getController())
.build();
image.setController(controller);
image.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View view) {
Intent intent = new Intent(ImageActivity.this, AlternateFullImageActivity.class);
intent.putExtra("ID", photoId);
intent.putExtra("photoUrl", photoUrl);
if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.LOLLIPOP) {
ActivityOptionsCompat options = ActivityOptionsCompat.
makeSceneTransitionAnimation(ImageActivity.this, (View)image, "image");
startActivity(intent, options.toBundle());
}
else {
startActivity(intent);
}
}
});
Second Activity
Intent intent = getIntent();
photoId = intent.getExtras().getString("ID");
photoUrl = intent.getExtras().getString("photoUrl");
Picasso.with(AlternateFullImageActivity.this)
.load(photoUrl)
.into(image);
mAttacher = new PhotoViewAttacher(image);
The problem is, the transition is not smooth and very fast. I read here that I need to change the transition to ChangeBounds
. How do I change the transition to that and how do I add duration to this transition like say, 1000ms?
You can create a class that extends TransitionSet to specify you transitions, like ChangeBounds. For example...
@TargetApi(Build.VERSION_CODES.LOLLIPOP)
public class DetailTransition extends TransitionSet {
public DetailsTransition(int duration, int delay) {
setOrdering(ORDERING_TOGETHER);
addTransition(new ChangeBounds()).
addTransition(new ChangeTransform()).
addTransition(new ChangeImageTransform()).setDuration(duration).setStartDelay(delay).setInterpolator(new AnticipateOvershootInterpolator());
}
}
and then you set shared element transition onto your fragment or activity / window. For fragments like this
currentFragment.setSharedElementEnterTransition(new DetailsTransition(1000, 400));
or for activity like this
getWindow().setSharedElementEnterTransition(new DetailsTransition(1000, 400));