欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Android編程滑動效果之Gallery+GridView實(shí)現(xiàn)圖片預(yù)覽功能(附demo源碼下載)

 更新時間:2016年02月12日 11:52:24   作者:陽光島主  
這篇文章主要介紹了Android編程滑動效果之Gallery+GridView實(shí)現(xiàn)圖片預(yù)覽功能,結(jié)合實(shí)例形式分析了Android通過GridView和Gallery兩個控件模仿Gallery圖像集圖片預(yù)覽功能,并附帶demo源碼供讀者下載參考,需要的朋友可以參考下

本文實(shí)例講述了Android編程滑動效果之Gallery+GridView實(shí)現(xiàn)圖片預(yù)覽功能。分享給大家供大家參考,具體如下:

Android系統(tǒng)自帶一個GridView和Gallery兩個控件,GridView網(wǎng)格顯示,Gallery單個瀏覽,兩者結(jié)合起來可以真正實(shí)現(xiàn)Gallery瀏覽圖片效果。

本示例通過GridView和Gallery兩個控件,模仿實(shí)現(xiàn)一個完整的仿Gallery圖像集的圖片瀏覽效果。效果圖如下:

1、GridView

首先,自定義一個GridImageAdapter圖片適配器,用于填充GridView控件的圖片

public class GridImageAdapter extends BaseAdapter {
  private Context mContext;
  Drawable btnDrawable;
  public GridImageAdapter(Context context) {
    mContext = context;
    Resources resources = context.getResources();
    btnDrawable = resources.getDrawable(R.drawable.bg);
  }
  @Override
  public int getCount() {
    return ImageSource.mThumbIds.length;
  }
  @Override
  public Object getItem(int position) {
    return position;
  }
  @Override
  public long getItemId(int position) {
    return position;
  }
  @Override
  public View getView(int position, View convertView, ViewGroup parent) {
    ImageViewExt imageView;
    int space;
    if (convertView == null) {
      imageView = new ImageViewExt(mContext);
      if (imageCol == 5) {
        space = dm.heightPixels / imageCol - 6;
        imageView.setLayoutParams(new GridView.LayoutParams(space, space));
      } else {
        space = dm.widthPixels / imageCol - 6;
        imageView.setLayoutParams(new GridView.LayoutParams( space, space));
      }
      imageView.setAdjustViewBounds(true);
      imageView.setScaleType(ImageView.ScaleType.CENTER_CROP);  // 縮放圖片使其長和寬一樣
       imageView.setPadding(3, 3, 3, 3);
    } else {
      imageView = (ImageViewExt) convertView;
    }
    imageView.setImageResource(ImageSource.mThumbIds[position]);
    return imageView;
  }
}

然后,用GridImageAdapter填充GridView

gridView = (GridView) findViewById(R.id.myGrid);
gridImageAdapter = new GridImageAdapter(this);
gridView.setAdapter(gridImageAdapter);
gridView.setOnItemClickListener(listener); // 設(shè)置點(diǎn)擊監(jiān)聽事件

最后,設(shè)置GridView控件的點(diǎn)擊監(jiān)聽事件

AdapterView.OnItemClickListener listener = new AdapterView.OnItemClickListener() {
  @Override
  public void onItemClick(AdapterView<?> arg0, View arg1, int position, long id) {
    Intent intent = new Intent();
    intent.setClass(GridViewActivity.this, GalleryActivity.class);
    intent.putExtra("position", position);
    startActivity(intent);
  }
};

2、Gallery

完成了GridView的圖片顯示、監(jiān)聽事件后,現(xiàn)在點(diǎn)擊圖片,會啟動一個Activity來顯示當(dāng)前點(diǎn)擊的圖片,此時顯示圖片的控件便是Gallery

首先,同GridView一樣,自定義一個ImageAdapter圖片適配器,用來填充Gallery

