2013-12-18 137 views
1

我的問題是我在應用程序,它有圖像滑塊,圖像來自服務器,現在我的問題是當我點擊我的圖像它的外觀像這樣,請參閱以下示例圖像,並使用滑動功能,我可以用手指輕掃看到圖像,任何想法和幫助都將得到高度讚賞。點擊圖片前android如何打開滑塊圖像時onclick圖像和手指滑動

enter image description here

後,當點擊圖片:

enter image description here

+0

你有試過什麼? –

+1

謝謝你的答覆。我已經嘗試了很多事情,但它沒有奏效。我需要確切的解決問題的指示或任何幫助或想法。 –

+0

爲您需要使用viewpager或viewflipper .. –

回答

1

使用查看傳呼機一樣,

<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" 
android:layout_width="match_parent" 
android:layout_height="match_parent" 
android:orientation="vertical" > 

<android.support.v4.view.ViewPager 
    android:id="@+id/pager" 
    android:layout_width="fill_parent" 
    android:layout_height="fill_parent" /> 

也訪問那View Pager

+0

感謝您的答覆..我訪問你的鏈接,我檢查,並回到你,我做了什麼.. –

+1

我有導入示例代碼它是錯誤這個「NAT目錄路徑無效!請設置圖像目錄名稱AppConstant.java類」.. –

+0

檢查http://stackoverflow.com/questions/17973431/how-to-import-android-project-properly-into -eclipse –

2

嘗試使用這個庫,這將是非常有益的。它會節省很多時間。但是對於這兩種功能,您還必須使用viewpager。

https://github.com/Dreddik/AndroidTouchGallery

+0

我已經導入項目和庫..但項目給我錯誤,我右鍵單擊項目>屬性> java構建路徑>庫,在那裏android依賴顯示錯誤,當我錄音,它顯示Library.jar是錯過?任何想法。 –

+0

你添加了suport-v4 jar嗎? – keshav

+0

意味着圖書館沒有問題,例如問題? – keshav

2

下面的代碼可能對您有幫助。

首先創建適配器類。

public class FullScreenImageAdapter extends PagerAdapter { 
private Activity _activity; 
private ArrayList<String> _imagePaths; 
private LayoutInflater inflater; 
// constructor 
public FullScreenImageAdapter(Activity activity, 
     ArrayList<String> imagePaths) { 
    this._activity = activity; 
    this._imagePaths = imagePaths; 
} 
@Override 
public int getCount() { 
    return this._imagePaths.size(); 
} 
@Override 
public boolean isViewFromObject(View view, Object object) { 
    return view == ((RelativeLayout) object); 
} 
@Override 
public Object instantiateItem(ViewGroup container, int position) { 
    TouchImageView imgDisplay; 
    Button btnClose; 
    inflater = (LayoutInflater) _activity 
      .getSystemService(Context.LAYOUT_INFLATER_SERVICE); 
    View viewLayout = inflater.inflate(R.layout.layout_fullscreen_image, container, 
      false); 
    imgDisplay = (TouchImageView) viewLayout.findViewById(R.id.imgDisplay); 
    btnClose = (Button) viewLayout.findViewById(R.id.btnClose); 

    BitmapFactory.Options options = new BitmapFactory.Options(); 
    options.inPreferredConfig = Bitmap.Config.ARGB_8888; 
    Bitmap bitmap = BitmapFactory.decodeFile(_imagePaths.get(position), options); 
    imgDisplay.setImageBitmap(bitmap); 
    // close button click event 
    btnClose.setOnClickListener(new View.OnClickListener() {    
     @Override 
     public void onClick(View v) { 
      _activity.finish(); 
     } 
    }); 
    ((ViewPager) container).addView(viewLayout); 
    return viewLayout; 
} 
@Override 
public void destroyItem(ViewGroup container, int position, Object object) { 
    ((ViewPager) container).removeView((RelativeLayout) object); 
} 
} 

這是在這個類中使用的XML文件:

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

<info.androidhive.imageslider.helper.TouchImageView 
    android:id="@+id/imgDisplay" 
    android:layout_width="fill_parent" 
    android:layout_height="fill_parent" 
    android:scaleType="fitCenter" /> 

<Button 
    android:id="@+id/btnClose" 
    android:layout_width="wrap_content" 
    android:layout_height="30dp" 
    android:layout_alignParentRight="true" 
    android:layout_alignParentTop="true" 
    android:layout_marginRight="15dp" 
    android:layout_marginTop="15dp" 
    android:paddingTop="2dp" 
    android:paddingBottom="2dp" 
    android:background="@drawable/button_background" 
    android:textColor="#ffffff" 
    android:paddingLeft="10dp" 
    android:paddingRight="10dp" 
    android:text="Close" /> 

