热门标签 | HotTags
当前位置:  开发笔记 > Android > 正文

Android中Image的简单实例详解

这篇文章主要为大家详细介绍了Android中Image的简单实例,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

在多媒体应用中,Image是最基础的功能模块,接下来我们将看看在Android中是如何获取和存储Image的。Android内嵌的Image获取和存储功能,可以让我们对于整个媒体框架有个比较全面的了解,同时为audio和video的学习打下基础。

一、Image的获取可以通过调Android自带的Camera应用来完成。该应用含有一个Intent-Filter。通过使用
Intent intent = new Intent(MediaStore.ACTION_IMAGE_CAPTURE);startActivityForResult(intent)就可以启动Camera应用了。

二、Image存储,Android系统中含有一个多媒体库,其中包括所有Image、Video、Audio的数据。通过MediaStore对象可以访问相关数据。

闲话少说,直接看例子,这是一本英文书上的,觉得写的很好,自己翻译了一下,并加入了很多注释。以备查询。

package demo.camera; 
import java.io.File; 
import android.app.Activity; 
import android.content.ContentValues; 
import android.content.Intent; 
import android.graphics.Bitmap; 
import android.graphics.BitmapFactory; 
import android.net.Uri; 
import android.os.Bundle; 
import android.os.Environment; 
import android.provider.MediaStore; 
import android.util.Log; 
import android.view.Display; 
import android.view.View; 
import android.widget.Button; 
import android.widget.ImageView; 
/** 
 * 这里多媒体第一个示例,主要介绍Image的获取和存储 
 * Image的获取可以通过Android自带的Camera应用来获得, 
 * 图片的存储需要用到MediaStore对象。Android中的多媒体库。 
 * 
 * @author Administrator 
 * 
 */ 
public class MainActivity extends Activity { 
   
  private static final int RESULT_CODE = 1; 
  private Button btnCamera; 
  private ImageView imageView; 
   
  private Uri imageFilePath; 
   