public class ImageAdapter extends BaseAdapter {
  private Context mContext;
  private int mPos;
  public ImageAdapter(Context context) {
    mContext = context;
  }
  public void setOwnposition(int ownposition) {
    this.mPos = ownposition;
  }
  public int getOwnposition() {
    return mPos;
  }
  @Override
  public int getCount() {
    return ImageSource.mThumbIds.length;
  }
  @Override
  public Object getItem(int position) {
    mPos=position;
    return position;
  }
  @Override
  public long getItemId(int position) {
    mPos=position;
    return position;
  }
  @Override
  public View getView(int position, View convertView, ViewGroup parent) {
    mPos=position;
    ImageView imageview = new ImageView(mContext);
    imageview.setBackgroundColor(0xFF000000);
    imageview.setScaleType(ImageView.ScaleType.FIT_CENTER);
    imageview.setLayoutParams(new myGallery.LayoutParams(LayoutParams.MATCH_PARENT, LayoutParams.MATCH_PARENT));
    imageview.setImageResource(ImageSource.mThumbIds[position]);
    return imageview;
  }
}

然后,用ImageAdapter填充Gallery

myGallery galllery = (myGallery) findViewById(R.id.mygallery);
Intent intent = getIntent();
position = intent.getIntExtra("position", 0); // 獲取GridViewActivity傳來的圖片位置position
ImageAdapter imgAdapter=new ImageAdapter(this);
galllery.setAdapter(imgAdapter); // 設(shè)置圖片ImageAdapter
galllery.setSelection(position); // 設(shè)置當(dāng)前顯示圖片
  Animation an= AnimationUtils.loadAnimation(this,R.anim.scale ); // Gallery動畫
  galllery.setAnimation(an);

此時,如果細(xì)心可以注意到,我們的Gallery也是自己定義的myGallery,具體定義如下:

public class myGallery extends Gallery {
  boolean isFirst = false;
  boolean isLast = false;
  public myGallery(Context context) {
    super(context);
  }
  public myGallery(Context context, AttributeSet paramAttributeSet) {
    super(context, paramAttributeSet);
  }
  /** 是否向左滑動(true - 向左滑動; false - 向右滑動) */
  private boolean isScrollingLeft(MotionEvent e1, MotionEvent e2) {
    return e2.getX() > e1.getX();
  }
  @Override
  public boolean onFling(MotionEvent e1, MotionEvent e2, float distanceX, float distanceY) {
    ImageAdapter ia = (ImageAdapter) this.getAdapter();
    int p = ia.getOwnposition(); // 獲取當(dāng)前圖片的position
    int count = ia.getCount(); // 獲取全部圖片的總數(shù)count
    int kEvent;
    if (isScrollingLeft(e1, e2)) {
      if (p == 0 && isFirst) {
        Toast.makeText(this.getContext(), "已是第一頁", Toast.LENGTH_SHORT).show();
      } else if (p == 0) {
        isFirst = true;
      } else {
        isLast = false;
      }
      kEvent = KeyEvent.KEYCODE_DPAD_LEFT;
    } else {
      if (p == count - 1 && isLast) {
        Toast.makeText(this.getContext(), "已到最后一頁", Toast.LENGTH_SHORT).show();
      } else if (p == count - 1) {
        isLast = true;
      } else {
        isFirst = false;
      }
      kEvent = KeyEvent.KEYCODE_DPAD_RIGHT;
    }
    onKeyDown(kEvent, null);
    return true;
  }
}

GalleryActivity的布局文件gallery.xml

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
  android:layout_width="match_parent"
  android:layout_height="match_parent"
  android:gravity="center"
  android:orientation="horizontal"
  android:padding="10dip" >
  <RelativeLayout
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:background="#000000"
    android:padding="2dip" >
    <com.homer.gridgallery.myGallery
      android:id="@+id/mygallery"
      android:layout_width="fill_parent"
      android:layout_height="fill_parent"
      android:spacing="16dp" />
  </RelativeLayout>
