图片的压缩

我们从网上获取图片有时太大我们的手机分辨率不够所以我们就得把图片压缩

下面就是从网上获取图片直接压缩的代码

package com.example.tupian;

import java.io.BufferedInputStream;
import java.io.ByteArrayOutputStream;
import java.io.IOException;
import java.io.InputStream;
import java.net.HttpURLConnection;
import java.net.MalformedURLException;
import java.net.ProtocolException;
import java.net.URL;

import android.R.integer;
import android.os.Bundle;
import android.util.DisplayMetrics;
import android.view.Display;
import android.view.WindowManager;
import android.widget.ImageView;
import android.widget.Toast;
import android.app.Activity;
import android.app.ProgressDialog;
import android.graphics.Bitmap;
import android.graphics.BitmapFactory;
import android.graphics.BitmapFactory.Options;

public class MainActivity extends Activity {

	String path="http://guaju.github.io/flower2.jpg";
	private HttpURLConnection conn;
	private ImageView iv;
	private ProgressDialog progressDialog;
	private BufferedInputStream bufferedInputStream;
	private Bitmap bitmap;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        initView();
        compressImage();
    }

	private void compressImage()  {
		//异步加载框架
		new MyAsync() {

			@Override//加载前
			public void perLoad() {
				//进度条对话框
				progressDialog = new ProgressDialog(MainActivity.this);
				progressDialog.show();//显示对话框

			}

			@Override//加载中
			public void loading() {
				try {
					URL url = new URL(path);
					conn = (HttpURLConnection) url.openConnection();
					conn.setRequestMethod("GET");
					conn.setConnectTimeout(5000);
					int code = conn.getResponseCode();
					if(code==200){//判断是否联网成功
						//得到流
						InputStream inputStream = conn.getInputStream();
//						bufferedInputStream = new BufferedInputStream(inputStream);
//						bufferedInputStream.mark(bufferedInputStream.available());
						ByteArrayOutputStream baos = new ByteArrayOutputStream();
						int temp=0;
						byte[] b=new byte[1024];
						while((temp=inputStream.read(b))!=-1){
							baos.write(b, 0, temp);
						}
						baos.close();
						inputStream.close();

						byte[] array = baos.toByteArray();

						/*压缩图片
						 * 一:先拿到图片的分辨率
						 * 1:得到Option
						 * 2:设置Option的一个取值方式
						 * 3:把Option与图片关联
						 * 4:取出图片大小
						 * 二:计算压缩比例(一般用480*800或者获取屏幕分辨率然后计算)
						 * 1:设置比例(如果实际照片宽大,那么就计算成宽的比例,反之亦然)
						 * 2:设置Option的压缩比例并且设置压缩方式
						 * 3:关联BitmapFactory去压缩图片
						 */

						Options options = new BitmapFactory.Options();//得到Option
						options.inJustDecodeBounds=true;//只是解析一下图片大小,不看内容,节省了空间和内存
//						BitmapFactory.decodeStream(bufferedInputStream, null, options);
						//关联图片
						BitmapFactory.decodeByteArray(array, 0, array.length,options);
						//得到图片的宽和高
						int outHeight=options.outHeight;
						int outWidth=options.outWidth;
						System.out.println("hhhhh"+outHeight+"wwww"+outWidth);

//						int hh=480f;
//						int ww=800f;
						//获取屏幕分辨率
						WindowManager manager = getWindowManager();
						Display display = manager.getDefaultDisplay();//拿到持有屏幕参数的类
						DisplayMetrics metrics = new DisplayMetrics();//屏幕的值
						display.getMetrics(metrics);
						int hh=metrics.heightPixels;
						int ww=metrics.widthPixels;
						int i=1;//压缩比例   1表示不作压缩
						if(outWidth>outHeight&&outWidth>ww){
							i=outWidth/ww;
						}else if (outHeight>outWidth&&outHeight>hh) {
							i=outHeight/hh;
						}else {
							i=1;
						}

						options.inSampleSize=i;//按照什么比例压缩
						options.inJustDecodeBounds=false;//设置option的测量方式改成能读取图片

//							bufferedInputStream.reset();
//							bitmap = BitmapFactory.decodeStream(bufferedInputStream, null, options);
							//关联图片
							bitmap=BitmapFactory.decodeByteArray(array, 0, array.length, options);
//							inputStream.close();
//							bufferedInputStream.close();

						runOnUiThread(new Runnable() {

							@Override
							public void run() {
								Toast.makeText(MainActivity.this, "加载成功", 0).show();
							}
						});

					}
					else {
						runOnUiThread(new Runnable() {

							@Override
							public void run() {
								Toast.makeText(MainActivity.this, "加载失败", 0).show();
							}
						});

					}
				} catch (MalformedURLException e) {
					// TODO Auto-generated catch block
					e.printStackTrace();
				} catch (ProtocolException e) {
					// TODO Auto-generated catch block
					e.printStackTrace();
				} catch (IOException e) {
					// TODO Auto-generated catch block
					e.printStackTrace();
				}
			}

			@Override//加载后
			public void afterLoad() {
				progressDialog.dismiss();//隐藏对话框
				iv.setImageBitmap(bitmap);//显示压缩过的图片

			}
		}.exe();

	}

	private void initView() {
		iv = (ImageView) findViewById(R.id.iv);
	}

}
异步加载框架
<pre name="code" class="java">package com.example.tupian;

