图片详情增加下载原图,答案详情对接新的图片显示规则

This commit is contained in:
kehaoyuan
2018-08-08 09:43:11 +08:00
parent f0af2e280b
commit 78d3c529c6
11 changed files with 242 additions and 178 deletions

View File

@ -14,6 +14,7 @@ import android.support.annotation.Nullable;
import android.support.v4.content.ContextCompat;
import android.support.v4.view.PagerAdapter;
import android.support.v4.view.ViewPager.OnPageChangeListener;
import android.text.TextUtils;
import android.util.DisplayMetrics;
import android.view.View;
import android.view.ViewGroup;
@ -26,7 +27,6 @@ import com.facebook.common.executors.CallerThreadExecutor;
import com.facebook.common.references.CloseableReference;
import com.facebook.datasource.DataSource;
import com.facebook.drawee.backends.pipeline.Fresco;
import com.facebook.drawee.drawable.ScalingUtils;
import com.facebook.drawee.interfaces.DraweeController;
import com.facebook.imagepipeline.core.ImagePipeline;
import com.facebook.imagepipeline.datasource.BaseBitmapDataSubscriber;
@ -38,11 +38,13 @@ import com.gh.common.util.DisplayUtils;
import com.gh.common.util.EntranceUtils;
import com.gh.common.util.ImageUtils;
import com.gh.common.util.MessageShareUtils;
import com.gh.common.util.NetworkUtils;
import com.gh.common.view.EmptyDrawable;
import com.gh.common.view.Gh_RelativeLayout;
import com.gh.common.view.Gh_RelativeLayout.OnSingleTapListener;
import com.gh.common.view.Gh_ViewPager;
import com.gh.common.view.ZoomSimpleDraweeView;
import com.gh.gamecenter.entity.ImageInfo;
import com.gh.gamecenter.entity.ImageInfoEntity;
import com.gh.gamecenter.retrofit.Response;
import com.gh.gamecenter.retrofit.RetrofitManager;
import com.lightgame.utils.Utils;
@ -81,7 +83,7 @@ public class ViewImageActivity extends BaseActivity implements OnPageChangeListe
private ViewImageAdapter adapter;
private ImagePipeline imagePipeline;
private ImagePipeline mImagePipeline;
private static final String KEY_URLS = "urls";
private static final String KEY_CURRENT = "current";
@ -89,11 +91,10 @@ public class ViewImageActivity extends BaseActivity implements OnPageChangeListe
private ArrayList<String> urls;
private HashSet<Integer> mViewedSet; // 让调用者知道该图片是否被看过了
private Map<String, ImageInfo> mImageInfoMap;
private String scaleType;
private Map<String, ImageInfoEntity> mImageInfoMap;
private int width;
private int mLimitWidth;
private boolean isOrientation;
@ -101,7 +102,6 @@ public class ViewImageActivity extends BaseActivity implements OnPageChangeListe
Intent checkIntent = new Intent(context, ViewImageActivity.class);
checkIntent.putExtra(KEY_URLS, list);
checkIntent.putExtra(KEY_CURRENT, position);
checkIntent.putExtra(KEY_SCALETYPE, "FIT_CENTER");
checkIntent.putExtra(EntranceUtils.KEY_ENTRANCE, entrance);
return checkIntent;
}
@ -124,7 +124,6 @@ public class ViewImageActivity extends BaseActivity implements OnPageChangeListe
if (extras != null) {
urls = extras.getStringArrayList(KEY_URLS);
current = extras.getInt(KEY_CURRENT, 0);
scaleType = extras.getString(KEY_SCALETYPE);
}
if (savedInstanceState != null) {
@ -132,12 +131,18 @@ public class ViewImageActivity extends BaseActivity implements OnPageChangeListe
isOrientation = savedInstanceState.getBoolean("isOrientation");
}
imagePipeline = Fresco.getImagePipeline();
mImagePipeline = Fresco.getImagePipeline();
// init slide
DisplayMetrics outMetrics = new DisplayMetrics();
getWindowManager().getDefaultDisplay().getMetrics(outMetrics);
width = outMetrics.widthPixels / urls.size();
int widthPixels = outMetrics.widthPixels;
if (NetworkUtils.isWifiConnected(this)) {
mLimitWidth = widthPixels * 2;
} else {
mLimitWidth = widthPixels;
}
width = widthPixels / urls.size();
rparams = new RelativeLayout.LayoutParams(width, DisplayUtils.dip2px(getApplicationContext(), 1));
rparams.addRule(RelativeLayout.ALIGN_PARENT_BOTTOM);
rparams.bottomMargin = DisplayUtils.dip2px(getApplicationContext(), 10);
@ -155,6 +160,31 @@ public class ViewImageActivity extends BaseActivity implements OnPageChangeListe
} else if (this.getResources().getConfiguration().orientation == Configuration.ORIENTATION_PORTRAIT) {
isOrientation = false;// 竖屏
}
mProgressHint.setOnClickListener(v -> {
int position = mViewPager.getCurrentItem();
Object object = mViewPager.findViewWithTag(position);
if (object != null) {
RelativeLayout view = (RelativeLayout) object;
final ZoomSimpleDraweeView draweeView = view.findViewById(R.id.viewimage_iv_show);
draweeView.getHierarchy().setProgressBarImage(new EmptyDrawable(progress -> {
if (position == mViewPager.getCurrentItem()) { // 防止下载过程中切换图片
int percent = progress / 100;
if (percent < 100) {
mProgressHint.setText((percent + "%"));
} else {
mProgressHint.setText("已完成");
mBaseHandler.postDelayed(() -> {
if (position == mViewPager.getCurrentItem()) { // 防止等待过程中切换图片
mProgressHint.setVisibility(View.GONE);
}
}, 500);
}
}
}));
draweeView.setImageURI(urls.get(position));
}
});
}
@Override
@ -178,10 +208,10 @@ public class ViewImageActivity extends BaseActivity implements OnPageChangeListe
mSlideLine.setLayoutParams(rparams);
mProgressHint.setVisibility(View.GONE);
} else {
ImageInfo imageInfo = mImageInfoMap.get(urls.get(position));
if (imageInfo != null && imageInfo.getFileSize() != null) {
ImageInfoEntity imageInfoEntity = mImageInfoMap.get(urls.get(position));
if (imageInfoEntity != null && imageInfoEntity.getFileSize() != null) {
String size = String.format(Locale.CHINA, "%.1fM",
Integer.valueOf(imageInfo.getFileSize().getValue()) / 1024F/1024F);
Integer.valueOf(imageInfoEntity.getFileSize().getValue()) / 1024F / 1024F);
mProgressHint.setVisibility(View.VISIBLE);
mProgressHint.setText(("查看原图(" + size + ")"));
}
@ -212,18 +242,21 @@ public class ViewImageActivity extends BaseActivity implements OnPageChangeListe
}
private void loadImageInfo(int position) {
private void loadImageInfo(int position, int width) {
String url = urls.get(position);
RetrofitManager.getInstance(this)
.getApi().getImageInfo(url + "?x-oss-process=image/info")
.subscribeOn(Schedulers.io())
.observeOn(AndroidSchedulers.mainThread())
.subscribe(new Response<ImageInfo>() {
.subscribe(new Response<ImageInfoEntity>() {
@Override
public void onResponse(@Nullable ImageInfo response) {
mImageInfoMap.put(url, response);
if (position == mViewPager.getCurrentItem()) {
onPageScrolled(position, 0, 0); // 刷新下载原图提示按钮
public void onResponse(@Nullable ImageInfoEntity response) {
if (response != null && response.getImageWidth() != null &&
Integer.valueOf(response.getImageWidth().getValue()) > width) {
mImageInfoMap.put(url, response);
if (position == mViewPager.getCurrentItem()) {
onPageScrolled(position, 0, 0); // 刷新下载原图提示按钮
}
}
}
});
@ -256,15 +289,18 @@ public class ViewImageActivity extends BaseActivity implements OnPageChangeListe
@Override
public Object instantiateItem(ViewGroup container, int position) {
String url = urls.get(position);
if (mImageInfoMap.get(url) == null) loadImageInfo(position);
Gh_RelativeLayout view = (Gh_RelativeLayout) View.inflate(container.getContext(), R.layout.viewimage_normal_item, null);
ZoomSimpleDraweeView imageView = view.findViewById(R.id.viewimage_iv_show);
loadImage(url, imageView);
if (scaleType != null || isOrientation) {
imageView.getHierarchy().setActualImageScaleType(ScalingUtils.ScaleType.FIT_CENTER);
if (mImagePipeline.isInBitmapMemoryCache(Uri.parse(url))) {
loadImage(url, imageView);
} else {
ImageUtils.addLimitWidthAndLoad(imageView, url, mLimitWidth, imageInfo -> {
if (imageInfo != null && mImageInfoMap.get(url) == null) {
loadImageInfo(position, imageInfo.getWidth()); // 加载图片参数,目的是用户显示原文按钮
}
});
}
//单点退出
@ -306,27 +342,26 @@ public class ViewImageActivity extends BaseActivity implements OnPageChangeListe
}
private void findImageBM() {
String key = urls.get(mViewPager.getCurrentItem());
String hdKey = "http://image.ghzs666.com/pic/hq" + key.substring(key.lastIndexOf("/"));
ImagePipeline imagePipeline = Fresco.getImagePipeline();
String curUrl;
String url = urls.get(mViewPager.getCurrentItem());
String limitUrl = ImageUtils.addLimitWidth(urls.get(mViewPager.getCurrentItem()), mLimitWidth);
String targetUrl = null;
if (imagePipeline.isInBitmapMemoryCache(Uri.parse(hdKey))) {
curUrl = hdKey;
} else if (imagePipeline.isInBitmapMemoryCache(Uri.parse(key))) {
curUrl = key;
} else {
return;
if (mImagePipeline.isInBitmapMemoryCache(Uri.parse(url))) {
targetUrl = url;
} else if (mImagePipeline.isInBitmapMemoryCache(Uri.parse(limitUrl))) {
targetUrl = limitUrl;
}
if (TextUtils.isEmpty(targetUrl)) return;
ImageRequest imageRequest = ImageRequestBuilder
.newBuilderWithSource(Uri.parse(key))
.newBuilderWithSource(Uri.parse(targetUrl))
.setProgressiveRenderingEnabled(true)
.build();
DataSource<CloseableReference<CloseableImage>>
dataSource = imagePipeline.fetchDecodedImage(imageRequest, ViewImageActivity.this);
final String finalCurUrl = curUrl;
dataSource = mImagePipeline.fetchDecodedImage(imageRequest, ViewImageActivity.this);
final String finalCurUrl = targetUrl;
dataSource.subscribe(new BaseBitmapDataSubscriber() {
@Override
protected void onNewResultImpl(Bitmap bitmap) {