游戏截图支持缩放

This commit is contained in:
khy
2016-10-27 19:00:34 +08:00
parent 929038fc30
commit 96e59d764a
7 changed files with 401 additions and 24 deletions

View File

@ -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
}
}