[BugFix]修复保存图片失败的bug

This commit is contained in:
wushaocheng
2023-04-14 15:31:58 +08:00
parent ee1d528027
commit cb21a12b95
2 changed files with 81 additions and 78 deletions

View File

@@ -1,8 +1,9 @@
package com.nnbc123.app.community.photo;
import android.Manifest;
import android.annotation.SuppressLint;
import android.app.Activity;
import android.content.Intent;
import android.net.Uri;
import android.os.Bundle;
import android.view.View;
import android.widget.ImageView;
@@ -12,17 +13,19 @@ import com.nnbc123.app.R;
import com.nnbc123.app.base.BaseActivity;
import com.nnbc123.app.ui.widget.ButtonItem;
import com.nnbc123.app.ui.widget.OnPageSelectedListener;
import com.nnbc123.core.community.download.DownloadModel;
import com.nnbc123.core.utils.DirectoryHelper;
import com.nnbc123.library.common.util.AlbumUtils;
import com.nnbc123.library.common.util.ExecutorCenter;
import com.nnbc123.library.utils.ResUtil;
import com.zhihu.matisse.internal.entity.CustomItem;
import com.zhihu.matisse.internal.ui.widget.PreviewViewPager;
import java.io.File;
import java.util.ArrayList;
import java.util.List;
import butterknife.BindView;
import butterknife.ButterKnife;
import kotlin.Unit;
import kotlin.jvm.functions.Function1;
/**
* create by lvzebiao @2019/11/20
@@ -143,6 +146,7 @@ public class BigPhotoActivity extends BaseActivity implements OnFragmentOptionLi
finish();
}
@SuppressLint("CheckResult")
@Override
public void onLongClick(int position) {
if (!option.isSave()) {
@@ -154,37 +158,25 @@ public class BigPhotoActivity extends BaseActivity implements OnFragmentOptionLi
if (item == null) {
return;
}
String format = item.getFormat();
if (format == null) {
format = ".jpg";
}
format = format.toLowerCase();
if (format.equals("jpeg")) {
format = ".jpg";
} else {
format = "." + format;
}
String fileName = "dynamic_" + System.currentTimeMillis() + format;
File dir = DirectoryHelper.get().getAppAlubmDir();
if (dir == null) {
toast("保存目录为空请保证APP权限正常并重启APP");
return;
}
LogUtil.print("下载路径:");
LogUtil.print(dir);
LogUtil.print(fileName);
DownloadModel.get().download(
item.getPath(), dir.getPath(), fileName)
.doOnSuccess(s -> {
Intent intent = new Intent(Intent.ACTION_MEDIA_SCANNER_SCAN_FILE);
Uri uri = Uri.fromFile(new File(dir, fileName));
intent.setData(uri);
sendBroadcast(intent);
toast("保存成功");
})
.doOnError(throwable -> toast("保存失败"))
.subscribe();
checkPermission(Manifest.permission.WRITE_EXTERNAL_STORAGE)
.compose(bindToLifecycle())
.subscribe(aBoolean -> {
if (aBoolean) {
ExecutorCenter.getInstance().post(() -> {
AlbumUtils.INSTANCE.addUrlToAlbum(context, item.getPath(), new Function1<Boolean, Unit>() {
@Override
public Unit invoke(Boolean aBoolean) {
if (aBoolean) {
toast("保存成功");
}
return null;
}
});
});
} else {
toast(ResUtil.getString(R.string.give_application_storage_permission));
}
});
}));
getDialogManager().showCommonPopupDialog(listBtn, "取消");

View File

@@ -1,16 +1,12 @@
package com.netease.nim.uikit.business.session.activity;
import android.content.ContentValues;
import android.Manifest;
import android.content.Context;
import android.content.Intent;
import android.graphics.Bitmap;
import android.graphics.Color;
import android.os.Bundle;
import android.os.Handler;
import android.provider.MediaStore;
import androidx.viewpager.widget.PagerAdapter;
import androidx.core.view.ViewCompat;
import androidx.viewpager.widget.ViewPager;
import android.text.TextUtils;
import android.util.Log;
import android.view.LayoutInflater;
@@ -19,20 +15,21 @@ import android.view.ViewGroup;
import android.widget.ImageView;
import android.widget.TextView;
import androidx.annotation.NonNull;
import androidx.core.view.ViewCompat;
import androidx.viewpager.widget.PagerAdapter;
import androidx.viewpager.widget.ViewPager;
import com.bumptech.glide.Glide;
import com.netease.nim.uikit.R;
import com.netease.nim.uikit.api.wrapper.NimToolBarOptions;
import com.netease.nim.uikit.common.activity.ToolBarOptions;
import com.netease.nim.uikit.common.activity.UI;
import com.netease.nim.uikit.common.ui.dialog.CustomAlertDialog;
import com.netease.nim.uikit.common.ui.dialog.CustomAlertDialog.onSeparateItemClickListener;
import com.netease.nim.uikit.common.ui.imageview.BaseZoomableImageView;
import com.netease.nim.uikit.common.ui.imageview.ImageGestureListener;
import com.netease.nim.uikit.common.util.C;
import com.netease.nim.uikit.common.util.file.AttachmentStore;
import com.netease.nim.uikit.common.util.media.BitmapDecoder;
import com.netease.nim.uikit.common.util.media.ImageUtil;
import com.netease.nim.uikit.common.util.storage.StorageUtil;
import com.netease.nim.uikit.common.util.sys.TimeUtil;
import com.netease.nimlib.sdk.AbortableFuture;
import com.netease.nimlib.sdk.NIMClient;
@@ -46,6 +43,9 @@ import com.netease.nimlib.sdk.msg.constant.AttachStatusEnum;
import com.netease.nimlib.sdk.msg.constant.MsgDirectionEnum;
import com.netease.nimlib.sdk.msg.constant.MsgTypeEnum;
import com.netease.nimlib.sdk.msg.model.IMMessage;
import com.nnbc123.library.common.util.AlbumUtils;
import com.nnbc123.library.common.util.ExecutorCenter;
import com.nnbc123.library.easyphoto.utils.permission.PermissionUtil;
import com.nnbc123.library.utils.SingleToastUtil;
import java.io.File;
@@ -53,6 +53,9 @@ import java.util.ArrayList;
import java.util.Collections;
import java.util.List;
import kotlin.Unit;
import kotlin.jvm.functions.Function1;
/**
* 查看聊天消息原图
@@ -220,7 +223,7 @@ public class WatchMessagePictureActivity extends UI {
@Override
public void onSuccess(List<IMMessage> param) {
for (IMMessage imMessage : param) {
if (!ImageUtil.isGif(((ImageAttachment) imMessage.getAttachment()).getExtension())){
if (!ImageUtil.isGif(((ImageAttachment) imMessage.getAttachment()).getExtension())) {
imageMsgList.add(imMessage);
}
}
@@ -415,7 +418,6 @@ public class WatchMessagePictureActivity extends UI {
Bitmap bitmap = BitmapDecoder.decodeSampledForDisplay(path, false);
bitmap = ImageUtil.rotateBitmapInNeeded(path, bitmap);
if (bitmap == null) {
// Toast.makeText(this, R.string.picker_image_error, Toast.LENGTH_LONG).show();
SingleToastUtil.showToastShort(R.string.picker_image_error);
image.setImageBitmap(ImageUtil.getBitmapFromDrawableRes(getImageResOnFailed()));
} else {
@@ -489,7 +491,6 @@ public class WatchMessagePictureActivity extends UI {
} else if (mode == MODE_GIF) {
simpleImageView.setImageBitmap(ImageUtil.getBitmapFromDrawableRes(getImageResOnFailed()));
}
// Toast.makeText(this, R.string.download_picture_fail, Toast.LENGTH_LONG).show();
SingleToastUtil.showToastShort(R.string.download_picture_fail);
}
@@ -530,17 +531,11 @@ public class WatchMessagePictureActivity extends UI {
return;
}
alertDialog.clearData();
String path = ((ImageAttachment) message.getAttachment()).getThumbPath();
if (TextUtils.isEmpty(path)) {
return;
}
String title;
if (!TextUtils.isEmpty(((ImageAttachment) message.getAttachment()).getPath())) {
title = getString(R.string.save_to_device);
alertDialog.addItem(title, new onSeparateItemClickListener() {
@Override
public void onClick() {
alertDialog.addItem(title, () -> {
if (PermissionUtil.checkAndRequestPermissionsInActivity(WatchMessagePictureActivity.this, getNeedPermissions())) {
savePicture();
}
});
@@ -556,29 +551,45 @@ public class WatchMessagePictureActivity extends UI {
return;
}
String srcFilename = attachment.getFileName();
//默认jpg
String extension = TextUtils.isEmpty(attachment.getExtension()) ? "jpg" : attachment.getExtension();
srcFilename += ("." + extension);
ExecutorCenter.getInstance().post(() -> {
AlbumUtils.INSTANCE.addUrlToAlbum(this, path, new Function1<Boolean, Unit>() {
@Override
public Unit invoke(Boolean aBoolean) {
if (aBoolean) {
SingleToastUtil.showToastShort(R.string.picture_save_to);
}
return null;
}
});
});
String picPath = StorageUtil.getSystemImagePath();
String dstPath = picPath + srcFilename;
if (AttachmentStore.copy(path, dstPath) != -1) {
try {
ContentValues values = new ContentValues(2);
values.put(MediaStore.Images.Media.MIME_TYPE, C.MimeType.MIME_JPEG);
values.put(MediaStore.Images.Media.DATA, dstPath);
getContentResolver().insert(MediaStore.Images.Media.EXTERNAL_CONTENT_URI, values);
// Toast.makeText(WatchMessagePictureActivity.this, getString(R.string.picture_save_to), Toast.LENGTH_LONG).show();
SingleToastUtil.showToastShort(R.string.picture_save_to);
} catch (Exception e) {
// may be java.lang.UnsupportedOperationException
// Toast.makeText(WatchMessagePictureActivity.this, getString(R.string.picture_save_fail), Toast.LENGTH_LONG).show();
SingleToastUtil.showToastShort(R.string.picture_save_fail);
}
} else {
// Toast.makeText(WatchMessagePictureActivity.this, getString(R.string.picture_save_fail), Toast.LENGTH_LONG).show();
SingleToastUtil.showToastShort(R.string.picture_save_fail);
}
}
@Override
public void onRequestPermissionsResult(int requestCode, @NonNull String[] permissions,
@NonNull int[] grantResults) {
super.onRequestPermissionsResult(requestCode, permissions, grantResults);
PermissionUtil.onPermissionResult(this, permissions, grantResults,
new PermissionUtil.PermissionCallBack() {
@Override
public void onSuccess() {
savePicture();
}
@Override
public void onShouldShow() {
SingleToastUtil.showToastShort(R.string.give_application_storage_permission);
}
@Override
public void onFailed() {
SingleToastUtil.showToastShort(R.string.give_application_storage_permission);
}
});
}
protected String[] getNeedPermissions() {
return new String[]{Manifest.permission.WRITE_EXTERNAL_STORAGE};
}
}