  @Override 
  public void onCreate(Bundle savedInstanceState) { 
    super.onCreate(savedInstanceState); 
    setContentView(R.layout.main); 
     
     
    imageView = (ImageView)this.findViewById(R.id.imageView); 
    btnCamera = (Button)this.findViewById(R.id.camera); 
    btnCamera.setOnClickListener(new View.OnClickListener() { 
       
      @Override 
      public void onClick(View v) { 
         
         
        /** 
         * 由于Camara返回的是缩略图,我们可以传递给他一个参数EXTRA_OUTPUT, 
         * 来将用Camera获取到的图片存储在一个指定的URI位置处。 
         * 下面就指定image存储在SDCard上,并且文件名为123.jpg 
         * imageFilePath = Environment.getExternalStorageDirectory().getAbsolutePath()+"123.jpg"; 
         * File file = new File(imageFilePath); //创建一个文件 
         * Uri imageUri = Uri.fromFile(file); 
         * 然而Android已经提供了一个多媒体库,那里统一存放了设备上所有的多媒体数据。所以, 
         * 我们可以将获取到的图片存放在那个多媒体库中。 
         * Android提供了MediaStore类,该类是一个ContentProvider,管理着设备上自带的和外部的多媒体文件, 
         * 同时包含着每一个多媒体文件的数据信息。 
         * 为了将数据存储在多媒体库,使用ContentResolver对象来操纵MediaStore对象 
         * 在MediaStore.Images.Media中有两个URI常量,一个是  EXTERNAL_CONTENT_URI,另一个是INTERNAL_CONTENT_URI 
         * 第一个URI对应着外部设备(SDCard),第二个URI对应着系统设备内部存储位置。 
         * 对于多媒体文件,一般比较大,我们选择外部存储方式 
         * 通过使用ContentResolver对象的insert方法我们可以向MediaStore中插入一条数据 
         * 这样在检索那张图片的时候,不再使用文件的路径,而是根据insert数据时返回的URI,获取一个InputStream 
         * 并传给BitmapFactory 
         */ 
        //在这里启动Camera。 
        //Camera中定义了一个Intent-Filter,其中Action是android.media.action.IMAGE_CAPTURE 
        //我们使用的时候,最好不要直接使用这个,而是用MediaStore中的常量ACTION_IMAGE_CAPTURE. 
        //这个常量就是对应的上面的action 
        Intent intent = new Intent(MediaStore.ACTION_IMAGE_CAPTURE); 
       
        //这里我们插入一条数据,ContentValues是我们希望这条记录被创建时包含的数据信息 
        //这些数据的名称已经作为常量在MediaStore.Images.Media中,有的存储在MediaStore.MediaColumn中了 
        //ContentValues values = new ContentValues(); 
        ContentValues values = new ContentValues(3); 
        values.put(MediaStore.Images.Media.DISPLAY_NAME, "testing"); 
        values.put(MediaStore.Images.Media.DESCRIPTION, "this is description"); 
        values.put(MediaStore.Images.Media.MIME_TYPE, "image/jpeg"); 
        imageFilePath = MainActivity.this.getContentResolver().insert(MediaStore.Images.Media.EXTERNAL_CONTENT_URI, values); 
        intent.putExtra(MediaStore.EXTRA_OUTPUT, imageFilePath); //这样就将文件的存储方式和uri指定到了Camera应用中 
         
        //由于我们需要调用完Camera后,可以返回Camera获取到的图片, 
        //所以,我们使用startActivityForResult来启动Camera           
        startActivityForResult(intent, RESULT_CODE); 
         
      } 
    }); 
  } 
  /** 
   * 为了获取Camera返回的图片信息,重写该方法。 
   */ 
  @Override 
  public void onActivityResult(int requestCode, int resultCode, Intent data){ 
    super.onActivityResult(requestCode, resultCode, data); 
    if(resultCode == RESULT_CODE){ 
      //说明是由Camera返回的数据 
      //由Camera应用返回的图片数据是一个Camera对象,存储在一个名为data的extra域 
      //然后将获取到的图片存储显示在ImageView中 
       
      try { 
        Bundle extra = data.getExtras(); 
        /** 
         * 然而为了节约内存的消耗,这里返回的图片是一个121*162的缩略图。 
         * 那么如何返回我们需要的大图呢?看上面 
         * 然而存储了图片。有了图片的存储位置,能不能直接将图片显示出来呢》 
         * 这个问题就设计到对于图片的处理和显示,是非常消耗内存的,对于PC来说可能不算什么,但是对于手机来说 
         * 很可能使你的应用因为内存耗尽而死亡。不过还好,Android为我们考虑到了这一点 
         * Android中可以使用BitmapFactory类和他的一个内部类BitmapFactory.Options来实现图片的处理和显示 
         * BitmapFactory是一个工具类,里面包含了很多种获取Bitmap的方法。BitmapFactory.Options类中有一个inSampleSize,比如设定他的值为8,则加载到内存中的图片的大小将 
         * 是原图片的1/8大小。这样就远远降低了内存的消耗。 
         * BitmapFactory.Options op = new BitmapFactory.Options(); 
         * op.inSampleSize = 8; 
         * Bitmap pic = BitmapFactory.decodeFile(imageFilePath, op); 
         * 这是一种快捷的方式来加载一张大图,因为他不用考虑整个显示屏幕的大小和图片的原始大小 
         * 然而有时候,我需要根据我们的屏幕来做相应的缩放,如何操作呢? 
         * 
         */ 
        //首先取得屏幕对象 
        Display display = this.getWindowManager().getDefaultDisplay(); 
        //获取屏幕的宽和高 
        int dw = display.getWidth(); 
        int dh = display.getHeight(); 
        /** 
         * 为了计算缩放的比例,我们需要获取整个图片的尺寸,而不是图片 
         * BitmapFactory.Options类中有一个布尔型变量inJustDecodeBounds,将其设置为true 
         * 这样,我们获取到的就是图片的尺寸,而不用加载图片了。 
         * 当我们设置这个值的时候,我们接着就可以从BitmapFactory.Options的outWidth和outHeight中获取到值 
         */ 
        BitmapFactory.Options op = new BitmapFactory.Options(); 
        //op.inSampleSize = 8; 
        op.inJustDecodeBounds = true; 
        //Bitmap pic = BitmapFactory.decodeFile(imageFilePath, op);//调用这个方法以后,op中的outWidth和outHeight就有值了 
        //由于使用了MediaStore存储,这里根据URI获取输入流的形式 
        Bitmap pic = BitmapFactory.decodeStream(this 
            .getContentResolver().openInputStream(imageFilePath), 
            null, op); 
        int wRatio = (int) Math.ceil(op.outWidth / (float) dw); //计算宽度比例 
        int hRatio = (int) Math.ceil(op.outHeight / (float) dh); //计算高度比例 
        Log.v("Width Ratio:", wRatio + ""); 
        Log.v("Height Ratio:", hRatio + ""); 
        /** 
         * 接下来,我们就需要判断是否需要缩放以及到底对宽还是高进行缩放。 
         * 如果高和宽不是全都超出了屏幕,那么无需缩放。 
         * 如果高和宽都超出了屏幕大小,则如何选择缩放呢》 
         * 这需要判断wRatio和hRatio的大小 
         * 大的一个将被缩放,因为缩放大的时,小的应该自动进行同比率缩放。 
         * 缩放使用的还是inSampleSize变量 
         */ 
        if (wRatio > 1 && hRatio > 1) { 
          if (wRatio > hRatio) { 
            op.inSampleSize = wRatio; 
          } else { 
            op.inSampleSize = hRatio; 
          } 
        } 
        op.inJustDecodeBounds = false; //注意这里,一定要设置为false,因为上面我们将其设置为true来获取图片尺寸了 
        pic = BitmapFactory.decodeStream(this.getContentResolver() 
            .openInputStream(imageFilePath), null, op); 
        imageView.setImageBitmap(pic); 
      } catch (Exception e) { 
        e.printStackTrace(); 
      }  
    } 
  } 
} 

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。


