Android實現(xiàn)便于批量操作可多選的圖片ListView實例
本文實例講述了Android實現(xiàn)便于批量操作可多選的圖片ListView。分享給大家供大家參考,具體如下:
之前項目需要實現(xiàn)一個可多選的圖片列表,用戶選中一到多張圖片后,批量上傳。但是網(wǎng)上有可多選普通列表的代碼、也有單純圖片列表的代碼,卻沒有兩者合并的代碼,只好自己實現(xiàn)一個。
廢話不說,直接上代碼。
先是兩個layout:
1、main.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">
<ListView
android:layout_width="fill_parent"
android:layout_height="fill_parent"
android:focusable="false"
android:id="@+id/lvImageList" >
</ListView>
</LinearLayout>
2、listitem.xml
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:orientation="horizontal"
android:layout_width="fill_parent"
android:layout_height="?android:attr/listPreferredItemHeight">
<ImageView
android:id="@+id/itemImgImageInfo"
android:layout_marginTop="4dip"
android:layout_marginBottom="4dip"
android:layout_width="?android:attr/listPreferredItemHeight"
android:layout_height="?android:attr/listPreferredItemHeight">
</ImageView>
<TwoLineListItem xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="fill_parent"
android:layout_height="fill_parent"
android:paddingLeft="4dip"
android:mode="twoLine">
<CheckedTextView
android:id="@+id/itemChkImageInfo"
android:layout_width="fill_parent"
android:layout_height="wrap_content"
android:gravity="center_vertical"
android:textAppearance="?android:attr/textAppearanceSmall"
android:checkMark="?android:attr/listChoiceIndicatorMultiple">
</CheckedTextView>
<TextView
android:id="@+id/itemTxtImageInfo"
android:layout_width="fill_parent"
android:layout_height="wrap_content"
android:gravity="center_vertical|top"
android:layout_marginBottom="4dip"
android:layout_below="@+id/itemChkImageInfo"
android:textAppearance="?android:attr/textAppearanceSmall">
</TextView>
</TwoLineListItem>
</LinearLayout>
接著是代碼:
package com.android.MultipleChoiceImageList;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
import android.app.Activity;
import android.content.Context;
import android.database.Cursor;
import android.graphics.Bitmap;
import android.net.Uri;
import android.os.Bundle;
import android.provider.MediaStore;
import android.provider.MediaStore.Images;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.AdapterView;
import android.widget.CheckedTextView;
import android.widget.ImageView;
import android.widget.ListView;
import android.widget.SimpleAdapter;
import android.widget.TextView;
import android.widget.AdapterView.OnItemClickListener;
public class MainActivity extends Activity {
private ListView lvImageList;
private String imageID= "imageID";
private String imageName = "imageName";
private String imageInfo = "imageInfo";
private ArrayList<String> fileNames = new ArrayList<String>();
private MultipleChoiceImageListAdapter mAdapter;
/** Called when the activity is first created. */
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.main);
lvImageList=(ListView) this.findViewById(R.id.lvImageList);
lvImageList.setItemsCanFocus(false);
lvImageList.setOnItemClickListener(new OnItemClickListener() {
@Override
public void onItemClick(AdapterView<?> parent, View view, int position, long id) {
CheckedTextView checkedTextView = (CheckedTextView) view.findViewById(R.id.itemChkImageInfo);
checkedTextView.toggle();
mAdapter.setCheckItem(position, checkedTextView.isChecked());
}
});
try{
String[] from = {imageID, imageName, imageInfo};
int[] to = {R.id.itemImgImageInfo, R.id.itemChkImageInfo, R.id.itemTxtImageInfo};
mAdapter = new MultipleChoiceImageListAdapter(MainActivity.this, GetImageList(), R.layout.listitem, from, to);
lvImageList.setAdapter(mAdapter);
}
catch(Exception ex){
return;
}
}
//獲取圖片列表
private ArrayList<Map<String, String>> GetImageList(){
ArrayList<Map<String, String>> imageList = new ArrayList<Map<String,String>>();
HashMap<String, String> imageMap;
//讀取SD卡中所有圖片
Uri uri = MediaStore.Images.Media.EXTERNAL_CONTENT_URI;
String[] projection = { MediaStore.Images.Media._ID, MediaStore.Images.Media.DISPLAY_NAME,MediaStore.Images.Media.DATA, MediaStore.Images.Media.SIZE};
String selection = MediaStore.Images.Media.MIME_TYPE + "=?";
String[] selectionArg ={"image/jpeg"};
Cursor mCursor = this.managedQuery(uri, projection, selection, selectionArg, MediaStore.Images.Media.DISPLAY_NAME);
imageList.clear();
if (mCursor != null) {
mCursor.moveToFirst();
while (mCursor.getPosition() != mCursor.getCount())
{
imageMap= new HashMap<String, String>();
imageMap.put(imageID, mCursor.getString(mCursor.getColumnIndex(MediaStore.Images.Media._ID)));
imageMap.put(imageName, mCursor.getString(mCursor.getColumnIndex(MediaStore.Images.Media.DISPLAY_NAME)));
imageMap.put(imageInfo, " " + (mCursor.getLong(mCursor.getColumnIndex(MediaStore.Images.Media.SIZE))/1024)+"KB");
imageList.add(imageMap);
fileNames.add(mCursor.getString(mCursor.getColumnIndex(MediaStore.Images.Media.DATA)));
mCursor.moveToNext();
}
mCursor.close();
}
return imageList;
}
//可多選圖片列表適配器
class MultipleChoiceImageListAdapter extends SimpleAdapter {
private Map<Integer, Boolean> map;
private List<Integer> state;
private List<? extends Map<String, ?>> mList;
LayoutInflater mInflater;
public MultipleChoiceImageListAdapter(Context context, List<Map<String, String>> data, int resource, String[] from, int[] to) {
super(context, data, resource, from, to);
map = new HashMap<Integer, Boolean>();
mInflater = LayoutInflater.from(context);
mList = data;
for(int i = 0; i < data.size(); i++) {
map.put(i, false);
}
state = new ArrayList<Integer>();
}
@Override
public int getCount() {
return mList.size();
}
@Override
public Object getItem(int position) {
return position;
}
@Override
public long getItemId(int position) {
return position;
}
//設(shè)置條目選中狀態(tài)
public void setCheckItem(int position, Boolean isChecked){
map.put(position, isChecked);
if (state.contains(position))
state.remove((Object)position);
if (isChecked){
state.add(position);
}
}
//獲取列表中已選中條目
public long[] getCheckItemIds(){
int count = state.size();
long[] ids = new long[count];
for (int i = 0; i < count; i++) {
ids[i]= (long)state.get(i);
}
return ids;
}
@Override
public View getView(int position, View convertView, ViewGroup parent) {
if(convertView == null) {
convertView = mInflater.inflate(R.layout.listitem, null);
}
CheckedTextView checkedTextView = (CheckedTextView) convertView.findViewById(R.id.itemChkImageInfo);
checkedTextView.setChecked(map.get(position));
checkedTextView.setText((String)mList.get(position).get(imageName));
TextView textView = (TextView) convertView.findViewById(R.id.itemTxtImageInfo);
textView.setText((String)mList.get(position).get(imageInfo));
//顯示圖片縮略圖
ImageView image = (ImageView) convertView.findViewById(R.id.itemImgImageInfo);
Bitmap bm = MediaStore.Images.Thumbnails.getThumbnail(getContentResolver(), Long.parseLong((String)mList.get(position).get(imageID)), Images.Thumbnails.MICRO_KIND, null);
image.setImageBitmap(bm);
return convertView;
}
}
}
下面是模擬器上的效果:

