2013-11-09 74 views
5

我是新來實現Android應用程序的滑動手勢。我試圖從刷卡左一個ImageView的使用下面的代碼在屏幕的右側:Android - 如何移動ImageView在滑動

public class MainActivity extends Activity implements OnClickListener{ 
private static final int SWIPE_MIN_DISTANCE = 10; 
private static final int SWIPE_MAX_OFF_PATH = 250; 
private static final int SWIPE_THRESHOLD_VELOCITY = 200; 
private GestureDetector gestureDetector; 
View.OnTouchListener gestureListener; 
@Override 
protected void onCreate(Bundle savedInstanceState) { 
    super.onCreate(savedInstanceState); 
    setContentView(R.layout.activity_main); 
    ImageView btnSwipe = (ImageView)findViewById(R.id.imgBtnSwipe); 
    btnSwipe.setOnClickListener(this); 
    gestureDetector = new GestureDetector(this, new MyGestureDetector()); 
    gestureListener = new View.OnTouchListener() { 
     public boolean onTouch(View v, MotionEvent event) { 
      return gestureDetector.onTouchEvent(event); 
     } 
    }; 
    btnSwipe.setOnTouchListener(gestureListener); 
} 
class MyGestureDetector extends SimpleOnGestureListener { 
    @Override 
    public boolean onFling(MotionEvent e1, MotionEvent e2, float velocityX, float velocityY) { 
     try { 
      if (Math.abs(e1.getY() - e2.getY()) > SWIPE_MAX_OFF_PATH) 
       return false; 
      if(e1.getX() - e2.getX() > SWIPE_MIN_DISTANCE && Math.abs(velocityX) > SWIPE_THRESHOLD_VELOCITY) { 
       Toast.makeText(MainActivity.this, "Left Swipe", Toast.LENGTH_SHORT).show(); 
      } else if (e2.getX() - e1.getX() > SWIPE_MIN_DISTANCE && Math.abs(velocityX) > SWIPE_THRESHOLD_VELOCITY) { 
       Toast.makeText(MainActivity.this, "Right Swipe", Toast.LENGTH_SHORT).show(); 
      } 
     } catch (Exception e) { 
      // nothing 
     } 
     return false; 
    } 

} 
@Override 
public void onClick(View v) { 
} 
} 

我得到吐司消息向右滑動。但形象不動。我怎樣才能實現呢?請幫助我提供示例代碼/鏈接。

回答

5

我發現如下一個簡單的解決方案:

用於向右滑動(向右) :

btnSwipe.setTranslationX(e2.getX()); 

對於左輕掃(向左)」

btnSwipe.setTranslation(e1.getX()); 

現在,ImageView的是從右到左,左過渡到水平的權利。但是這從Android的API級別11起。

+0

第二個「向左滑動」,我想它一定是setTranslationX,對吧? – iversoncru

+0

當我嘗試使用「setTranslation」與視圖(這裏是btnSwipe ImageView),有一個錯誤:「該方法setTranslationX未定義的類型查看」 ImageView的同樣的錯誤。有任何想法嗎? – iversoncru

+0

什麼是您的API級別?如果它小於11,那麼你不會有這個功能。 – Brianide

3

您需要使用PagerAdapter進行滑動功能。 類似這樣的:

public class FullScreenImageAdapter extends PagerAdapter { 

//Stores all the image paths 
private ArrayList<String> _imagePaths; 

......... 


@Override 
    public Object instantiateItem(ViewGroup container, int position) { 
//This method is called each time user swipes the screen 
//Write suitable code to display next image on the screen 
} 

...... 

} 

這是官方文檔的鏈接。

http://developer.android.com/training/animation/screen-slide.html http://developer.android.com/reference/android/support/v4/view/PagerAdapter.html

這裏是鏈接關於影像優良的教程滑塊

http://www.androidhive.info/2013/09/android-fullscreen-image-slider-with-swipe-and-pinch-zoom-gestures/

+0

我不需要移動頁面。我只需要在Swipe上移動imageview(從左到右)......當圖像進入右端時,只需切換活動即可。我不需要PageAdapter或ViewFlipper,因爲他們翻譯整個頁面... –

+0

噢..如何使用水平ListView?用圖像填充水平ListView適配器,每個List Item的佈局是ImageView。 –

+0

@AhhishekV他說他只有一個圖像視圖,他想用TouchEvents刷一下。 –