Warning: file_get_contents(/data/phpspider/zhask/data//catemap/3/android/229.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Android 页面卷曲动画在viewflipper视图之间翻转_Android_Animation_Viewflipper_Page Curl - Fatal编程技术网

Android 页面卷曲动画在viewflipper视图之间翻转

Android 页面卷曲动画在viewflipper视图之间翻转,android,animation,viewflipper,page-curl,Android,Animation,Viewflipper,Page Curl,我遇到了几个页面卷曲动画和视口翻转器的示例。是否可以通过页面卷曲动画在viewflipper的子对象之间导航。到目前为止,我应用于ViewFlipper的动画都是非常基本的,比如滑入/滑出,我想知道是否可以使用页面卷曲动画实现同样的效果 这里有一个开源android项目:。 我在这里找到了另一个: 但如果这是您所要求的,则没有本机实现。您需要为此从导入一个模块库 之后,请使用以下代码:- item_page.xml <?xml version="1.0" encoding="utf-8"?

我遇到了几个页面卷曲动画和视口翻转器的示例。是否可以通过页面卷曲动画在viewflipper的子对象之间导航。到目前为止,我应用于ViewFlipper的动画都是非常基本的,比如滑入/滑出,我想知道是否可以使用页面卷曲动画实现同样的效果

这里有一个开源android项目:。 我在这里找到了另一个:


但如果这是您所要求的,则没有本机实现。

您需要为此从导入一个模块库

之后,请使用以下代码:-

item_page.xml

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

        <LinearLayout
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            android:orientation="vertical">

            <ImageView
                android:id="@+id/image"
                android:layout_width="200dp"
                android:layout_height="200dp"
                android:layout_gravity="center"
                android:layout_marginTop="10dp"
                android:contentDescription="@string/app_name"
                android:scaleType="centerCrop" />

            <TextView
                android:id="@+id/text"
                android:padding="10dp"
                android:layout_width="match_parent"
                android:layout_height="wrap_content"
                android:textAppearance="?android:attr/textAppearanceMediumInverse"
                android:textColor="@android:color/black" />
        </LinearLayout>
    </ScrollView>
活动\u flipper\u视图\u controller.xml

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

    <TextView
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:background="@android:color/darker_gray"
        android:paddingLeft="10dp"
        android:text="@string/header"
        android:textAppearance="@android:style/TextAppearance.Large" />

    <com.aphidmobile.flip.FlipViewController
        android:id="@+id/flip_view"
        android:layout_width="match_parent"
        android:layout_height="0dp"
        android:layout_weight="1"
        flip:orientation="horizontal" />

    <TextView
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:background="@android:color/darker_gray"
        android:paddingLeft="10dp"
        android:text="@string/footer"
        android:textAppearance="@android:style/TextAppearance.Large" />
</LinearLayout>
FlipperAdapter.java

package pratiksha.com.pagecurlviewdemo;

import android.app.Activity;
import android.support.v7.app.AppCompatActivity;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.BaseAdapter;
import android.widget.ImageView;
import android.widget.TextView;

import java.util.List;

import pratiksha.com.pagecurlviewdemo.R;

/**
 * Created by User(LPT-APR2015-02) on 11/7/2016.
 */
public class FlipperAdapter extends BaseAdapter {

    private AppCompatActivity appCompatActivity;
    private List<String> strings;
    private int[] drawableIds = {R.mipmap.ic_launcher, R.mipmap.page1, R.mipmap.page2, R.mipmap.ic_launcher,
            R.mipmap.page2, R.mipmap.page1, R.mipmap.page2, R.mipmap.ic_launcher,
            R.mipmap.page1};

    public FlipperAdapter(AppCompatActivity appCompatActivity, List<String> strings) {
        super();
        this.strings = strings;
        this.appCompatActivity = appCompatActivity;
    }

    @Override
    public int getCount() {
        return strings.size();
    }

    @Override
    public String getItem(int position) {
        return strings.get(position);
    }

    @Override
    public long getItemId(int position) {
        return strings.indexOf(getItem(position));
    }

    @Override
    public View getView(int position, View convertView, ViewGroup parent) {
        ViewHolder holder;
        LayoutInflater inflater = (LayoutInflater) appCompatActivity.getSystemService(Activity.LAYOUT_INFLATER_SERVICE);

        // If holder not exist then locate all view from UI file.
        if (convertView == null) {
            // inflate UI from XML file
            convertView = inflater.inflate(R.layout.item_page, parent, false);
            // get all UI view
            holder = new ViewHolder(convertView);
            // set tag for holder
            convertView.setTag(holder);
        } else {
            // if holder created, get tag from view
            holder = (ViewHolder) convertView.getTag();
        }

        holder.textView.setText(getItem(position));
        holder.imageView.setImageResource(drawableIds[position]);

        return convertView;
    }

    private static class ViewHolder {
        private TextView textView;
        private ImageView imageView;

        public ViewHolder(View v) {
            imageView = (ImageView)v.findViewById(R.id.image);
            textView = (TextView) v.findViewById(R.id.text);
        }
    }
}
Main Activity.java

package pratiksha.com.pagecurlviewdemo;

import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;

import com.aphidmobile.flip.FlipViewController;

import java.util.ArrayList;

public class FlipperViewController extends AppCompatActivity {

    private FlipViewController flipViewController;
    private FlipperAdapter adapter;
    private ArrayList<String> stringArrayList;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_flipper_view_controller);

        flipViewController = (FlipViewController)findViewById(R.id.flip_view);
        stringArrayList = new ArrayList<>();
        readDataFromAssets();

        //create and attach adapter to flipper view
        adapter = new FlipperAdapter(this, stringArrayList);
        flipViewController.setAdapter(adapter);
    }

    private void readDataFromAssets() {
        for(int i=1;i<10;i++)
        stringArrayList.add("Page Number "+i);
    }
}

感谢您花时间回答@Warpzit,但我希望页面卷曲专门应用于视图翻转器的子视图。@Rohan您应该做出选择,最重要的是什么?让它变得完美=自己动手,节省一些时间和时间=使用别人做的东西并适应自己的工作。谢谢。我可能会详细阅读OpenGL,并尝试实现/使用一些代码。我试着投票支持你的答案,但我需要15%的声誉才能这么做。@Rohan没关系,如果你能更好地实现,请记住发布答案,这样其他人就可以从你的工作中受益:一旦我运行了答案,哪怕是部分,我肯定会发布一个解决方案。嗨,你找到或实现了答案吗?