2012-10-14 4 views
8

Ich verwende ViewPager, um Bilder vom Remote-Server abzurufen. Alles funktioniert gut, aber das Problem ist, ich weiß nicht, wie Pinch Zoom in/out-Funktion zu implementieren. Mein Code ist untenImplementieren von Pinch Zoom mit ViewPager

public class ImagePagerActivity extends BaseActivity { 

    private ViewPager pager; 

    private DisplayImageOptions options; 

    public void onCreate(Bundle savedInstanceState) { 
    super.onCreate(savedInstanceState); 

    setContentView(R.layout.ac_image_pager); 
    Bundle bundle = getIntent().getExtras(); 
    String[] imageUrls = bundle.getStringArray(Extra.IMAGES); 
    int pagerPosition = bundle.getInt(Extra.IMAGE_POSITION, 0); 

    options = new DisplayImageOptions.Builder() 
       .showImageForEmptyUri(R.drawable.image_for_empty_url) 
       .cacheOnDisc() 
       .imageScaleType(ImageScaleType.IN_SAMPLE_INT) 
       .build(); 

    pager = (ViewPager) findViewById(R.id.pager); 
    pager.setAdapter(new ImagePagerAdapter(imageUrls)); 
    pager.setCurrentItem(pagerPosition); 

    } 

    protected void onStop() { 
    imageLoader.stop(); 
    super.onStop(); 
    } 

    private class ImagePagerAdapter extends PagerAdapter { 

    private String[] images; 
    private LayoutInflater inflater; 

    ImagePagerAdapter(String[] images) { 
    this.images = images; 
    inflater = getLayoutInflater(); 
    } 

    public void destroyItem(View container, int position, Object object) { 
    ((ViewPager) container).removeView((View) object); 
    } 

    public void finishUpdate(View container) { 
    } 

    public int getCount() { 
    return images.length; 
    } 

    public Object instantiateItem(View view, int position) { 
       final View imageLayout = inflater.inflate(R.layout.item_pager_image, null); 
       final ImageView imageView = (ImageView) imageLayout.findViewById(R.id.image); 
       final ProgressBar spinner = (ProgressBar) imageLayout.findViewById(R.id.loading); 

    imageLoader.displayImage(images[position], imageView, options, new ImageLoadingListener() { 

    public void onLoadingStarted() { 
    spinner.setVisibility(View.VISIBLE); 
    } 


    public void onLoadingFailed(FailReason failReason) { 
    String message = null; 
    switch (failReason) { 
    case IO_ERROR: 
    message = "Input/Output error"; 
    break; 
    case OUT_OF_MEMORY: 
    message = "Out Of Memory error"; 
    break; 
    case UNKNOWN: 
    message = "Unknown error"; 
    break; 
    } 
    Toast.makeText(ImagePagerActivity.this, message, Toast.LENGTH_SHORT).show(); 

    spinner.setVisibility(View.GONE); 
           imageView.setImageResource(android.R.drawable.ic_delete); 
        } 


    public void onLoadingComplete(Bitmap loadedImage) { 
    spinner.setVisibility(View.GONE); 
    Animation anim = AnimationUtils.loadAnimation(ImagePagerActivity.this, R.anim.fade_in); 
    imageView.setAnimation(anim); 
    anim.start(); 
    } 

    public void onLoadingCancelled() { 
    // Do nothing 
    } 
    }); 

    ((ViewPager) view).addView(imageLayout, 0); 
    return imageLayout; 
    } 

    public boolean isViewFromObject(View view, Object object) { 
    return view.equals(object); 
    } 

    public void restoreState(Parcelable state, ClassLoader loader) { 
    } 
    public Parcelable saveState() { 
    return null; 
    } 

    public void startUpdate(View container) { 
    } 
    } 
    } 
+1

Dies scheint wie eine grundlegende Funktion, die vererbt werden sollte, wenn ein Bild vorhanden ist. Verstehe nicht, warum Google dies nicht als Option in einer Bildansicht zur Verfügung gestellt hat – JPM

Antwort

6

wenn Ihr viewpager ein Imageview verwendet, dann können Sie touchImageView

https://github.com/MikeOrtiz/TouchImageView/blob/master/src/com/example/touch/TouchImageView.java

nur ersetzen Ihre aktuelle Imageview mit dieser benutzerdefinierten Ansicht verwenden. goodluck

+0

Danke, das war ziemlich hilfreich :) Wird versuchen und aktualisieren Sie das Ergebnis. – iabhi

+5

Dies scheint meistens zu funktionieren, obwohl die Aktion des Pagers gegen die Aktionen des touchimageview zu kämpfen scheint, und der Versuch, Pinch-Zoom zu ziehen, beginnt ebenfalls mit dem Umblättern der Seite. Und sobald sich die Seite zu drehen beginnt, endet die Pinch-Zoom-Aktion. Erfordern mehrere sorgfältige Versuche, wirklich erfolgreich zu zoomen. – directedition

+0

Es zoomt nicht wie Vollbild. Aber die Zoom-Steuerung funktioniert gut. Kannst du mir helfen, es mit Vollbild zu zoomen? –