您好,登錄后才能下訂單哦!
本篇文章給大家分享的是有關如何在Android中使用ImageSwitcher實現一個相冊功能,小編覺得挺實用的,因此分享給大家學習,希望大家閱讀完這篇文章后可以有所收獲,話不多說,跟著小編一起來看看吧。
<?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" android:gravity="center_horizontal"> <!--定義一個GridView組件--> <GridView android:id="@+id/grid01" android:layout_width="match_parent" android:layout_height="match_parent" android:listSelector="@null" android:numColumns="3" android:horizontalSpacing="2dp" android:verticalSpacing="2dp" android:gravity="center"> </GridView> <!--定義一個ImageSwitcher組件--> <ImageSwitcher android:id="@+id/switcher" android:layout_width="match_parent" android:layout_height="match_parent" android:layout_gravity="center_horizontal" android:padding="50dp" android:inAnimation="@android:anim/fade_in" android:outAnimation="@android:anim/fade_out" android:background="@color/colorPrimaryDark" android:visibility="gone"> </ImageSwitcher> </RelativeLayout>
關于GridView 有兩種常用的監聽事件:
gridView.setOnItemSelectedListener
和 gridView.setOnItemClickListener
關于ImageSwitcher 設置ImageSwitcher 采用了imageSwitcher.setFactory
方法:
public class MainActivity extends Activity { int[] imageId = new int[]{ R.drawable.a0,R.drawable.a1,R.drawable.a2,R.drawable.a4, R.drawable.a5,R.drawable.a6,R.drawable.a7,R.drawable.a8, R.drawable.a9,R.drawable.a00,R.drawable.a02,R.drawable.a02, }; ImageSwitcher imageSwitcher ; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); //創建一個List對象,list對象的元素是Map List<Map<String,Object>> listitems = new ArrayList<Map<String, Object>>(); for (int i = 0 ; i < imageId.length ; i++ ){ Map<String,Object> listitem = new HashMap<String, Object>(); listitem.put("image",imageId[i]); listitems.add(listitem); } //獲取顯示圖片的ImageSwitcher imageSwitcher = (ImageSwitcher) findViewById(R.id.switcher); //為ImageSwitcher設置動畫效果 imageSwitcher.setFactory(new ViewSwitcher.ViewFactory() { @Override public View makeView() { //創建ImageView對象 ImageView imageView = new ImageView(MainActivity.this); imageView.setScaleType(ImageView.ScaleType.FIT_XY); imageView.setLayoutParams(new ImageSwitcher.LayoutParams(ViewGroup.LayoutParams.MATCH_PARENT,ViewGroup.LayoutParams.MATCH_PARENT)); //返回ImageView對象 return imageView; } }); //創建一個SimpleAdapter SimpleAdapter simpleAdapter = new SimpleAdapter(this,listitems,R.layout.cell,new String[]{"image"},new int[]{R.id.image1}); GridView gridView = (GridView) findViewById(R.id.grid01); //為gridView設置adapter gridView.setAdapter(simpleAdapter); //添加列表選中監聽事件 gridView.setOnItemSelectedListener(new AdapterView.OnItemSelectedListener() { @Override public void onItemSelected(AdapterView<?> parent, View view, int position, long id) { imageSwitcher.setVisibility(View.VISIBLE); imageSwitcher.setClickable(true); //顯示當前選中圖片 imageSwitcher.setImageResource(imageId[position]); } @Override public void onNothingSelected(AdapterView<?> parent) { } }); //添加列表被單擊的監聽器 gridView.setOnItemClickListener(new AdapterView.OnItemClickListener() { @Override public void onItemClick(AdapterView<?> parent, View view, int position, long id) { imageSwitcher.setVisibility(View.VISIBLE); imageSwitcher.setClickable(true); //顯示被單擊圖片 imageSwitcher.setImageResource(imageId[position]); } }); //為imageSwitcher添加監聽事件 imageSwitcher.setOnClickListener(new View.OnClickListener() { @Override public void onClick(View v) { imageSwitcher.setVisibility(View.GONE); imageSwitcher.setClickable(false); } }); imageSwitcher.setClickable(false); } }
幾點值得注意的:
由于SimpleAdapter 對象 是根據Map 建立的 ,所以他們的Key一定要相同才行,否則無法生成。
關于閃退現象:我才用的是經過壓縮過的圖片,如果是加載高清大圖很可能出現OOM現象,這是我們需要對圖片進行壓縮
這里cell文件還是和往常一樣,只是個簡單的ImageView罷了,注意設置它的 id 要與活動中調用它的地方相同,這里就不過多描述了。
以上就是如何在Android中使用ImageSwitcher實現一個相冊功能,小編相信有部分知識點可能是我們日常工作會見到或用到的。希望你能通過這篇文章學到更多知識。更多詳情敬請關注億速云行業資訊頻道。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。