</RelativeLayout> 

這是活動:活動類的

import com.example.crystalgallery.R; 
import info.androidhive.imageslider.adapter.FullScreenImageAdapter; 
import info.androidhive.imageslider.helper.Utils; 
import android.app.Activity; 
import android.app.ActivityManager; 
import android.content.ComponentName; 
import android.content.Context; 
import android.content.Intent; 
import android.os.Bundle; 
import android.os.Handler; 
import android.support.v4.view.ViewPager; 

public class FullScreenViewActivity extends Activity{ 
private FullScreenImageAdapter adapter; 
private ViewPager viewPager; 

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

    viewPager = (ViewPager) findViewById(R.id.pager); 
    adapter = new FullScreenImageAdapter(FullScreenViewActivity.this, 
      FilePaths); 
    viewPager.setAdapter(adapter); 

    // displaying selected image first 
    viewPager.setCurrentItem("You can set the position of selected item here"); 
} 

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:orientation="vertical" 
android:background="#000000"> 

<android.support.v4.view.ViewPager 
    android:id="@+id/pager" 
    android:layout_width="fill_parent" 
    android:layout_height="fill_parent" /> 

</LinearLayout> 

TouchImageView .java

import android.content.Context; 
import android.graphics.Matrix; 
import android.graphics.PointF; 
import android.graphics.drawable.Drawable; 
import android.util.AttributeSet; 
import android.util.Log; 
import android.view.MotionEvent; 
import android.view.ScaleGestureDetector; 
import android.view.View; 
import android.widget.ImageView; 

