Android開(kāi)發(fā)之ImageSwitcher相冊(cè)功能實(shí)例分析
本文實(shí)例講述了Android開(kāi)發(fā)之ImageSwitcher相冊(cè)功能。分享給大家供大家參考,具體如下:
簡(jiǎn)介:
1.ImageSwitcher是viewSwitcher的子類,所以ImageSwitcher繼承了ViewSwitcher素有的特性
2.作為ViewSwitcher的子類,它比ViewSwitcher使用更加方便,主要體現(xiàn)在:①. 重寫(xiě)了setNext()
②. 重寫(xiě)了showPrevious()
方法。所以其實(shí)用起來(lái),要比ViewSwitcher更為方便。
3.中重要的是:ImageSwitcher增加了圖片切換動(dòng)畫(huà),使得圖片的切換更加自然
這里看下運(yùn)行效果:
這個(gè)例子中,看考了瘋狂Android講義,采用ImageSwicher結(jié)合Gridview實(shí)現(xiàn)的,一下問(wèn)布局文件:
<?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"> <!--定義一個(gè)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> <!--定義一個(gè)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>
關(guān)于GridView 有兩種常用的監(jiān)聽(tīng)事件:
gridView.setOnItemSelectedListener
和 gridView.setOnItemClickListener
關(guān)于ImageSwitcher 設(shè)置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); //創(chuàng)建一個(gè)List對(duì)象,list對(duì)象的元素是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設(shè)置動(dòng)畫(huà)效果 imageSwitcher.setFactory(new ViewSwitcher.ViewFactory() { @Override public View makeView() { //創(chuàng)建ImageView對(duì)象 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對(duì)象 return imageView; } }); //創(chuàng)建一個(gè)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設(shè)置adapter gridView.setAdapter(simpleAdapter); //添加列表選中監(jiān)聽(tīng)事件 gridView.setOnItemSelectedListener(new AdapterView.OnItemSelectedListener() { @Override public void onItemSelected(AdapterView<?> parent, View view, int position, long id) { imageSwitcher.setVisibility(View.VISIBLE); imageSwitcher.setClickable(true); //顯示當(dāng)前選中圖片 imageSwitcher.setImageResource(imageId[position]); } @Override public void onNothingSelected(AdapterView<?> parent) { } }); //添加列表被單擊的監(jiān)聽(tīng)器 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添加監(jiān)聽(tīng)事件 imageSwitcher.setOnClickListener(new View.OnClickListener() { @Override public void onClick(View v) { imageSwitcher.setVisibility(View.GONE); imageSwitcher.setClickable(false); } }); imageSwitcher.setClickable(false); } }
幾點(diǎn)值得注意的:
- 由于SimpleAdapter 對(duì)象 是根據(jù)Map 建立的 ,所以他們的Key一定要相同才行,否則無(wú)法生成。
- 關(guān)于閃退現(xiàn)象:我才用的是經(jīng)過(guò)壓縮過(guò)的圖片,如果是加載高清大圖很可能出現(xiàn)OOM現(xiàn)象,這是我們需要對(duì)圖片進(jìn)行壓縮,具體可以參照:http://chabaoo.cn/article/158268.htm
- 這里cell文件還是和往常一樣,只是個(gè)簡(jiǎn)單的ImageView罷了,注意設(shè)置它的 id 要與活動(dòng)中調(diào)用它的地方相同,這里就不過(guò)多描述了。
更多關(guān)于Android相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《Android圖形與圖像處理技巧總結(jié)》、《Android開(kāi)發(fā)入門(mén)與進(jìn)階教程》、《Android調(diào)試技巧與常見(jiàn)問(wèn)題解決方法匯總》、《Android基本組件用法總結(jié)》、《Android視圖View技巧總結(jié)》、《Android布局layout技巧總結(jié)》及《Android控件用法總結(jié)》
希望本文所述對(duì)大家Android程序設(shè)計(jì)有所幫助。
相關(guān)文章
Android破解微信獲取聊天記錄和通訊錄信息(靜態(tài)方式)
這篇文章主要介紹了Android以靜態(tài)方式破解微信獲取聊天記錄和通訊錄信息,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2016-08-08Android布局(RelativeLayout、TableLayout等)使用方法
這篇文章主要介紹了Android布局使用方法及各種屬性介紹,包括RelativeLayout、TableLayout等,感興趣的朋友可以參考一下2016-03-03詳解Flutter如何在單個(gè)屏幕上實(shí)現(xiàn)多個(gè)列表
這篇文章主要為大家詳細(xì)介紹了Flutter如何在單個(gè)屏幕上實(shí)現(xiàn)多個(gè)列表,這些列表可以水平排列、網(wǎng)格格式、垂直排列,甚至是這些常用布局的組合,感興趣的小伙伴可以了解下2023-11-11Android?中的?Timer?和?TimerTask詳解
Timer?是?Java?中用于創(chuàng)建定時(shí)任務(wù)的類,它位于?java.util?包中,可以使用Timer來(lái)安排一次性或定期執(zhí)行的任務(wù),這篇文章主要介紹了Android?的?Timer?和?TimerTask,需要的朋友可以參考下2024-05-05Android基于OpenCV實(shí)現(xiàn)Harris角點(diǎn)檢測(cè)
角點(diǎn)就是極值點(diǎn),即在某方面屬性特別突出的點(diǎn)。當(dāng)然,你可以自己定義角點(diǎn)的屬性(設(shè)置特定熵值進(jìn)行角點(diǎn)檢測(cè))。角點(diǎn)可以是兩條線的交叉處,也可以是位于相鄰的兩個(gè)主要方向不同的事物上的點(diǎn)。本文介紹如何基于OpenCV實(shí)現(xiàn)Harris角點(diǎn)檢測(cè)2021-06-06Android實(shí)現(xiàn)氣泡布局/彈窗效果 氣泡尖角方向及偏移量可控
這篇文章主要為大家詳細(xì)介紹了Android實(shí)現(xiàn)氣泡布局/彈窗效果,可控制氣泡尖角方向及偏移量,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2016-08-08Android Studio 1.2版安裝設(shè)置圖文教程
這篇文章主要介紹了Android Studio 1.2版安裝設(shè)置圖文教程,本文詳細(xì)講解了下載、安裝Android Studio 1.2教程,以及常用設(shè)置詳細(xì)圖文教程,需要的朋友可以參考下2015-05-05移動(dòng)端開(kāi)發(fā)之Jetpack?Hilt技術(shù)實(shí)現(xiàn)解耦
Hilt的出現(xiàn)解決前兩點(diǎn)問(wèn)題,因?yàn)镠ilt是Dagger針對(duì)Android平臺(tái)的場(chǎng)景化框架,比如Dagger需要我們手動(dòng)聲明注入的地方,而Android聲明的地方不都在onCreate()嗎,所以Hilt就幫我們做了,除此之外還做了很多事情2023-02-02