游戏截图支持缩放
This commit is contained in:
@ -8,7 +8,6 @@ import android.os.Bundle;
|
||||
import android.os.Handler;
|
||||
import android.os.Message;
|
||||
import android.support.v4.view.PagerAdapter;
|
||||
import android.support.v4.view.ViewPager;
|
||||
import android.support.v4.view.ViewPager.OnPageChangeListener;
|
||||
import android.util.DisplayMetrics;
|
||||
import android.view.View;
|
||||
@ -19,7 +18,6 @@ import com.facebook.drawee.backends.pipeline.Fresco;
|
||||
import com.facebook.drawee.controller.BaseControllerListener;
|
||||
import com.facebook.drawee.drawable.ScalingUtils;
|
||||
import com.facebook.drawee.interfaces.DraweeController;
|
||||
import com.facebook.drawee.view.SimpleDraweeView;
|
||||
import com.facebook.imagepipeline.core.ImagePipeline;
|
||||
import com.gc.materialdesign.views.ProgressBarCircularIndeterminate;
|
||||
import com.gh.base.BaseActivity;
|
||||
@ -27,6 +25,8 @@ import com.gh.common.util.DisplayUtils;
|
||||
import com.gh.common.util.ImageUtils;
|
||||
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 java.io.IOException;
|
||||
import java.net.HttpURLConnection;
|
||||
@ -44,7 +44,7 @@ import java.util.Map;
|
||||
public class ViewImageActivity extends BaseActivity implements
|
||||
OnPageChangeListener {
|
||||
|
||||
private ViewPager viewimage_vp_show;
|
||||
private Gh_ViewPager viewimage_vp_show;
|
||||
private ViewImageAdapter adapter;
|
||||
private View viewimage_slide_line;
|
||||
private RelativeLayout.LayoutParams rparams;
|
||||
@ -71,7 +71,7 @@ public class ViewImageActivity extends BaseActivity implements
|
||||
Object object = viewimage_vp_show.findViewWithTag(position);
|
||||
if (object != null) {
|
||||
RelativeLayout view = (RelativeLayout) object;
|
||||
SimpleDraweeView imageView = (SimpleDraweeView) view.findViewById(R.id.viewimage_iv_show);
|
||||
final ZoomSimpleDraweeView imageView = (ZoomSimpleDraweeView) view.findViewById(R.id.viewimage_iv_show);
|
||||
final ProgressBarCircularIndeterminate progressBar = (ProgressBarCircularIndeterminate) view.findViewById(R.id.viewimage_pb_loading);
|
||||
progressBar.setVisibility(View.VISIBLE);
|
||||
ImageUtils.getInstance(getApplicationContext()).display(newUrls.get(position), urls.get(position), imageView
|
||||
@ -80,6 +80,14 @@ public class ViewImageActivity extends BaseActivity implements
|
||||
public void onFinalImageSet(String id, Object imageInfo, Animatable animatable) {
|
||||
super.onFinalImageSet(id, imageInfo, animatable);
|
||||
progressBar.setVisibility(View.GONE);
|
||||
// if (imageInfo == null){
|
||||
// return;
|
||||
// }
|
||||
// ImageInfo imageInfo1 = (ImageInfo) imageInfo;
|
||||
// int height = imageInfo1.getHeight();
|
||||
// int width = imageInfo1.getWidth();
|
||||
// float index = (float) height / (float) width;
|
||||
// imageView.setImagePro(index);
|
||||
}
|
||||
});
|
||||
}
|
||||
@ -114,7 +122,7 @@ public class ViewImageActivity extends BaseActivity implements
|
||||
viewimage_slide_line = findViewById(R.id.viewimage_slide_line);
|
||||
viewimage_slide_line.setLayoutParams(rparams);
|
||||
|
||||
viewimage_vp_show = (ViewPager) findViewById(R.id.viewimage_vp_show);
|
||||
viewimage_vp_show = (Gh_ViewPager) findViewById(R.id.viewimage_vp_show);
|
||||
adapter = new ViewImageAdapter();
|
||||
viewimage_vp_show.setAdapter(adapter);
|
||||
viewimage_vp_show.setCurrentItem(current);
|
||||
@ -151,7 +159,7 @@ public class ViewImageActivity extends BaseActivity implements
|
||||
|
||||
Gh_RelativeLayout view = (Gh_RelativeLayout) View.inflate(container.getContext(),
|
||||
R.layout.viewimage_normal_item, null);
|
||||
SimpleDraweeView imageView = (SimpleDraweeView) view.findViewById(R.id.viewimage_iv_show);
|
||||
ZoomSimpleDraweeView imageView = (ZoomSimpleDraweeView) view.findViewById(R.id.viewimage_iv_show);
|
||||
|
||||
if (scaleType != null || isOrientation) {
|
||||
imageView.getHierarchy().setActualImageScaleType(ScalingUtils.ScaleType.FIT_CENTER);
|
||||
@ -166,7 +174,15 @@ public class ViewImageActivity extends BaseActivity implements
|
||||
}else {
|
||||
loadImage(url, imageView);
|
||||
}
|
||||
view.setOnSingleTapListener(this);
|
||||
|
||||
//单点退出
|
||||
imageView.setOnSingleClickListener(new ZoomSimpleDraweeView.setOnSingleClickListener() {
|
||||
@Override
|
||||
public void onClick() {
|
||||
finish();
|
||||
}
|
||||
});
|
||||
|
||||
view.setTag(position);
|
||||
container.addView(view);
|
||||
return view;
|
||||
@ -206,10 +222,22 @@ public class ViewImageActivity extends BaseActivity implements
|
||||
|
||||
@Override
|
||||
public void onPageSelected(int position) {
|
||||
|
||||
Gh_RelativeLayout ghRelativeLayout;
|
||||
for (int i = 0; i < viewimage_vp_show.getChildCount(); i++){
|
||||
if (viewimage_vp_show.getChildAt(i).getTag() != null){
|
||||
ghRelativeLayout = (Gh_RelativeLayout) viewimage_vp_show.getChildAt(i);
|
||||
if (ghRelativeLayout == null){
|
||||
return;
|
||||
}
|
||||
ZoomSimpleDraweeView zoomDraweeView = (ZoomSimpleDraweeView) ghRelativeLayout.findViewById(R.id.viewimage_iv_show);
|
||||
zoomDraweeView.reset(); // 重置矩阵,还原图片
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
private void loadImage(String url, SimpleDraweeView imageView){
|
||||
private void loadImage(String url, final ZoomSimpleDraweeView imageView){
|
||||
|
||||
|
||||
if (url.contains(".gif")) {
|
||||
DraweeController controller = Fresco.newDraweeControllerBuilder()
|
||||
.setUri(url)
|
||||
@ -218,13 +246,27 @@ public class ViewImageActivity extends BaseActivity implements
|
||||
imageView.setController(controller);
|
||||
}else {
|
||||
imageView.setImageURI(url);
|
||||
// ImageUtils.getInstance(getApplicationContext()).display(url, imageView, new BaseControllerListener(){
|
||||
// @Override
|
||||
// public void onFinalImageSet(String id, Object imageInfo, Animatable animatable) {
|
||||
// super.onFinalImageSet(id, imageInfo, animatable);
|
||||
// if (imageInfo == null){
|
||||
// return;
|
||||
// }
|
||||
// ImageInfo imageInfo1 = (ImageInfo) imageInfo;
|
||||
// int height = imageInfo1.getHeight();
|
||||
// int width = imageInfo1.getWidth();
|
||||
// float index = (float) height / (float) width;
|
||||
// imageView.setImagePro(index);
|
||||
// }
|
||||
// });
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
|
||||
|
||||
private void checkUrl(final String url, final SimpleDraweeView imageView) {
|
||||
private void checkUrl(final String url, final ZoomSimpleDraweeView imageView) {
|
||||
newUrls = new HashMap<>();
|
||||
new Thread() {
|
||||
@Override
|
||||
@ -266,6 +308,6 @@ public class ViewImageActivity extends BaseActivity implements
|
||||
@Override
|
||||
protected void onDestroy() {
|
||||
super.onDestroy();
|
||||
System.gc();
|
||||
viewimage_vp_show.onDestory(); // 注销EventBus
|
||||
}
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user