在ViewFlipper中动态创建imageView获取imageView id

kgg*_*goh 2 android onclick imageview viewflipper

我在我的ViewFlipper中动态创建了imageView,它运行顺畅.但是,当我想点击图像时,我需要对图像进行放大并对其进行处理.我如何获得身份证明.我需要能够区分哪些图像我已经陈词滥调.

提前致谢.

    public class Home_Fragment extends Fragment{

.....

   private ViewFlipper vf;

    int gallery_grid_Images[]={R.drawable.a,R.drawable.b,R.drawable.c,
            R.drawable.d};

  private void setFlipperImage(int res) {
        //Log.i("Set Filpper Called", res+"");
        ImageView image = new ImageView(getActivity());



        LayoutParams lp = new LayoutParams(LayoutParams.MATCH_PARENT, 
                LayoutParams.MATCH_PARENT);
        image.setLayoutParams(lp);

        image.setAdjustViewBounds (true);
        image.setScaleType(ScaleType.CENTER_INSIDE);
        image.setClickable(true);

        image.setBackgroundResource(res);

        image.setOnClickListener(new OnClickListener() {

            public void onClick(View v) {
                // TODO Auto-generated method stub
                int id=(Integer) v.getTag();     //---> This will crash if i click the image
                //Toast.makeText(getActivity(), id+"", Toast.LENGTH_LONG).show();

            }
        });


        vf.setTag(res);

        vf.addView(image);
    }
Run Code Online (Sandbox Code Playgroud)

MFP*_*MFP 5

下面的代码我用于viewflipper滑动图像.你可以在forloop中添加onclick图像事件.

SlideShowActivity.java

package com.example.viewpagerexample;

import android.app.Activity;
import android.os.Bundle;
import android.view.MotionEvent;
import android.widget.ImageView;
import android.widget.ViewFlipper;

public class SlideShowActivity extends Activity {

private ViewFlipper myViewFlipper;
private float initialXPoint;
int[] image = { R.drawable.one_full, R.drawable.two_full,
    R.drawable.three_full, R.drawable.four_full, R.drawable.five_full,
    R.drawable.six_full, R.drawable.seven_full, R.drawable.eight_full,
    R.drawable.nine_full, R.drawable.ten_full };

@Override
protected void onCreate(Bundle savedInstanceState) {

super.onCreate(savedInstanceState);
setContentView(R.layout.slide_show);
myViewFlipper = (ViewFlipper) findViewById(R.id.myflipper);

for (int i = 0; i < image.length; i++) {
    ImageView imageView = new ImageView(SlideShowActivity.this);
    imageView.setImageResource(image[i]);
    myViewFlipper.addView(imageView);
    imageView.setOnClickListener(new OnClickListener() {

        @Override
        public void onClick(View v) {
       // your code
   }});
} 

@Override
public boolean onTouchEvent(MotionEvent event) {
switch (event.getAction()) {
case MotionEvent.ACTION_DOWN:
    initialXPoint = event.getX();
    break;
case MotionEvent.ACTION_UP:
    float finalx = event.getX();
    if (initialXPoint > finalx) {
        if (myViewFlipper.getDisplayedChild() == image.length)
            break;
        myViewFlipper.showNext();
    } else {
        if (myViewFlipper.getDisplayedChild() == 0)
            break;
        myViewFlipper.showPrevious();
    }
    break;
}
return false;
}
}
Run Code Online (Sandbox Code Playgroud)

这里的图像仅在用户滑动时才会发生变化.

如果要以特定间隔自动滑动,请添加以下代码.

myViewFlipper.setAutoStart(true);
myViewFlipper.setFlipInterval(3000);
myViewFlipper.startFlipping();
Run Code Online (Sandbox Code Playgroud)