我觉得我将脱离这个论坛的范围,如果我愿意的话,请把我引向正确的方向。

我当时是为网站创建360度旋转产品预览。例如:

http://uniqstudios.co.uk/vid-360/interactive-360-rotate-rich-media-2

我想知道是否有一种简单的方法,例如我们拥有全景照片应用程序的方式,是否也可以使用某些应用程序创建类似的内容?或有特定的相机可以做到这一点。

另外,请让我知道如何将这些360度旋转图像嵌入网站中。

在此先感谢您将我定向到正确的论坛,或者在此处帮助我。
e山

最佳答案

如果您有不同 Angular 2d图像(如果有gif图像,则可以从中提取帧),可以按照以下方式进行:

在可绘制文件夹中定义axml:

image_3D_images.xml

<level-list xmlns:android="http://schemas.android.com/apk/res/android">
  <item android:maxLevel="0" android:drawable="@drawable/bg_01" />
  <item android:maxLevel="1" android:drawable="@drawable/bg_02" />
  <item android:maxLevel="2" android:drawable="@drawable/bg_03" />
  <item android:maxLevel="3" android:drawable="@drawable/bg_04" />
  <item android:maxLevel="4" android:drawable="@drawable/bg_05" />
</level-list>

然后使用如下图像 View 创建布局:

activity_3d_view.xml:
<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
  android:orientation="vertical"
  android:layout_width="match_parent"
  android:layout_height="match_parent"
  >

<ImageView
  android:id="@+id/santafe3dview"
  android:layout_gravity="center"
  android:layout_width="match_parent"
  android:layout_height="match_parent"
  android:src="@drawable/image_3d_images"
  android:scaleType="fitXY"
  />

</RelativeLayout>

然后在您的 Activity 中编写以下代码:

Launcher3DViewActivity.java:
  @Override
  public void onCreate(Bundle savedInstanceState) {
      super.onCreate(savedInstanceState);

      mContext = this;
      setContentView(R.layout.activity_3d_view);
          m360DegreeImageView = (ImageView)findViewById(R.id.santafe3dview);
   }


  @Override
  public boolean onTouchEvent(MotionEvent event){

      int action = MotionEventCompat.getActionMasked(event);

      switch(action) {
          case (MotionEvent.ACTION_DOWN) :

              mStartX = (int)event.getX();
              mStartY = (int)event.getY();
              return true;

          case (MotionEvent.ACTION_MOVE) :

              mEndX = (int)event.getX();
              mEndY = (int)event.getY();

              if((mEndX - mStartX) > 3) {
                mImageIndex++;
                 if(mImageIndex > 56 )
                    mImageIndex = 0;

                m360DegreeImageView.setImageLevel(mImageIndex);

              }
              if((mEndX - mStartX) < -3) {
                mImageIndex--;
                 if(mImageIndex <0)
                     mImageIndex = 56;

                 m360DegreeImageView.setImageLevel(mImageIndex);

              }
              mStartX = (int)event.getX();
              mStartY = (int)event.getY();
              return true;

          case (MotionEvent.ACTION_UP) :
              mEndX = (int)event.getX();
              mEndY = (int)event.getY();

              return true;

          case (MotionEvent.ACTION_CANCEL) :
              return true;

          case (MotionEvent.ACTION_OUTSIDE) :
              return true;

          default :
              return super.onTouchEvent(event);
      }
  }

07-24 09:38
查看更多