[BugFix]修复保存图片失败的bug
This commit is contained in:
@@ -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, "取消");
|
||||
|
||||
|
@@ -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};
|
||||
}
|
||||
|
||||
}
|
||||
|
Reference in New Issue
Block a user