GitHub地址:ImagePicker
完全仿微信的圖片選擇,并且提供了多種圖片加載接口,選擇圖片后可以旋轉,可以裁剪成矩形或圓形,可以配置各種其他的參數.
該項目參考了:
https://github.com/pengjianbo/GalleryFinalhttps://github.com/easonline/AndroidImagePicker喜歡原作的可以去使用。同時歡迎大家下載體驗本項目,如果使用過程中遇到什么問題,歡迎反饋。

 

使用前,對于Android Studio的用戶,可以選擇添加:
compile 'com.lzy.widget:imagepicker:0.3.2' //指定版本 compile 'com.lzy.widget:imagepicker:+' //最新版本2.功能和參數含義
溫馨提示:目前庫中的預覽界面有個原圖的復選框,暫時只做了UI,還沒有做壓縮的邏輯
| 配置參數 | 參數含義 | 
|---|---|
| multiMode | 圖片選著模式,單選/多選 | 
| selectLimit | 多選限制數量,默認為9 | 
| showCamera | 選擇照片時是否顯示拍照按鈕 | 
| crop | 是否允許裁剪(單選有效) | 
| style | 有裁剪時,裁剪框是矩形還是圓形 | 
| focusWidth | 矩形裁剪框寬度(圓形自動取寬高最小值) | 
| focusHeight | 矩形裁剪框高度(圓形自動取寬高最小值) | 
| outPutX | 裁剪后需要保存的圖片寬度 | 
| outPutY | 裁剪后需要保存的圖片高度 | 
| isSaveRectangle | 裁剪后的圖片是按矩形區域保存還是裁剪框的形狀,例如圓形裁剪的時候,該參數給true,那么保存的圖片是矩形區域,如果該參數給fale,保存的圖片是圓形區域 | 
| imageLoader | 需要使用的圖片加載器,自需要實現ImageLoader接口即可 | 
com.lzy.imagepicker.loader.ImageLoader 這個接口,實現其中的方法,比如以下代碼是使用 Picasso 三方加載庫實現的    public class PicassoImageLoader implements ImageLoader {        @Override        public void displayImage(Activity activity, String path, ImageView imageView, int width, int height) {            Picasso.with(activity)//                    .load(new File(path))//                    .placeholder(R.mipmap.default_image)//                    .error(R.mipmap.default_image)//                    .resize(width, height)//                    .centerInside()//                    .memoryPolicy(MemoryPolicy.NO_CACHE, MemoryPolicy.NO_STORE)//                    .into(imageView);        }        @Override        public void clearMemoryCache() {            //這里是清除緩存的方法,根據需要自己實現        }    }1.然后配置圖片選擇器,一般在application初始化配置一次就可以,這里就需要將上面的圖片加載器設置進來,其余的配置根據需要設置
    PRotected void onCreate(Bundle savedInstanceState) {        super.onCreate(savedInstanceState);        setContentView(R.layout.activity_image_picker);        ImagePicker imagePicker = ImagePicker.getInstance();        imagePicker.setImageLoader(new PicassoImageLoader());   //設置圖片加載器        imagePicker.setShowCamera(true);  //顯示拍照按鈕        imagePicker.setCrop(true);        //允許裁剪(單選才有效)        imagePicker.setSaveRectangle(true); //是否按矩形區域保存        imagePicker.setSelectLimit(9);    //選中數量限制        imagePicker.setStyle(CropImageView.Style.RECTANGLE);  //裁剪框的形狀        imagePicker.setFocusWidth(800);   //裁剪框的寬度。單位像素(圓形自動取寬高最小值)        imagePicker.setFocusHeight(800);  //裁剪框的高度。單位像素(圓形自動取寬高最小值)        imagePicker.setOutPutX(1000);//保存文件的寬度。單位像素        imagePicker.setOutPutY(1000);//保存文件的高度。單位像素    }2.以上配置完成后,在適當的方法中開啟相冊,例如點擊按鈕時
    public void onClick(View v) {            Intent intent = new Intent(this, ImageGridActivity.class);            startActivityForResult(intent, IMAGE_PICKER);          }    }3.重寫onActivityResult方法,回調結果
    @Override    protected void onActivityResult(int requestCode, int resultCode, Intent data) {        super.onActivityResult(requestCode, resultCode, data);        if (resultCode == ImagePicker.RESULT_CODE_ITEMS) {            if (data != null && requestCode == IMAGE_PICKER) {                ArrayList<ImageItem> images = (ArrayList<ImageItem>) data.getSerializableExtra(ImagePicker.EXTRA_RESULT_ITEMS);                MyAdapter adapter = new MyAdapter(images);                gridView.setAdapter(adapter);            } else {                Toast.makeText(this, "沒有數據", Toast.LENGTH_SHORT).show();            }        }    }
新聞熱點
疑難解答