亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

Android UI控件之Gallery實(shí)現(xiàn)拖動(dòng)式圖片瀏覽效果

 更新時(shí)間:2021年01月22日 10:35:37   作者:LCore  
這篇文章主要為大家詳細(xì)介紹了Android UI控件之Gallery實(shí)現(xiàn)拖動(dòng)式圖片瀏覽效果,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下

我們知道現(xiàn)在智能手機(jī)上都有這樣一種功能,就是你在瀏覽圖片的時(shí)候。不是硬性的點(diǎn)擊按鈕而是可以實(shí)現(xiàn)手指的拖動(dòng),劃開(kāi)效果。使用戶具有更好的交互體驗(yàn),不過(guò)這種效果是如何實(shí)現(xiàn)的呢?

在Android中是通過(guò)Gallery來(lái)實(shí)現(xiàn)拖動(dòng)效果的。

通過(guò)Gallery可以實(shí)現(xiàn)各種各樣的效果,此篇文章只是簡(jiǎn)要談?wù)勊挠梅?,至于后續(xù)的一些效果

有機(jī)會(huì)的時(shí)候做一個(gè)整理。 

首先看看其簡(jiǎn)單實(shí)現(xiàn)吧!本次實(shí)例是通過(guò)選取圖片實(shí)現(xiàn)類(lèi)似設(shè)置背景的功能!

不過(guò)需要說(shuō)明的是:圖片不宜過(guò)大,否則容易內(nèi)存溢出,android對(duì)大圖片的支持不好!

我們來(lái)看看切換之后的效果吧

看看重新設(shè)置一幅背景圖片!

怎么樣一個(gè)簡(jiǎn)單的效果就出來(lái)了吧!

下面是具體的實(shí)現(xiàn)方法:

xml文件:

<?xml version="1.0" encoding="utf-8"?> 
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" 
 android:orientation="vertical" 
 android:layout_width="fill_parent" 
 android:layout_height="fill_parent" 
 > 
 <Gallery 
 android:id="@+id/gallery1" 
 android:layout_height="fill_parent" 
 android:layout_width="fill_parent" 
 android:spacing="3px" 
 > 
 </Gallery> 
</LinearLayout> 

 MainActivity文件:

package com.kiritor.ui_gallery; 
 
import android.app.Activity; 
import android.graphics.Color; 
import android.os.Bundle; 
import android.view.View; 
import android.widget.AdapterView; 
import android.widget.AdapterView.OnItemClickListener; 
import android.widget.Gallery; 
import android.widget.Toast; 
 
/** 
 * @author 記憶的永恒 
 * 
 */ 
public class MainActivity extends Activity { 
 @Override 
 public void onCreate(Bundle savedInstanceState) { 
  super.onCreate(savedInstanceState); 
  setContentView(R.layout.activity_main); 
 
  final Gallery gallery = (Gallery) findViewById(R.id.gallery1); 
  // 將存放圖片的ImageAdapter給gallery對(duì)象 
  gallery.setAdapter(new ImageAdapter(this)); 
 
  // 設(shè)置gallery 的背景圖片 
  gallery.setBackgroundResource(R.drawable.first); 
 
  // 設(shè)置Gallery的監(jiān)聽(tīng)事件 
  gallery.setOnItemClickListener(new OnItemClickListener() { 
   @Override 
   public void onItemClick(AdapterView<?> arg0, View arg1, int arg2, 
     long arg3) { 
    switch (arg2) { 
    case 0: 
     gallery.setBackgroundResource(R.drawable.first); 
     break; 
    case 1: 
     gallery.setBackgroundResource(R.drawable.second); 
     break; 
    case 2: 
     gallery.setBackgroundResource(R.drawable.third); 
     break; 
    case 3: 
     gallery.setBackgroundResource(R.drawable.forth); 
     break; 
    case 4: 
     gallery.setBackgroundResource(R.drawable.fifth); 
     break; 
    default: 
     break; 
    } 
   } 
  }); 
 } 
} 

 自己實(shí)現(xiàn)一個(gè)ImageAdapter繼承與BaseAdapter實(shí)現(xiàn)適配器

package com.kiritor.ui_gallery; 
 
import android.content.Context; 
import android.view.View; 
import android.view.ViewGroup; 
import android.widget.BaseAdapter; 
import android.widget.Gallery; 
import android.widget.ImageView; 
 
public class ImageAdapter extends BaseAdapter{ 
 
//定義Content 
private Context mContext; 
//定義一個(gè)數(shù)組,存放圖片資源 
private Integer[] mImageIds = { 
 R.drawable.first, 
 R.drawable.second, 
 R.drawable.third, 
 R.drawable.forth, 
 R.drawable.fifth, 
  
}; 
 
 //構(gòu)造 
 public ImageAdapter(Context c){ 
 mContext = c; 
 } 
 
 //獲取圖片的個(gè)數(shù) 
 public int getCount() { 
 // TODO Auto-generated method stub 
 return mImageIds.length; 
 } 
 
 //獲取圖片在庫(kù)中的位置 
 public Object getItem(int position) { 
 // TODO Auto-generated method stub 
 return position; 
 } 
 
 //獲取圖片在庫(kù)中的ID 
 public long getItemId(int position) { 
 // TODO Auto-generated method stub 
 return position; 
 } 
 
 //將圖片取出來(lái) 
 public View getView(int position, View convertView, ViewGroup parent) { 
 //要取出圖片,即要定義一個(gè)ImageView來(lái)存 
 ImageView imageView = new ImageView(mContext); 
 imageView.setImageResource(mImageIds[position]); 
 //設(shè)置顯示比例類(lèi)型 
 
 
 
 //設(shè)置布局圖片以105*150顯示 (簡(jiǎn)單解釋——設(shè)置數(shù)字不一樣,圖片的顯示大小不一樣) 
 imageView.setLayoutParams(new Gallery.LayoutParams(240, 200)); 
 
 
 imageView.setScaleType(ImageView.ScaleType.FIT_CENTER); 
 return imageView; 
 } 
 
} 

 Over!一個(gè)簡(jiǎn)單的圖片拖動(dòng)展示外加設(shè)置背景圖片的小功能就實(shí)現(xiàn)了。

下面是項(xiàng)目完整代碼部分:Gallery實(shí)現(xiàn)拖動(dòng)式圖片瀏覽效果

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

最新評(píng)論