android - 安卓實(shí)現(xiàn)類似QQ剛換聊天背景的功能
問題描述
自己實(shí)現(xiàn)了一下,但對(duì)于一些手機(jī)一設(shè)置背景就出現(xiàn)閃退不知道為什么,大體思路就是獲得用戶選擇的uri,然后如果屏幕分辨率小于圖片的分辨率就對(duì)圖片進(jìn)行下處理,防止OOM。但現(xiàn)在不知道哪里還有問題
啟動(dòng)系統(tǒng)的圖片選擇
Intent intent = new Intent(Intent.ACTION_GET_CONTENT);intent.setType('image/*');CourseFragment.getInstannce().startActivityForResult(intent,1);
里邊有檢查權(quán)限,安卓6.0權(quán)限得經(jīng)用戶同意讀內(nèi)存,還有就是我把圖片以字符串的形式保存下來了,使得下次啟動(dòng)直接顯示保存的圖片(不知道有沒有更好的方法,感覺這個(gè)方法很不正規(guī))。
@Override public void onActivityResult(int requestCode, int resultCode, Intent data) {super.onActivityResult(requestCode, resultCode, data);if(requestCode==1&&resultCode==RESULT_OK&&data!=null) { Uri uri = data.getData(); int weight= CourseBackground.getHeight(); int height=CourseBackground.getWidth(); Bitmap photo=getSmallBitmap(getRealPathFromURI(uri),weight,height); if(photo==null) {OwnToast.Long('請(qǐng)檢查存儲(chǔ)權(quán)限是否開啟');return; } BitmapDrawable bd=new BitmapDrawable(getResources(),photo); if(bd==null) {OwnToast.Long('請(qǐng)檢查存儲(chǔ)權(quán)限是否開啟');return; } ByteArrayOutputStream stream = new ByteArrayOutputStream(); photo.compress(Bitmap.CompressFormat.JPEG, 60, stream); byte[] b = stream.toByteArray(); // 將圖片流以字符串形式存儲(chǔ)下來 String tp = new String(Base64Encoder.encode(b)); InformationShared.setString('course_background', tp); CourseBackground.setBackground(bd);} }
根據(jù)URI去返回真實(shí)路徑,網(wǎng)上找的代碼,似乎這里有問題,在錯(cuò)誤統(tǒng)計(jì)里看到這里的報(bào)錯(cuò)
private String getRealPathFromURI(Uri contentURI) {String result;Cursor cursor = getActivity().getContentResolver().query(contentURI, null, null, null, null);if (cursor == null) { // Source is Dropbox or other similar local file path result = contentURI.getPath();} else { cursor.moveToFirst(); int idx = cursor.getColumnIndex(MediaStore.Images.ImageColumns.DATA); result = cursor.getString(idx); cursor.close();}return result; }
1273 return result那一行
org.pointstone.cugapp.fragments.CourseFragment.getRealPathFromURI(CourseFragment.java:1273)
然后是得到壓縮的圖片函數(shù)
public Bitmap getSmallBitmap(String filepath, int reqWidth, int reqHeight) {// 第一次解析將inJustDecodeBounds設(shè)置為true,來獲取圖片大小final BitmapFactory.Options options = new BitmapFactory.Options();options.inJustDecodeBounds = true;BitmapFactory.decodeFile(filepath,options);// 調(diào)用上面定義的方法計(jì)算inSampleSize值options.inSampleSize = calculateInSampleSize(options, reqWidth, reqHeight);// 使用獲取到的inSampleSize值再次解析圖片options.inJustDecodeBounds = false;return BitmapFactory.decodeFile(filepath, options); } private String getRealPathFromURI(Uri contentURI) {String result;Cursor cursor = getActivity().getContentResolver().query(contentURI, null, null, null, null);if (cursor == null) { // Source is Dropbox or other similar local file path result = contentURI.getPath();} else { cursor.moveToFirst(); int idx = cursor.getColumnIndex(MediaStore.Images.ImageColumns.DATA); result = cursor.getString(idx); cursor.close();}return result; }
不知道哪里有問題,請(qǐng)大家?guī)兔纯矗惺裁唇ㄗh告訴我,就是一個(gè)LinearLayout然后調(diào)用setBackground設(shè)置背景圖。感覺QQ的那個(gè)很棒,如果有相關(guān)的開源項(xiàng)目感謝推薦。
問題解答
回答1:getRealPathFromURI這個(gè)方法,在Android4.4有變化,所以你需要是用新的.你可以看一下這篇博客 http://blog.csdn.net/dj0379/a...
回答2:把圖片以字符串的形式保存下來的方法確實(shí)很獨(dú)出心裁啊。我的想法是在選擇圖片之后,將圖片處理后復(fù)制一份到App所在的目錄,然后設(shè)置其為背景,下次啟動(dòng)直接加載圖片,免得此圖片在圖庫中被刪除。
相關(guān)文章:
1. java - 在用戶不登錄的情況下,用戶如何添加保存到購(gòu)物車?2. java - spring boot 如何打包成asp.net core 那種獨(dú)立應(yīng)用?3. android - SwipeRefreshLayout5.0以下不兼容4. datetime - Python如何獲取當(dāng)前時(shí)間5. 安全性測(cè)試 - nodejs中如何防m(xù)ySQL注入6. html - eclipse 標(biāo)簽錯(cuò)誤7. javascript - nginx反向代理靜態(tài)資源403錯(cuò)誤?8. javascript - webpack 分割加載代碼后,react 界面不更新9. javascript - 關(guān)于apply()與call()的問題10. python文檔怎么查看?
