开发者社区> 古镇月影> 正文
阿里云
为了无法计算的价值
打开APP
阿里云APP内打开

android 拍照并保存

简介: 引用:http://blog.sina.com.cn/s/blog_821e2bb10101475x.html 第一种:   字节数组data保存Bitmap对象转为字节数组,处理代码: BitmapFactory.
+关注继续查看

引用:http://blog.sina.com.cn/s/blog_821e2bb10101475x.html

第一种:

  字节数组data保存Bitmap对象转为字节数组,处理代码:

BitmapFactory.decodeByteArray(data, 0, data.length);

第二种:

ByteArrayOutputStream baos = new ByteArrayOutputStream();
bitmap.compress(Bitmap.CompressFormat.JPEG, 100, baos);
data2 = baos.toByteArray();

这里其实很好理解,第二种方法使用了Bitmap的compress方法,一般用于保存一个Bitmap对象,转为字节输出流,但是compress目前编码由两种,比如JPG,一般处理照片和PNG,PNG一般处理带Alpha透明通道的图片,后面的第二个参数是清晰度,一般100是最高,0是最低,这个值越大图片越清晰,同时文件体积越大,JPG和PNG都是压缩的图片,所以和原始的直接通过 BitmapFactory.decodeByteArray解码后的大小会有很大的不同。

 

android调用照相机拍照获取照片并做简单剪裁:

1.调用系统的照相机程序
Intent intent = newIntent(MediaStore.ACTION_IMAGE_CAPTURE);
 startActivityForResult(intent,TAKE_PHOTO_WITH_DATA);

2.在onActivityResult中处理返回的data
final Bitmap photo = data.getParcelableExtra("data");
如果不需要做剪切处理就可以直接使用图片了,比如输出到ImageView上
imageView.setImageBitmap(photo);
如果需要做剪切处理,就继续向下执行

3.做剪切处理
       Intent intent = newIntent("com.android.camera.action.CROP");
       intent.setType("image
   private Button btnTake = null;
   private ImageView lblImage = null;
   
   private static final int PHOTO_PICKED_WITH_DATA = 3021;
   private static final int CAMERA_WITH_DATA = 3023;
   
   @Override
   public void onCreate(Bundle savedInstanceState) {
       super.onCreate(savedInstanceState);
       setContentView(R.layout.main);
       
       btnTake = (Button)findViewById(R.id.btnTake);
       lblImage = (ImageView)findViewById(R.id.lblImage);
       btnTake.setOnClickListener(new View.OnClickListener() {
           
           @Override
           public void onClick(View v) {
               // TODO Auto-generated method stub
               Intent intent = newIntent(MediaStore.ACTION_IMAGE_CAPTURE);
               startActivityForResult(intent, CAMERA_WITH_DATA);
           }
       });
       
   }
   
   @Override
   protected void onActivityResult(int requestCode, int resultCode,Intent data) {
       // TODO Auto-generated method stub
       if(resultCode!=RESULT_OK)
           return;
       switch(requestCode){
       case CAMERA_WITH_DATA:
           final Bitmap photo = data.getParcelableExtra("data");
           if(photo!=null){
               doCropPhoto(photo);
           }
       case PHOTO_PICKED_WITH_DATA:
           Bitmap photo1 = data.getParcelableExtra("data");
           if(photo1!=null){
               lblImage.setImageBitmap(photo1);
           }
           
       }
   }
   
   protected void doCropPhoto(Bitmap data){
       Intent intent = getCropImageIntent(data);
       startActivityForResult(intent, PHOTO_PICKED_WITH_DATA);
   }
   
   public static Intent getCropImageIntent(Bitmap data) {
       Intent intent = newIntent("com.android.camera.action.CROP");
       intent.setType("image/*");
       intent.putExtra("data", data);
       intent.putExtra("crop", "true");
       intent.putExtra("aspectX", 1);
       intent.putExtra("aspectY", 1);
       intent.putExtra("outputX", 128);
       intent.putExtra("outputY", 128);
       intent.putExtra("return-data", true);
       return intent;
   }
}

 

 

完整代码:

package com.chc.android;

import android.app.Activity;
import android.content.Intent;
import android.graphics.Bitmap;
import android.os.Bundle;
import android.provider.MediaStore;
import android.view.View;
import android.widget.Button;
import android.widget.ImageView;

public class tapgetcut extends Activity {
private Button btnTake = null;
private ImageView lblImage = null;

private static final int PHOTO_PICKED_WITH_DATA = 3021;
private static final int CAMERA_WITH_DATA = 3023;

@Override
public void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.main);
   
    btnTake = (Button)findViewById(R.id.btn01);
    lblImage = (ImageView)findViewById(R.id.iv01);
    btnTake.setOnClickListener(new View.OnClickListener() {
       
        @Override
        public void onClick(View v) {
            // TODO Auto-generated method stub
            Intent intent = new Intent(MediaStore.ACTION_IMAGE_CAPTURE);
            startActivityForResult(intent, CAMERA_WITH_DATA);
        }
    });
   
}

