自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

Android-如何開發(fā)一個功能強大的圖片選擇器

移動開發(fā) Android
圖片選擇器是Android開發(fā)中會經(jīng)常用到的一個功能,特別對于社交類的應(yīng)用,比如頭像設(shè)置,比如發(fā)圖片。自然ImagePicker的輪子很多,今天介紹一個功能強大的輪子SImagePicker。

  [[182968]]

圖片選擇器是Android開發(fā)中會經(jīng)常用到的一個功能,特別對于社交類的應(yīng)用,比如頭像設(shè)置,比如發(fā)圖片。自然ImagePicker的輪子很多,今天介紹一個功能強大的輪子SImagePicker

https://github.com/martin90s/ImagePicker

介紹

首先功能強大之處

  • 首先基本的圖片讀取顯示,以及圖片更新監(jiān)控
  • 超大圖片預(yù)覽,比如一張19M,10000*5000px的圖片
  • 圖片的裁剪功能
  • 豐富的可配置項,支持拍照選取,選取張數(shù)定義,支持選擇的圖片過濾,
  • 支持多種圖片加載器(Fresco,Glide等)

廢話不說,先看效果

***張頭像模式,第二張選擇多張圖片(包括動畫和順暢的跳轉(zhuǎn)),第三張是分片加載超大圖(19.5M,10000*5000px)   

 

頭像模式,支持裁剪   

 

多選圖片,流暢的頁面跳轉(zhuǎn)  

  

超大圖預(yù)覽,可以看到漸變加載

如何使用

1.首先初始化(推薦在Application的oncreate中調(diào)用)

  1. SImagePicker.init(new PickerConfig.Builder().setAppContext(this) 
  2.  
  3. .setImageLoader(new FrescoImageLoader()) 
  4.  
  5. .setToolbaseColor(getColor(R.color.colorPrimary)) 
  6.  
  7. .build());  

2.在需要選擇圖片的地方調(diào)用 

  1. SImagePicker 
  2.  
  3. .from(MainActivity.this) 
  4.  
  5. .maxCount(9) 
  6.  
  7. .rowCount(3) 
  8.  
  9. .pickMode(SImagePicker.MODE_IMAGE) 
  10.  
  11. .fileInterceptor(new SingleFileLimitInterceptor()) 
  12.  
  13. .forResult(REQUEST_CODE_IMAGE);  

可配置項

1.全局配置(即初始化時傳入的PickerConfig,此配置作用于SImagePicker整個使用過程)

配置參數(shù) 參數(shù)含義
setImageLoader(ImageLoader) 使用的圖片加載器。demo工程中實現(xiàn)了Fresco和Glide兩種ImageLoader,可以參考
setToolbarColor(int) Picker的主色調(diào),默認(rèn)值是App的primaryColor
setAppContext(Context) Picker內(nèi)部用到的Context,傳入ApplicationContext即可

2.單次配置(即每次調(diào)用SImagePicker時傳入的參數(shù),此參數(shù)只對這次調(diào)用生效)

配置參數(shù) 參數(shù)含義
from(Activity or Fragment) 調(diào)用圖片選擇器可從Activity或者Fragment進入,***的結(jié)果會在onActivityResult()返回,現(xiàn)在返回的結(jié)果有兩個值,用戶選擇的圖片的路徑列表data.getStringArrayListExtra(PhotoPickerActivity.EXTRA_RESULT_SELECTION);用戶是否選擇了原圖data.getBooleanExtra(PhotoPickerActivity.EXTRA_RESULT_ORIGINAL, false);
maxCount(int) 此次選擇允許的***選擇數(shù)量,默認(rèn)是1.比如發(fā)朋友圈最多選擇9張圖就傳9

rowCount(int) 

圖片列表單排展示多少張圖
setSelected(List) 默認(rèn)已經(jīng)被選中的圖片
pickMode(int) 選圖的模式,現(xiàn)在有頭像模式和普通模式兩種,頭像模式選中圖片后默認(rèn)會跳到圖片裁剪頁面且默認(rèn)只能選擇一張
cropFilePath(String) 頭像模式下裁剪圖片存放地址
showCamera(boolen) 是否要展示拍照入口
pickText(int)  Picker里右下角展示的文字信息(比如配置選擇,發(fā)送,完成)

fileInterceptor(FileChooseInterceptor)

圖片過濾器,比如用戶選擇的單張圖片大小有限制,即可寫在這個攔截器中,當(dāng)用戶選擇過大圖片時可以提示并且過濾
forResult(int requestCode) 打開圖片選擇器,并且傳入requestCode

獲取結(jié)果

在調(diào)用圖片選擇器的Fragment或者Activity中

  1. @Override 
  2.  
  3.   protected void onActivityResult(int requestCode, int resultCode, Intent data) { 
  4.  
  5.     super.onActivityResult(requestCode, resultCode, data); 
  6.  
  7.     if (resultCode == Activity.RESULT_OK && requestCode == REQUEST_CODE_IMAGE) { 
  8.  
  9.       final ArrayList<String> pathList = 
  10.  
  11.           data.getStringArrayListExtra(PhotoPickerActivity.EXTRA_RESULT_SELECTION); 
  12.  
  13.       final boolean original = 
  14.  
  15.           data.getBooleanExtra(PhotoPickerActivity.EXTRA_RESULT_ORIGINAL, false); 
  16.  
  17.     } 
  18.  
  19.   } 

 

實現(xiàn)

圖片數(shù)據(jù)庫讀取CursorLoader

