Android使用gallery和imageSwitch制作可左右循環(huán)滑動的圖片瀏覽器
效果圖:
為了使圖片瀏覽器左右無限循環(huán)滑動 我們要自定義gallery的adapter
如果要想自定義adapter首先要了解這幾個方法
@Override public int getCount() { // TODO Auto-generated method stub return 0; } @Override public Object getItem(int position) { // TODO Auto-generated method stub return null; } @Override public long getItemId(int position) { // TODO Auto-generated method stub return 0; } @Override public View getView(int position, View convertView, ViewGroup parent) { // TODO Auto-generated method stub return null; }
其中g(shù)etCount方法 是返回數(shù)據(jù)源的數(shù)量
getItem方法 返回的是一個object對象 也就是返回目前容器中數(shù)據(jù)ID position所對應(yīng)的對象
getItemId 返回目前容器中的數(shù)據(jù)ID
getView取得目前要顯示的View
如果要實現(xiàn)左右循環(huán)滑動 首先我們要返回數(shù)據(jù)源的數(shù)量為最大值 然后把所有數(shù)據(jù)的ID對原本數(shù)據(jù)源的數(shù)量取余 最后設(shè)置gallery初始的位置在0-最大值的中間即可
更改后的adapter就是這樣
package com.example.imageswitcher; import android.content.Context; import android.view.View; import android.view.ViewGroup; import android.widget.BaseAdapter; import android.widget.Gallery; import android.widget.ImageView; import android.widget.ImageView.ScaleType; public class MyAdapter extends BaseAdapter{ private int id_image[]; private Context contex; public MyAdapter(Context contex,int id_image[]) { this.contex=contex; this.id_image=id_image; } @Override public int getCount() { // TODO Auto-generated method stub return Integer.MAX_VALUE; } @Override public Object getItem(int position) { // TODO Auto-generated method stub return id_image[position%id_image.length]; } @Override public long getItemId(int position) { // TODO Auto-generated method stub return position%id_image.length; } @Override public View getView(int position, View convertView, ViewGroup parent) { // TODO Auto-generated method stub ImageView imageView=new ImageView(contex); imageView.setBackgroundResource(id_image[position%id_image.length]); imageView.setLayoutParams(new Gallery.LayoutParams(250, 200)); imageView.setScaleType(ScaleType.FIT_XY); return imageView; } }
MainActivity
package com.example.imageswitcher; import android.os.Bundle; import android.app.Activity; import android.view.LayoutInflater.Factory; import android.view.Menu; import android.view.View; import android.view.Window; import android.view.animation.AnimationUtils; import android.widget.AdapterView; import android.widget.AdapterView.OnItemSelectedListener; import android.widget.Gallery; import android.widget.ImageSwitcher; import android.widget.ImageView; import android.widget.ImageView.ScaleType; import android.widget.ViewSwitcher.ViewFactory; public class MainActivity extends Activity implements OnItemSelectedListener,ViewFactory{ private ImageSwitcher imageSwitcher; private Gallery gallery; private int id_image[] = { R.drawable.beauty1, R.drawable.beauty2, R.drawable.beauty3, R.drawable.beauty4, R.drawable.beauty5, R.drawable.beauty6, R.drawable.beauty7, R.drawable.beauty8, R.drawable.beauty9}; private MyAdapter myAdapter; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); requestWindowFeature(Window.FEATURE_NO_TITLE); setContentView(R.layout.activity_main); gallery = (Gallery) findViewById(R.id.id_gallery); imageSwitcher = (ImageSwitcher) findViewById(R.id.id_imageSwitcher); myAdapter=new MyAdapter(this, id_image); imageSwitcher.setFactory(this); gallery.setOnItemSelectedListener(this); //設(shè)置淡入淡出效果 imageSwitcher.setInAnimation(AnimationUtils.loadAnimation(this, android.R.anim.fade_in)); imageSwitcher.setOutAnimation(AnimationUtils.loadAnimation(this, android.R.anim.fade_out)); gallery.setAdapter(myAdapter); //一定不要忘記 設(shè)置gallery的初始位置為中間即可 gallery.setSelection(id_image.length*100); } @Override public void onItemSelected(AdapterView<?> parent, View view, int position, long id) { // TODO Auto-generated method stub imageSwitcher.setBackgroundResource(id_image[position%id_image.length]); } @Override public void onNothingSelected(AdapterView<?> parent) { // TODO Auto-generated method stub } @Override public View makeView() { // TODO Auto-generated method stub ImageView image=new ImageView(this); image.setScaleType(ScaleType.FIT_CENTER); return image; } }
以上就是本文的全部內(nèi)容,希望本文的內(nèi)容對大家的學(xué)習(xí)或者工作能帶來一定的幫助,同時也希望多多支持腳本之家!
相關(guān)文章
Android GridView中包含EditText的焦點重新獲取方法
這篇文章主要介紹了Android GridView中包含EditText的焦點重新獲取方法,實例分析了界面刷新時EditText重新獲取焦點的技巧,需要的朋友可以參考下2016-03-03Android?Jetpack?組件LiveData源碼解析
這篇文章主要為大家介紹了Android?Jetpack?組件LiveData源碼解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2023-03-03android 調(diào)用JNI SO動態(tài)庫的方法
android 調(diào)用JNI 分為靜態(tài)調(diào)用與動態(tài)調(diào)用,接下來通過本文給大家介紹android 調(diào)用JNI SO動態(tài)庫的方法,感興趣的朋友一起看看吧2021-11-11Input系統(tǒng)分發(fā)策略及其應(yīng)用示例詳解
這篇文章主要為大家介紹了Input系統(tǒng)分發(fā)策略及其應(yīng)用示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2023-02-02Android應(yīng)用中炫酷的橫向和環(huán)形進度條的實例分享
這篇文章主要介紹了Android應(yīng)用中炫酷的橫向和圓形進度條的實例分享,文中利用了一些GitHub上的插件進行改寫,也是一片很好的二次開發(fā)教學(xué),需要的朋友可以參考下2016-04-04強制去除Unity自動添加的Android隱私權(quán)限
大家好,本篇文章主要講的是強制去除Unity自動添加的Android隱私權(quán)限,感興趣的同學(xué)趕快來看一看吧,對你有幫助的話記得收藏一下,方便下次瀏覽2021-12-12