import android.os.Handler;

public abstract class MyAsync {

	public abstract void perLoad();
	public abstract void loading();
	public abstract void afterLoad();

	public Handler myhHandler=new Handler(){
		public void handleMessage(android.os.Message msg) {
			if(msg.what==1){

				afterLoad();
			}

		};

	};

	public void exe(){
		perLoad();
		new Thread(new Runnable() {

			@Override
			public void run() {
				loading();
				myhHandler.sendEmptyMessage(1);
			}
		}).start();

	}

}
</pre><pre name="code" class="java">布局文件
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:paddingBottom="@dimen/activity_vertical_margin"
    android:paddingLeft="@dimen/activity_horizontal_margin"
    android:paddingRight="@dimen/activity_horizontal_margin"
    android:paddingTop="@dimen/activity_vertical_margin"
    tools:context=".MainActivity" >

  <ImageView
      android:id="@+id/iv"
      android:layout_width="wrap_content"
      android:layout_height="wrap_content"
      android:layout_centerInParent="true"/>

</RelativeLayout>

先存到本地后压缩


<pre name="code" class="java">package com.example.piccompress;

import java.io.FileOutputStream;
import java.io.IOException;
import java.io.InputStream;
import java.net.HttpURLConnection;
import java.net.MalformedURLException;
import java.net.URL;
import java.net.URLConnection;

import android.os.Bundle;
import android.util.Log;
import android.view.Display;
import android.view.WindowManager;
import android.widget.ImageView;
import android.widget.Toast;
import android.app.Activity;
import android.app.ProgressDialog;
import android.graphics.Bitmap;
import android.graphics.BitmapFactory;
import android.graphics.BitmapFactory.Options;

public class MainActivity extends Activity {

	String path="http://b.hiphotos.baidu.com/zhidao/pic/item/a686c9177f3e6709b0f3328939c79f3df9dc55d0.jpg";
	private ImageView iv;