Android3.0中引入了加載器/裝載器(Loader)的功能,主要用于異步的方式加載數(shù)據(jù)庫。裝載器Loader的特點:

  1. 裝載器提供異步數(shù)據(jù)加載的能力
  2. 裝載器監(jiān)視數(shù)據(jù)資源并且當(dāng)內(nèi)容改變時發(fā)送新的結(jié)果;
  3. 在配置改變后重建的時候,裝載器自動的重連***的裝載器游標(biāo),因此,不需要重新查詢數(shù)據(jù)。

此項目也是使用loader去加載和監(jiān)控圖片數(shù)據(jù),對于Photo和Album即圖片和相冊分別有一個loader和一個controller,loader主要用于加載對應(yīng)的數(shù)據(jù),controller主要用于數(shù)據(jù)讀取到后的刷新已經(jīng)loader的釋放。

源碼中的對應(yīng) 

 

 

 

PhotoLoader初始化

  1. public static CursorLoader newInstance(Context context, Album album, long minSize) { 
  2.  
  3.   if (album == null || album.isAll()) { 
  4.  
  5.     return new PhotoLoader(context, MediaStore.Images.Media.EXTERNAL_CONTENT_URI, PROJECTION, 
  6.  
  7.         SELECTION_SIZE, new String[] {minSize + ""}, ORDER_BY); 
  8.  
  9.   } 
  10.  
  11.   return new PhotoLoader(context, MediaStore.Images.Media.EXTERNAL_CONTENT_URI, PROJECTION, 
  12.  
  13.       MediaStore.Images.Media.BUCKET_ID + " = ? and (" + SELECTION_SIZE + ")", new String[] { 
  14.  
  15.           album.getId(), minSize + ""}, ORDER_BY); 
  16.  

 

超大圖片加載

對于超大的圖片如何展示,這個是個比較棘手的問題

比如這張圖

http://7xpb9x.com1.z0.glb.clouddn.com/2017/01/20/b578e4755a32ac56a9c4b9a1f7e2822d.jpg

10000*5000的像素,接近20M。

這種圖片肯定無法一次全部load到內(nèi)存中,可以稍微計算一下即使是RGB_565的方式全部load進內(nèi)存也要占用幾乎90M的內(nèi)存,顯然是不太可能??梢曰仡^看一下第三張demo gif,顯然用戶打開一張圖時,在默認(rèn)情況下,并不要求能看到細節(jié),當(dāng)用戶點擊某區(qū)域放大時此時才會需要這一塊的清晰圖。那么如何展示這種超大圖的思路基本基本就是

  1. 首先拿到文件路徑,讀取出圖片的寬高,并且根據(jù)屏幕和圖片寬高計算出一個展示全圖的情況下的Samplesize,根據(jù)這個值去加載出一個全景的圖
  2. 對圖片進行分塊,分塊會分出不同放大倍數(shù)下(即選擇不同SampleSize)下的一個塊列表,比如放大2倍時,放大4倍時對應(yīng)怎么分塊
  3. 當(dāng)用戶點擊放大某一區(qū)域時,根據(jù)放大的倍數(shù)以及當(dāng)前的中心點選擇對應(yīng)的塊進行l(wèi)oad和渲染

在SImagePicker項目中主要是用了subsamplingImageView

并且根據(jù)picker的需求做了些修改,來實現(xiàn)超大圖的預(yù)覽

圖片列表展示

展示

由于使用了cursorLoader,對于ListView的話有CursorAdapter可以使用,但是對于RecyclerView確沒有對應(yīng)的Adapter,所以在源碼中可以看到實現(xiàn)了一個RecycleCursorAdapter,用于實現(xiàn)從cursor獲取數(shù)據(jù)已經(jīng)自動刷新。

兼容

為了能夠兼容多個圖片加載器,SImagePicker抽象了一個ImageLoader接口用于讓使用者自定義對應(yīng)的圖片加載器。

使用建議

SImagePicker提供了jitpack上的依賴庫,可以很快的接入業(yè)務(wù)中,但是由于大部分的APP對于ImagePicker的使用都有各種業(yè)務(wù)需求,且SImagePicker只是抽象出了比較通用的一些配置,用于讓使用者能快速集成,所以此處還是建議使用者盡可能源碼引用的方式的使用SImagePicker,既方便做一些調(diào)試,也可以很快的了解實現(xiàn)原理,說起來這種UI組件代碼應(yīng)該是很好讀的,因為本身并不復(fù)雜。

責(zé)任編輯:龐桂玉 來源: 安卓巴士Android開發(fā)者門戶
相關(guān)推薦

2011-02-23 13:52:07

vsftpd

2010-03-05 09:19:54

Android系統(tǒng)

2023-08-29 17:43:39

人工智能Fooocus

2021-10-17 20:37:44

組件DrawerReact

2022-02-24 13:08:12

前端開發(fā)視頻

2023-11-03 11:57:04

2024-05-24 08:34:16

2022-03-20 18:12:03

Shotcut開源視頻編輯器

2013-01-23 11:30:39

JSVirtualKeybjQuery

2017-04-20 18:00:59

Linux命令行工具系統(tǒng)信息

2019-01-31 11:01:57

2021-07-09 10:14:05

IP工具命令

2009-12-01 16:44:06

PHP編輯器

2010-02-24 17:58:28

Python 測試框架

2022-10-10 10:14:38

Python繪圖庫

2023-09-21 15:10:55

2009-07-07 08:46:11

微軟Windows 7新功能

2020-12-15 07:54:40

工具Hutoolgithub

2020-12-15 15:08:17

工具Java線程

2011-08-08 13:15:35

QWrap
點贊
收藏

51CTO技術(shù)棧公眾號