我想实现一个基本的3d立方体并将其在Touch上水平或垂直旋转90度。我要实现的类似于下图中所示。

我已经使用ViewPagerViewTransformer实现了
但是我对结果不满意。动画不是很流畅,我无法翻转它,我必须在屏幕的整个宽度上拖动手指来旋转立方体。
我只想翻转它,但无法实现它。

我已经使用BTGridPager-Android实现了上述目的。但是如上所述,它不是很令人信服。

这是我的ViewTransformer代码:

    public abstract class ABaseTransformer implements PageTransformer {
 @Override
 public void transformPage(View page, float position) {
  onPreTransform(page, position);
  onTransform(page, position);
  onPostTransform(page, position);
 }
protected void onPreTransform(View page, float position) {
  final float width = page.getWidth();

  page.setRotationX(0);
  page.setRotationY(0);
  page.setRotation(0);
  page.setScaleX(1);
  page.setScaleY(1);
  page.setPivotX(0);
  page.setPivotY(0);
  page.setTranslationY(0);
  page.setTranslationX(isPagingEnabled() ? 0f : -width * position);

  if (hideOffscreenPages()) {
   page.setAlpha(position <= -1f || position >= 1f ? 0f : 1f);
  } else {
   page.setAlpha(1f);
  }
 }


public class HorizontalCubeOutTransformer extends ABaseTransformer {

 @Override
 protected void onTransform(View view, float position) {

  final float normalizedposition = Math.abs(1 - Math.abs(position));

  view.setPivotX(position < 0f ? view.getWidth() : 0f);
  view.setPivotY(view.getHeight() * 0.5f);
  view.setRotationY(90f * position);
  view.setAlpha(normalizedposition);
 }

 @Override
 public boolean isPagingEnabled() {
  return true;
 }

}



public class VerticalCubeOutTransformer extends ABaseTransformer {


 @Override
 protected void onTransform(View view, float position) {

  final float normalizedposition = Math.abs(Math.abs(position) - 1);
  view.setAlpha(normalizedposition);
  view.setTranslationX(view.getWidth() * -position);
  view.setTranslationY(position * view.getHeight());

  view.setPivotX(view.getWidth() * 0.5f);
  view.setPivotY(position < 0f ? view.getHeight() : 0f);
  view.setRotationX(90f * -position);

 }

 @Override
 public boolean isPagingEnabled() {
  return false;
 }
}

我想知道的是如何在翻转手势上旋转立方体。
注意:我想在没有OpenGL或SurfaceView的情况下实现此目的。

更新:
到目前为止,我已经使用fragmenttransactionExtended实现了多维数据集翻转,但是现在我遇到了其他一些问题,因为当前 fragment 在翻转开始后就消失了

最佳答案

您可以使用FragmentTransactionExtended

FragmentTransactionExtended

它提供 fragment 之间的所有类型的动画

10-04 22:59
查看更多