如何在ViewFlipper中添加单击事件

时间:2013-12-31 07:42:04

标签: java android viewflipper clicklistener

我正在尝试设计一个至少包含10张图像的视图鳍状肢。如果用户点击图像,现在每个图像都有自己的活动。如何为不同的图像获得不同的点击事件。我的意思是如果image1在屏幕上并且用户点击屏幕,点击toast image1,对于image2 toast image2点击等等。这就是我所做的。

public class PaperSelectionActivity extends Activity implements OnClickListener 
{
    ViewFlipper page;
    LinearLayout lyt;

    Animation animFlipInForeward;
    Animation animFlipOutForeward;
    Animation animFlipInBackward;
    Animation animFlipOutBackward;

    /* Called when the activity is first created. */
    @Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_paper_selection);

        page = (ViewFlipper)findViewById(R.id.flipper);

        animFlipInForeward = AnimationUtils.loadAnimation(this, R.anim.flipin);
        animFlipOutForeward = AnimationUtils.loadAnimation(this, R.anim.flipout);
        animFlipInBackward = AnimationUtils.loadAnimation(this, R.anim.flipin_reverse);
        animFlipOutBackward = AnimationUtils.loadAnimation(this, R.anim.flipout_reverse);   
    }

    private void SwipeRight(){
        page.setInAnimation(animFlipInBackward);
        page.setOutAnimation(animFlipOutBackward);
        page.showPrevious();
    }

    private void SwipeLeft(){
        page.setInAnimation(animFlipInForeward);
        page.setOutAnimation(animFlipOutForeward);
        page.showNext();
    }

    @Override
    public boolean onTouchEvent(MotionEvent event) {
        // TODO Auto-generated method stub
        return gestureDetector.onTouchEvent(event);
    }

    SimpleOnGestureListener simpleOnGestureListener = new SimpleOnGestureListener(){
        @Override
        public boolean onFling(MotionEvent e1, MotionEvent e2, float velocityX, float velocityY) 
        {
            float sensitvity = 50;
            if((e1.getX() - e2.getX()) > sensitvity){
                SwipeLeft();
            }else if((e2.getX() - e1.getX()) > sensitvity){
                SwipeRight();
            }
            return true;
        }
    };

    GestureDetector gestureDetector = new GestureDetector(simpleOnGestureListener);

    @Override
    public void onClick(View v) {
        // TODO Auto-generated method stub

    }
    @Override
    public boolean onCreateOptionsMenu(Menu menu) {
        // Inflate the menu; this adds items to the action bar if it is present.
        getMenuInflater().inflate(R.menu.paper_selection, menu);
        return true;
    }
}

XML文件:

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="fill_parent"
    android:layout_height="fill_parent"
    android:background="@drawable/background"
    android:orientation="vertical">

    <ViewFlipper
        android:id="@+id/flipper"
        android:layout_width="fill_parent"
        android:layout_height="fill_parent">

        <RelativeLayout
            android:layout_width="fill_parent"
            android:layout_height="fill_parent"
            android:orientation="vertical">

            <ImageView
                android:layout_width="fill_parent"
                android:layout_height="fill_parent"
                android:src="@drawable/image1"/>

        </RelativeLayout>

        <RelativeLayout
            android:layout_width="fill_parent"
            android:layout_height="fill_parent"
            android:orientation="vertical">
            <ImageView
                android:layout_width="fill_parent"
                android:layout_height="fill_parent"
                android:src="@drawable/image2"/>

        </RelativeLayout>

        <RelativeLayout
            android:layout_width="fill_parent"
            android:layout_height="fill_parent"
            android:orientation="vertical">
            <ImageView
                android:layout_width="fill_parent"
                android:layout_height="fill_parent"
                android:src="@drawable/image3"/>

        </RelativeLayout>

        <RelativeLayout
            android:layout_width="fill_parent"
            android:layout_height="fill_parent"
            android:orientation="vertical">

            <ImageView
                android:layout_width="fill_parent"
                android:layout_height="fill_parent"
                android:src="@drawable/image4"/>  

        </RelativeLayout>

    </ViewFlipper>
</LinearLayout>

1 个答案:

答案 0 :(得分:0)

冒着过早优化的风险,我已经解决了一个与此非常相似的问题(翻转一组可能数十个或多或少相同的页面),结果非常好,这可以解决你的问题,尽管间接地

我的技术基础是让ViewFlipper包含一个子页面。当用户点击“上一个”或“下一个”时,会发生以下情况:

  1. 实例化一个特殊的视图,它“克隆”ViewFlipper的真实子视图的图像。
  2. 将克隆视图添加到ViewFlipper并将其设置为当前子视图而不进行任何动画。到目前为止,UI看起来好像什么都没有改变。
  3. 使用正在翻转的页面的文本和图像等更新真正的子视图(现在被克隆遮挡)。
  4. 将ViewFlipper的当前页面设置回真正的子视图,这次是一个很好的动画。
  5. 我需要更加努力,因为我的页面非常复杂......有几个列表,各种各样的按钮,图像等等。在我的视图层次结构中有两个或三个它们会非常浪费,更不用说了许多。上述技术可最大限度地减少布局复杂性,如果页面复杂,翻转动画可以更快地运行。 您可以更详细地了解there