	@Override
	protected void onCreate(Bundle savedInstanceState) {
		super.onCreate(savedInstanceState);
		setContentView(R.layout.activity_main);
		initView();

		System.out.println("hkjjhkhnlhk");
		//加载图片
		String data = initData();
		System.out.println(data);
		//压缩图片z
		Options options = new BitmapFactory.Options();
		options.inJustDecodeBounds=true;
		BitmapFactory.decodeFile(data, options);
		int outWidth = options.outWidth;
		int outHeight = options.outHeight;
		System.out.println("宽"+outWidth+"高"+outHeight);

		//计算压缩比例
		int scale=1;//压缩比列    1表示不做压缩
		float actWidth=480;
		float actHeight=800;

		//        WindowManager manager = getWindowManager();
		//        Display display = manager.getDefaultDisplay();
		//        int width = display.getWidth();
		//        int height = display.getHeight();
		//        float actHeight=display.getHeight();
		//        float actWidth=display.getWidth();
		//
		if(outWidth>outHeight&&outWidth>actWidth){
			scale=(int) (outWidth/actWidth);

		}else if (outHeight>outWidth&&outHeight>actHeight) {
			scale=(int) (outHeight/actHeight);

		}else {
			scale=1;
		}
		options.inSampleSize=scale;
		options.inJustDecodeBounds=false;
		Bitmap bitmap = BitmapFactory.decodeFile(data, options);
		iv.setImageBitmap(bitmap);
	}

	private String initData() {
		new MyAsync() {

			private ProgressDialog pd;
			private HttpURLConnection conn;

			@Override
			public void preLoad() {
				//进度条对话框
				pd = new ProgressDialog(MainActivity.this);
				pd.show();
			}
			@Override
			public void loading() {
				try {
					URL url = new URL(path);
					try {
						conn = (HttpURLConnection) url.openConnection();
						conn.setRequestMethod("GET");
						conn.setConnectTimeout(5000);
						int code = conn.getResponseCode();
						if(code==200){

							try {

								System.out.println("jkshfskhfalk");
								InputStream is = conn.getInputStream();
								FileOutputStream fos = openFileOutput("jing.jpg", MODE_PRIVATE);
								int temp=0;
								byte[] b=new byte[1024];

								while((temp=is.read(b))!=-1){
									fos.write(b, 0, temp);
								}
								is.close();
								fos.close();

							} catch (IOException e) {
								// TODO Auto-generated catch block
								e.printStackTrace();
							}

							Log.e("wwwwwwwwwww", "233333");

						}else {
							Log.e("", "233333");
							runOnUiThread(new Runnable() {
								public void run() {
									Toast.makeText(MainActivity.this, "加载失败啊!!", 0).show();
								}
							});
						}

					} catch (IOException e) {
						// TODO Auto-generated catch block
						e.printStackTrace();
					}

				} catch (MalformedURLException e) {
					// TODO Auto-generated catch block
					e.printStackTrace();
				}
			}

			@Override
			public void afterLoad() {
				pd.dismiss();
			}
		}.exe();
		//拿到图片地址
		return getFilesDir().getAbsolutePath()+"/jing.jpg";
	}

	private void initView() {
		iv = (ImageView) findViewById(R.id.iv);
	}

}
				
时间: 2024-08-24 17:22:41

图片的压缩的相关文章

移动前端—H5实现图片先压缩再上传

在做移动端图片上传的时候,用户传的都是手机本地图片,而本地图片一般都相对比较大,拿iphone6来说,平时拍很多图片都是一两M的,如果直接这样上传,那图片就太大了,如果用户用的是移动流量,完全把图片上传显然不是一个好办法. 目前来说,HTML5的各种新API都在移动端的webkit上得到了较好的实现.根据查看caniuse,本demo里使用到的FileReader.Blob.Formdata对象均已在大部分移动设备浏览器中得到了实现(safari6.0+.android 3.0+),所以直接在前

Atitit. 图像处理jpg图片的压缩 清理垃圾图片 java版本

Atitit. 图像处理jpg图片的压缩  清理垃圾图片 java版本 1. 清理图片压缩图片尺寸 1 2. 所以要使用ImageWriter 1 3. Thumbnails质量压缩builder.outputQuality(0.9); 2 4. attilax框架的处理 code 2 5. 到一篇文章提到如何控制jpg图片后压缩的质量 3 6. 参考 4 1. 清理图片压缩图片尺寸 目标::300kb>>>10kb.. 处理流程:::scale,outputQuality(0.5) 裁

android图片的压缩