public class TouchImageView extends ImageView { 

Matrix matrix; 

// We can be in one of these 3 states 
static final int NONE = 0; 
static final int DRAG = 1; 
static final int ZOOM = 2; 
int mode = NONE; 

// Remember some things for zooming 
PointF last = new PointF(); 
PointF start = new PointF(); 
float minScale = 1f; 
float maxScale = 3f; 
float[] m; 

int viewWidth, viewHeight; 
static final int CLICK = 3; 
float saveScale = 1f; 
protected float origWidth, origHeight; 
int oldMeasuredWidth, oldMeasuredHeight; 

ScaleGestureDetector mScaleDetector; 

Context context; 

public TouchImageView(Context context) { 
    super(context); 
    sharedConstructing(context); 
} 

public TouchImageView(Context context, AttributeSet attrs) { 
    super(context, attrs); 
    sharedConstructing(context); 
} 

private void sharedConstructing(Context context) { 
    super.setClickable(true); 
    this.context = context; 
    mScaleDetector = new ScaleGestureDetector(context, new ScaleListener()); 
    matrix = new Matrix(); 
    m = new float[9]; 
    setImageMatrix(matrix); 
    setScaleType(ScaleType.MATRIX); 

    setOnTouchListener(new OnTouchListener() { 

     @Override 
     public boolean onTouch(View v, MotionEvent event) { 
      mScaleDetector.onTouchEvent(event); 
      PointF curr = new PointF(event.getX(), event.getY()); 

      switch (event.getAction()) { 
      case MotionEvent.ACTION_DOWN: 
       last.set(curr); 
       start.set(last); 
       mode = DRAG; 
       break; 

      case MotionEvent.ACTION_MOVE: 
       if (mode == DRAG) { 
        float deltaX = curr.x - last.x; 
        float deltaY = curr.y - last.y; 
        float fixTransX = getFixDragTrans(deltaX, viewWidth, 
          origWidth * saveScale); 
        float fixTransY = getFixDragTrans(deltaY, viewHeight, 
          origHeight * saveScale); 
        matrix.postTranslate(fixTransX, fixTransY); 
        fixTrans(); 
        last.set(curr.x, curr.y); 
       } 
       break; 

      case MotionEvent.ACTION_UP: 
       mode = NONE; 
       int xDiff = (int) Math.abs(curr.x - start.x); 
       int yDiff = (int) Math.abs(curr.y - start.y); 
       if (xDiff < CLICK && yDiff < CLICK) 
        performClick(); 
       break; 

      case MotionEvent.ACTION_POINTER_UP: 
       mode = NONE; 
       break; 
      } 

      setImageMatrix(matrix); 
      invalidate(); 
      return true; // indicate event was handled 
     } 

    }); 
} 

public void setMaxZoom(float x) { 
    maxScale = x; 
} 

private class ScaleListener extends 
     ScaleGestureDetector.SimpleOnScaleGestureListener { 
    @Override 
    public boolean onScaleBegin(ScaleGestureDetector detector) { 
     mode = ZOOM; 
     return true; 
    } 

    @Override 
    public boolean onScale(ScaleGestureDetector detector) { 
     float mScaleFactor = detector.getScaleFactor(); 
     float origScale = saveScale; 
     saveScale *= mScaleFactor; 
     if (saveScale > maxScale) { 
      saveScale = maxScale; 
      mScaleFactor = maxScale/origScale; 
     } else if (saveScale < minScale) { 
      saveScale = minScale; 
      mScaleFactor = minScale/origScale; 
     } 

     if (origWidth * saveScale <= viewWidth 
       || origHeight * saveScale <= viewHeight) 
      matrix.postScale(mScaleFactor, mScaleFactor, viewWidth/2, 
        viewHeight/2); 
     else 
      matrix.postScale(mScaleFactor, mScaleFactor, 
        detector.getFocusX(), detector.getFocusY()); 

     fixTrans(); 
     return true; 
    } 
} 

void fixTrans() { 
    matrix.getValues(m); 
    float transX = m[Matrix.MTRANS_X]; 
    float transY = m[Matrix.MTRANS_Y]; 

    float fixTransX = getFixTrans(transX, viewWidth, origWidth * saveScale); 
    float fixTransY = getFixTrans(transY, viewHeight, origHeight 
      * saveScale); 

    if (fixTransX != 0 || fixTransY != 0) 
     matrix.postTranslate(fixTransX, fixTransY); 
} 

float getFixTrans(float trans, float viewSize, float contentSize) { 
    float minTrans, maxTrans; 

    if (contentSize <= viewSize) { 
     minTrans = 0; 
     maxTrans = viewSize - contentSize; 
    } else { 
     minTrans = viewSize - contentSize; 
     maxTrans = 0; 
    } 

    if (trans < minTrans) 
     return -trans + minTrans; 
    if (trans > maxTrans) 
     return -trans + maxTrans; 
    return 0; 
} 

float getFixDragTrans(float delta, float viewSize, float contentSize) { 
    if (contentSize <= viewSize) { 
     return 0; 
    } 
    return delta; 
} 

@Override 
protected void onMeasure(int widthMeasureSpec, int heightMeasureSpec) { 
    super.onMeasure(widthMeasureSpec, heightMeasureSpec); 
    viewWidth = MeasureSpec.getSize(widthMeasureSpec); 
    viewHeight = MeasureSpec.getSize(heightMeasureSpec); 

    // 
    // Rescales image on rotation 
    // 
    if (oldMeasuredHeight == viewWidth && oldMeasuredHeight == viewHeight 
      || viewWidth == 0 || viewHeight == 0) 
     return; 
    oldMeasuredHeight = viewHeight; 
    oldMeasuredWidth = viewWidth; 

    if (saveScale == 1) { 
     // Fit to screen. 
     float scale; 

     Drawable drawable = getDrawable(); 
     if (drawable == null || drawable.getIntrinsicWidth() == 0 
       || drawable.getIntrinsicHeight() == 0) 
      return; 
     int bmWidth = drawable.getIntrinsicWidth(); 
     int bmHeight = drawable.getIntrinsicHeight(); 

     Log.d("bmSize", "bmWidth: " + bmWidth + " bmHeight : " + bmHeight); 

     float scaleX = (float) viewWidth/(float) bmWidth; 
     float scaleY = (float) viewHeight/(float) bmHeight; 
     scale = Math.min(scaleX, scaleY); 
     matrix.setScale(scale, scale); 

     // Center the image 
     float redundantYSpace = (float) viewHeight 
       - (scale * (float) bmHeight); 
     float redundantXSpace = (float) viewWidth 
       - (scale * (float) bmWidth); 
     redundantYSpace /= (float) 2; 
     redundantXSpace /= (float) 2; 

     matrix.postTranslate(redundantXSpace, redundantYSpace); 

     origWidth = viewWidth - 2 * redundantXSpace; 
     origHeight = viewHeight - 2 * redundantYSpace; 
     setImageMatrix(matrix); 
    } 
    fixTrans(); 
} 
} 

注意:嘗試更改此代碼和xml中使用的包名稱。

您可以全屏打開圖像,現在可以輕掃。在這個代碼中有一個按鈕來關閉全屏圖像。如果你不需要,那麼避免創建按鈕和點擊。

+1

非常感謝你的答案。我會檢查,現在currentely我已經開始另一個模塊,當完成當前模塊,然後我回到與手指滑動模塊的圖像滑塊,我會讓你知道。 –

+0

@FarhanShah:好的。快樂的編碼。 – Shahina