由于是初學(xué)java和android,代碼寫得比較糙,請見諒,歡迎指正,不勝感激。
更多關(guān)于Android相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《Android圖形與圖像處理技巧總結(jié)》、《Android開發(fā)入門與進(jìn)階教程》、《Android調(diào)試技巧與常見問題解決方法匯總》、《Android多媒體操作技巧匯總(音頻,視頻,錄音等)》、《Android基本組件用法總結(jié)》、《Android視圖View技巧總結(jié)》、《Android布局layout技巧總結(jié)》及《Android控件用法總結(jié)》
希望本文所述對大家Android程序設(shè)計有所幫助。
相關(guān)文章
Android筆記設(shè)計范例之日記APP實現(xiàn)全流程
這篇文章主要介紹了Android筆記設(shè)計范例之日記APP實現(xiàn)全流程,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)吧2023-01-01
Android開發(fā)實現(xiàn)廣告無限循環(huán)功能示例
這篇文章主要介紹了Android開發(fā)實現(xiàn)廣告無限循環(huán)功能,結(jié)合完整實例形式分析了Android廣告圖片輪播功能的具體實現(xiàn)步驟與相關(guān)功能、布局等操作技巧,需要的朋友可以參考下2017-11-11
Android自定義View實現(xiàn)繪制水波浪溫度刻度表
這篇文章主要為大家詳細(xì)介紹了Android如何利用自定義View實現(xiàn)一個水波浪溫度刻度表,文中的示例代碼講解詳細(xì),感興趣的小伙伴可以嘗試一下2022-11-11
Android ListView實現(xiàn)無限循環(huán)滾動
這篇文章主要為大家詳細(xì)介紹了Android ListView實現(xiàn)無限循環(huán)滾動,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下2020-06-06
Android實現(xiàn)微信支付的統(tǒng)一下單
這篇文章主要為大家詳細(xì)介紹了Android實現(xiàn)微信支付的統(tǒng)一下單,具有一定的參考價值,感興趣的小伙伴們可以參考一下2018-06-06
Android自定義控件實現(xiàn)可多選課程日歷CalendarView
這篇文章主要為大家詳細(xì)介紹了Android自定義控件實現(xiàn)可多選課程日歷CalendarView,具有一定的參考價值,感興趣的小伙伴們可以參考一下2017-05-05
Android相冊效果(使用C#和Java分別實現(xiàn))
這篇文章主要介紹了Android相冊效果(使用C#和Java分別實現(xiàn)),原來C#也可以開發(fā)APP,小編第一次見了~感覺不錯,因為小編暫時不喜歡Java,所以,需要的朋友可以參考下2015-06-06