1.质量压缩  bmp.compress() 这种压缩方法之所以称之为质量压缩,是因为它不会减少图片的像素.它是在保持像素的前提下改变图片的位深及透明度等,来达到压缩图片的目的.进过它压缩的图片文件大小会有改变,但是导入成bitmap后占得内存是不变的.因为要保持像素不变,所以它就无法无限压缩,到达一个值之后就不会继续变小了.显然这个方法并不适用与缩略图,其实也不适用于想通过压缩图片减少内存的适用,仅仅适用于想在保证图片质量的同时减少文件大小的情况而已. 2.大小压缩 BitmapFactory

ios中摄像头/相册获取图片,压缩图片,上传服务器方法总结

相册 iphone的相册包含摄像头胶卷+用户计算机同步的部分照片.用户可以通过UIImagePickerController类提供的交互对话框来从相册中选择图像.但是,注意:相册中的图片机器路径无法直接从应用程序访问,只能通过终端用户去选择和使用相册图片 应用程序包 应用程序包可能会将图像与可执行程序.Info.plist文件和其他资源一同存储.我们可以通过本地文件路径来读取这些基于包的图像并在应用程序中显示它们. 沙盒 借助沙盒,我们可以把图片存储到Documents.Library.tmp文

java实现的图片缩放 压缩 裁剪工具!找了很久,市面上再也找不到比它缩放效果还好的代码了

原文:java实现的图片缩放 压缩 裁剪工具!找了很久,市面上再也找不到比它缩放效果还好的代码了 源代码下载地址:http://www.zuidaima.com/share/1550463380458496.htm 纯 java 实现的 图片缩放 压缩 裁剪工具!不依赖任何第三方 jar 包 1. 找了很久,市面上再也找不到比它缩放效果还好的代码了 (再不使用任何第三方组件的前提下) 2. 支持缩放 3. 支持剪切 (例如:用户上传头像后剪切成正方形小图) /* * Copyright 2012

Android加载大图片(压缩)

转载自http://blog.csdn.net/junjx/article/details/7798604 在Android开发中,我们经常需要加载图片.但是图片的尺寸往往会很大,如果我们要的是比较小的图片,在Android有限的内存下,我们显然不能把大尺寸的图片放到内存里,这样不但效率降低,而且会导致java.lang.OutOfMemory异常,相信很多朋友都遇到过这样的问题,那么该怎么解决这一问题呢?其实在Android官方文档中早已给出了解决的方案. 一.读Bitmap的尺寸和类型   

phpPHP创建创建jpg格式图片以及压缩图片(转)

其实是因为一些业务上的需求,所以需要对用户上传后的图片进行压缩,因为上传的图片比较大,显示的时候加载起来如果网速不给力的话就很吃力了,而且大图片也浪费空间,于是找了一下相关的资源,主要方法在开源中国上找到了: http://www.oschina.net/question/814955_115750 然后,图片压缩后显示出来了,但是要保存,所以还需要进行处理,然后看到了另外一篇文章: http://www.nowamagic.net/php/php_CreateJpg.php 这里就将这篇文章转

js图片前端压缩多图上传(旋转其实已经好了只是手机端有问题要先压缩再旋转)

var filechooser = document.getElementById("choose"); // 用于压缩图片的canvas var canvas = document.createElement("canvas"); var ctx = canvas.getContext('2d'); // 瓦片canvas var tCanvas = document.createElement("canvas"); var tctx = tC

iOS 使用AFN 进行单图和多图上传 摄像头/相册获取图片,压缩图片

图片上传时必要将图片进行压缩,不然会上传失败 首先是同系统相册选择图片和视频.iOS系统自带有UIImagePickerController,可以选择或拍摄图片视频,但是最大的问题是只支持单选,由于项目要求需要支持多选,只能自己自定义.获取系统图库的框架有两个,一个是ALAssetsLibrary,兼容iOS低版本,但是在iOS9中是不建议使用的:另一个是PHAsset,但最低要求iOS8以上.兼容到iOS7,可以选择了ALAssetsLibrary 现在我们先说选择一张图的情况 一.单图多图上