@Override
protected void onActivityResult(int requestCode, int resultCode, Intent data) {
    // TODO Auto-generated method stub
    if(resultCode!=RESULT_OK)
        return;
    switch(requestCode){
    case CAMERA_WITH_DATA:
        final Bitmap photo = data.getParcelableExtra("data");
        if(photo!=null){
            doCropPhoto(photo);
        }
    case PHOTO_PICKED_WITH_DATA:
        Bitmap photo1 = data.getParcelableExtra("data");
        if(photo1!=null){
            lblImage.setImageBitmap(photo1);
        }
       
    }
}

protected void doCropPhoto(Bitmap data){
    Intent intent = getCropImageIntent(data);
    startActivityForResult(intent, PHOTO_PICKED_WITH_DATA);
}

public static Intent getCropImageIntent(Bitmap data) {
    Intent intent = new Intent("com.android.camera.action.CROP");
    intent.setType("image/*");
    intent.putExtra("data", data);
    intent.putExtra("crop", "true");
    intent.putExtra("aspectX", 1);
    intent.putExtra("aspectY", 1);
    intent.putExtra("outputX", 128);
    intent.putExtra("outputY", 128);
    intent.putExtra("return-data", true);
    return intent;
}
}

xml:

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:orientation="vertical"
    android:layout_width="fill_parent"
    android:layout_height="fill_parent"
    >
<TextView
    android:id ="@+id/test01"
    android:layout_width="fill_parent"
    android:layout_height="wrap_content"
    android:text="@string/hello"
    />
<Button
    android:id="@+id/btn01"
      android:layout_width="fill_parent"
    android:layout_height="wrap_content"
    android:text="确定"
    />
<ImageView android:id="@+id/iv01"
    android:layout_width="fill_parent"
    android:layout_height="wrap_content"
    ></ImageView>
</LinearLayout>

注:貌似这篇文章与题目不符,仔细看看这两个模块,是不是豁然开朗呢

版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。

相关文章
Android调用相机拍照录视频录音以及存储,7.0以上及以下都可使用。
Android调用相机拍照录视频录音以及存储,7.0以上及以下都可使用。
0 0
Android MVVM框架搭建(七)Permission、AlertDialog、拍照和相册选取
Android MVVM框架搭建(七)Permission、AlertDialog、拍照和相册选取
0 0
Android 更换用户头像(拍照、相册选取)
Android 更换用户头像(拍照、相册选取)
0 0
android CameraX牛刀小试-预览、抽帧、拍照功能实现
android CameraX牛刀小试-预览、抽帧、拍照功能实现
0 0
Android拉起系统相机拍照的两种方式及陷阱
在Android中我们可以通过Camera Api在应用内拍照,也可以拉起系统相机进行拍照。拉起系统相机拍照有两种方式。
0 0
Android中的拍照camera和camera2
在android我们可以调用系统的相机来进行照相,当然也可以设计自己的照相页面,通过surface进行预览,通过camera api来进行拍照即可。 在Android 5.0之后google推荐使用的Camera2 Api,但是由于兼容问题我们大部分还在使用Camera Api。这里我们一起简单介绍一下,仅仅是预览拍照,至于细节的设置,比如图像大小比例、对焦、图像旋转等就不一一细说了。 首先我们需要在布局中加入一个SurfaceView
0 0
【Flutter】Flutter 拍照示例 ( Flutter 插件配置 | Flutter 插件源码示例 | iOS 应用配置 | Android 应用配置 )(二)
【Flutter】Flutter 拍照示例 ( Flutter 插件配置 | Flutter 插件源码示例 | iOS 应用配置 | Android 应用配置 )(二)
0 0
【Flutter】Flutter 拍照示例 ( Flutter 插件配置 | Flutter 插件源码示例 | iOS 应用配置 | Android 应用配置 )(一)
【Flutter】Flutter 拍照示例 ( Flutter 插件配置 | Flutter 插件源码示例 | iOS 应用配置 | Android 应用配置 )(一)
0 0
【Flutter】Flutter 拍照示例 ( Android 应用兼容 Android X | Gradle 版本号 | Gradle 插件版本号 | Android X 支持 | SDK 版本 )(二)
【Flutter】Flutter 拍照示例 ( Android 应用兼容 Android X | Gradle 版本号 | Gradle 插件版本号 | Android X 支持 | SDK 版本 )(二)
0 0
【Flutter】Flutter 拍照示例 ( Android 应用兼容 Android X | Gradle 版本号 | Gradle 插件版本号 | Android X 支持 | SDK 版本 )(一)
【Flutter】Flutter 拍照示例 ( Android 应用兼容 Android X | Gradle 版本号 | Gradle 插件版本号 | Android X 支持 | SDK 版本 )(一)
0 0
+关注
文章
问答
文章排行榜
最热
最新
相关电子书
更多
Android组件化实现
立即下载
蚂蚁聚宝Android秒级编译—— Freeline
立即下载
Android插件化:从入门到放弃
立即下载