</LinearLayout>

完整實(shí)例代碼點(diǎn)擊此處本站下載

更多關(guān)于Android相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《Android開發(fā)動畫技巧匯總》、《Android開發(fā)入門與進(jìn)階教程》及《Android控件用法總結(jié)》。

希望本文所述對大家Android程序設(shè)計(jì)有所幫助。

相關(guān)文章

  • Android自定義漂亮的圓形進(jìn)度條

    Android自定義漂亮的圓形進(jìn)度條

    這篇文章主要介紹了Android自定義漂亮的圓形進(jìn)度條,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-01-01
  • Android應(yīng)用中使用及實(shí)現(xiàn)系統(tǒng)“分享”接口實(shí)例

    Android應(yīng)用中使用及實(shí)現(xiàn)系統(tǒng)“分享”接口實(shí)例

    為了應(yīng)用的推廣、傳播,很多的應(yīng)用中都有“分享”功能,這篇文章主要介紹了Android應(yīng)用中使用及實(shí)現(xiàn)系統(tǒng)“分享”接口實(shí)例,有興趣的可以了解一下。
    2016-12-12
  • Android通過BLE傳輸文件遇到問題解決

    Android通過BLE傳輸文件遇到問題解決

    這篇文章主要為大家介紹了Android通過BLE傳輸文件遇到問題解決方法,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-04-04
  • 談?wù)凙ndroid6.0運(yùn)行時的權(quán)限處理

    談?wù)凙ndroid6.0運(yùn)行時的權(quán)限處理

    之前有人在 Android 6.0 的機(jī)型上運(yùn)行了DragGridView結(jié)果出異常奔潰了。想必問題的原因大家都知道,是Android 6.0新引入了在運(yùn)行時權(quán)限申請(Runtime Permissions)的功能。那么這所謂的運(yùn)行時申請權(quán)限究竟是怎么一回事呢,下面跟著小編一起來看看吧!
    2016-08-08
  • android ListView深入理解

    android ListView深入理解

    在android開發(fā)中ListView是比較常用的組件,它以列表的形式展示具體內(nèi)容,并且能夠根據(jù)數(shù)據(jù)的長度自適應(yīng)顯示。抽空把對ListView的使用做了整理,需要的朋友可以參考下
    2012-11-11
  • AndroidQ 沙箱適配多媒體文件(小結(jié))

    AndroidQ 沙箱適配多媒體文件(小結(jié))

    這篇文章主要介紹了AndroidQ 沙箱適配多媒體文件(小結(jié)),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-11-11
  • Android實(shí)現(xiàn)音樂視頻播放

    Android實(shí)現(xiàn)音樂視頻播放

    這篇文章主要為大家詳細(xì)介紹了Android實(shí)現(xiàn)音樂視頻播放,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-05-05
  • Kotlin基礎(chǔ)學(xué)習(xí)之lambda中return語句詳解

    Kotlin基礎(chǔ)學(xué)習(xí)之lambda中return語句詳解

    這篇文章主要給大家介紹了關(guān)于Kotlin基礎(chǔ)學(xué)習(xí)之lambda中return語句的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家學(xué)習(xí)或使用Kotlin具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2018-07-07
  • Android tabLayout+recyclerView實(shí)現(xiàn)錨點(diǎn)定位的示例

    Android tabLayout+recyclerView實(shí)現(xiàn)錨點(diǎn)定位的示例

    這篇文章主要介紹了Android tabLayout+recyclerView實(shí)現(xiàn)錨點(diǎn)定位的示例,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-08-08
  • Android實(shí)現(xiàn)判斷手機(jī)未接來電及處理方法

    Android實(shí)現(xiàn)判斷手機(jī)未接來電及處理方法

    這篇文章主要介紹了Android實(shí)現(xiàn)判斷手機(jī)未接來電及處理方法,需要的朋友可以參考下
    2014-07-07

最新評論