1

我需要有关片段到片段转换的帮助。我不清楚如何正确地做到这一点,因为我能找到的文档很少。

我有一个带有电影海报的 GridView。当单击一张海报时,它将移动到下一个片段。海报是共享元素,它将调整大小(变大)并覆盖屏幕。其他元素将根据内容过渡淡化.这工作正常。

我无法获得重新进入过渡。按下后退按钮时,网格视图中的第一个元素将始终首先出现(它不跟随内容过渡(淡入淡出)),然后其他元素淡入。共享元素不会调整大小(变小)并加入其他元素。它与其他元素一起淡入,从而遵循内容转换样式。这是我的代码:

NowShowingFragment.java 包含带有图像的网格视图

 @Override
public void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setRetainInstance(true);
    setHasOptionsMenu(true);
    Transition shared = TransitionInflater.from(getActivity()).inflateTransition(android.R.transition.fade);
    shared.setDuration(2000);
    setExitTransition(shared);
}  

在我的 OnCreateView-我使用 Picasso 从 web 加载图像。所以我首先从 Imageview 中提取位图并将其传递给 Activity,后者又将传递给下一个要显示的片段。(不知道这是否应该做完了)。

 mGridView.setOnItemClickListener(new AdapterView.OnItemClickListener() {
        @Override
        public void onItemClick(AdapterView<?> parent, View view, int position, long id) {
            imageView = (ImageView) view.findViewById(R.id.gridImage);
            Drawable drawable = imageView.getDrawable();

            if (drawable instanceof BitmapDrawable) {
                bmp = ((BitmapDrawable) imageView.getDrawable()).getBitmap();
            } else {
                return;
            }
            imageView.setTransitionName("Poster" + position);
            mCallback.onArticleSelected(bmp, "Poster" + position, imageView);
        }
    });  

主要活动

 @Override
public void onArticleSelected(Bitmap bmp, String name, ImageView image) {

    NowShowingDetail newFragment = new NowShowingDetail();

    Transition shared=TransitionInflater.from(this).inflateTransition(android.R.transition.move);
    shared.setDuration(2000);
    Bundle args = new Bundle();
    args.putParcelable("Bitmap", bmp);
    args.putString("TransitionName", name);
    newFragment.setArguments(args);
    newFragment.setEnterTransition(shared);
    newFragment.setSharedElementEnterTransition(TransitionInflater.from(this).inflateTransition(R.transition.change_image_transform));

    getSupportFragmentManager().beginTransaction().replace(R.id.now_showing_fragment, newFragment).addToBackStack(null).addSharedElement(image, image.getTransitionName()).commit();

}  

在 NowShowingDetail - 这是将替换旧片段的新片段。它只会全屏显示共享元素。

 @Override
public View onCreateView(LayoutInflater inflater, @Nullable ViewGroup container, @Nullable Bundle savedInstanceState) {
    View rootView = inflater.inflate(R.layout.testlayout, container, false);
    ImageView imageView = (ImageView) rootView.findViewById(R.id.gridImage);

    Bundle arguments = getArguments();
    if (arguments != null) {
        Bitmap bitmap = arguments.getParcelable("Bitmap");
        imageView.setImageBitmap(bitmap);
        imageView.setTransitionName(arguments.getString("TransitionName"));

    }
    return rootView;
}  

change_image_transorm.xml

<transitionSet xmlns:android="http://schemas.android.com/apk/res/android">
<changeImageTransform
    android:duration="2000"></changeImageTransform>
<changeBounds
    android:duration="2000"></changeBounds>
<changeTransform
    android:duration="2000"></changeTransform>


先感谢您。

编辑:使用相同的代码,我更改为活动转换方法。这完美无瑕。我认为我称之为片段转换的方式可能是错误的。您的意见表示赞赏。

4

1 回答 1

0

我注意到片段没有共享元素退出和重新输入转换。

引用@George Mount 帖子:

除了没有共享元素退出和共享元素返回转换之外,所有这些转换在片段转换中都是相同的。片段转换使用 FragmentTransaction 工作。您删除一个片段,然后添加一个片段,然后过渡被激活。如果你删除了一个 Fragment,肯定很难像在 Activity Transition 中那样对其进行一些操作。相反,您必须在启动 FragmentTransaction 之前进行操作。

来自https://halfthought.wordpress.com/2014/12/08/what-are-all-these-dang-transitions/

所以我认为片段转换只是一种方式。如果是这种情况,那么行为就是预期的。

在其他人给出更好的解释之前,将保持此为已接受。

于 2015-03-20T04:59:27.223 回答