推荐阅读
  • 深入理解OAuth认证机制
    本文介绍了OAuth认证协议的核心概念及其工作原理。OAuth是一种开放标准,旨在为第三方应用提供安全的用户资源访问授权,同时确保用户的账户信息(如用户名和密码)不会暴露给第三方。 ... [详细]
  • 2023 ARM嵌入式系统全国技术巡讲旨在分享ARM公司在半导体知识产权(IP)领域的最新进展。作为全球领先的IP提供商,ARM在嵌入式处理器市场占据主导地位,其产品广泛应用于90%以上的嵌入式设备中。此次巡讲将邀请来自ARM、飞思卡尔以及华清远见教育集团的行业专家,共同探讨当前嵌入式系统的前沿技术和应用。 ... [详细]
  • 在计算机技术的学习道路上,51CTO学院以其专业性和专注度给我留下了深刻印象。从2012年接触计算机到2014年开始系统学习网络技术和安全领域,51CTO学院始终是我信赖的学习平台。 ... [详细]
  • CSS 布局:液态三栏混合宽度布局
    本文介绍了如何使用 CSS 实现液态的三栏布局,其中各栏具有不同的宽度设置。通过调整容器和内容区域的属性,可以实现灵活且响应式的网页设计。 ... [详细]
  • Linux 系统启动故障排除指南:MBR 和 GRUB 问题
    本文详细介绍了 Linux 系统启动过程中常见的 MBR 扇区和 GRUB 引导程序故障及其解决方案,涵盖从备份、模拟故障到恢复的具体步骤。 ... [详细]
  • 本文介绍了如何使用jQuery根据元素的类型(如复选框)和标签名(如段落)来获取DOM对象。这有助于更高效地操作网页中的特定元素。 ... [详细]
  • 本文将详细介绍如何使用剪映应用中的镜像功能,帮助用户轻松实现视频的镜像效果。通过简单的步骤,您可以快速掌握这一实用技巧。 ... [详细]
  • 深入理解Cookie与Session会话管理
    本文详细介绍了如何通过HTTP响应和请求处理浏览器的Cookie信息,以及如何创建、设置和管理Cookie。同时探讨了会话跟踪技术中的Session机制,解释其原理及应用场景。 ... [详细]
  • 本文介绍如何在 Xcode 中使用快捷键和菜单命令对多行代码进行缩进,包括右缩进和左缩进的具体操作方法。 ... [详细]
  • 本文介绍了一款用于自动化部署 Linux 服务的 Bash 脚本。该脚本不仅涵盖了基本的文件复制和目录创建,还处理了系统服务的配置和启动,确保在多种 Linux 发行版上都能顺利运行。 ... [详细]
  • 在Linux系统中配置并启动ActiveMQ
    本文详细介绍了如何在Linux环境中安装和配置ActiveMQ,包括端口开放及防火墙设置。通过本文,您可以掌握完整的ActiveMQ部署流程,确保其在网络环境中正常运行。 ... [详细]
  • Android 渐变圆环加载控件实现
    本文介绍了如何在 Android 中创建一个自定义的渐变圆环加载控件,该控件已在多个知名应用中使用。我们将详细探讨其工作原理和实现方法。 ... [详细]
  • 如何在WPS Office for Mac中调整Word文档的文字排列方向
    本文将详细介绍如何使用最新版WPS Office for Mac调整Word文档中的文字排列方向。通过这些步骤,用户可以轻松更改文本的水平或垂直排列方式,以满足不同的排版需求。 ... [详细]
  • 本文总结了在使用Ionic 5进行Android平台APK打包时遇到的问题,特别是针对QRScanner插件的改造。通过详细分析和提供具体的解决方法,帮助开发者顺利打包并优化应用性能。 ... [详细]
  • 理解存储器的层次结构有助于程序员优化程序性能,通过合理安排数据在不同层级的存储位置,提升CPU的数据访问速度。本文详细探讨了静态随机访问存储器(SRAM)和动态随机访问存储器(DRAM)的工作原理及其应用场景,并介绍了存储器模块中的数据存取过程及局部性原理。 ... [详细]
author-avatar
锋哥很好
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有