android中的多媒体应用camera

简介:

MainActivity.java

 

 
  1. 代码  
  2.  
  3. package com.amaker.ch11.app;  
  4.  
  5. import java.io.File;  
  6. import java.io.FileOutputStream;  
  7. import java.io.IOException;  
  8.  
  9. import android.app.Activity;  
  10. import android.graphics.PixelFormat;  
  11. import android.hardware.Camera;  
  12. import android.os.AsyncTask;  
  13. import android.os.Bundle;  
  14. import android.os.Environment;  
  15. import android.view.KeyEvent;  
  16. import android.view.SurfaceHolder;  
  17. import android.view.SurfaceView;  
  18.  
  19. public class MainActivity extends Activity {  
  20.     // 声明拍照界面组件SurfaceView  
  21.     private SurfaceView surfaceView;  
  22.     // 声明界面控制组件SurfaceHolder  
  23.     private SurfaceHolder surfaceHolder;  
  24.     // 声明照相机  
  25.     private Camera camera;  
  26.       
  27.     @Override  
  28.     public void onCreate(Bundle savedInstanceState) {  
  29.         super.onCreate(savedInstanceState);  
  30.         setContentView(R.layout.main);  
  31.         // 实例化拍照界面组件  
  32.         surfaceView = (SurfaceView)findViewById(R.id.preview);  
  33.         // 从SurfaceView中获得SurfaceHolder  
  34.         surfaceHolder = surfaceView.getHolder();  
  35.         // 为SurfaceHolder 添加回调  
  36.         surfaceHolder.addCallback(surfaceCallback);  
  37.         surfaceHolder.setType(SurfaceHolder.SURFACE_TYPE_PUSH_BUFFERS);  
  38.     }  
  39.       
  40.     // 响应按键事件  
  41.     @Override  
  42.     public boolean onKeyDown(int keyCode, KeyEvent event) {  
  43.         if(keyCode==KeyEvent.KEYCODE_CAMERA||keyCode==KeyEvent.KEYCODE_SEARCH){  
  44.             takePic();  
  45.             return true;  
  46.         }  
  47.         return super.onKeyDown(keyCode, event);  
  48.     }  
  49.     // 拍照方法  
  50.     private void takePic(){  
  51.         // 停止预览  
  52.         camera.stopPreview();  
  53.         // 拍照  
  54.         camera.takePicture(null,null, pictureCallback);  
  55.     }  
  56.     // 照片回调  
  57.     Camera.PictureCallback pictureCallback = new Camera.PictureCallback() {  
  58.         @Override  
  59.         public void onPictureTaken(byte[] data, Camera camera) {  
  60.             new SavePictureTask().execute(data);  
  61.             camera.startPreview();  
  62.         }  
  63.     };  
  64.       
  65.     // 保存照片任务类  
  66.     class SavePictureTask extends AsyncTask<byte[],String,String>{  
  67.         @Override  
  68.         protected String doInBackground(byte[]... params) {  
  69.             // 创建文件  
  70.             File picture = new File(Environment.getExternalStorageDirectory(),"picture.jpg");  
  71.             // 如果文件存在删除掉  
  72.             if(picture.exists())picture.delete();  
  73.             try {  
  74.                 // 获得文件输出流  
  75.                 FileOutputStream  fos = new FileOutputStream(picture.getPath());  
  76.                 // 写到该文件  
  77.                 fos.write(params[0]);  
  78.                 // 关闭文件流  
  79.                 fos.close();  
  80.             } catch (Exception e) {  
  81.                 e.printStackTrace();  
  82.             }  
  83.             return null;  
  84.         }  
  85.     }  
  86.     // SurfaceHodler 回调,处理打开相机,关闭相机以及照片尺寸的改变  
  87.     SurfaceHolder.Callback surfaceCallback = new SurfaceHolder.Callback() {  
  88.         @Override  
  89.         public void surfaceCreated(SurfaceHolder holder) {  
  90.             // 打开相机  
  91.             camera = Camera.open();  
  92.             try {  
  93.                 // 设置预览  
  94.                 camera.setPreviewDisplay(holder);  
  95.             } catch (IOException e) {  
  96.                 e.printStackTrace();  
  97.             }  
  98.         }  
  99.           
  100.         @Override  
  101.         public void surfaceChanged(SurfaceHolder holder, int format, int width,  
  102.                 int height) {  
  103.             // 获得相机参数  
  104.             Camera.Parameters parameters = camera.getParameters();  
  105.             // 设置照片大小  
  106.             parameters.setPreviewSize(width, height);  
  107.             // 设置照片格式  
  108.             parameters.setPictureFormat(PixelFormat.JPEG);  
  109.             // 设置相机参数  
  110.             camera.setParameters(parameters);  
  111.             // 开始预览  
  112.             camera.startPreview();  
  113.         }  
  114.           
  115.         @Override  
  116.         public void surfaceDestroyed(SurfaceHolder holder) {  
  117.             // 停止预览  
  118.             camera.stopPreview();  
  119.             // 释放相机资源  
  120.             camera.release();  
  121.             camera = null;  
  122.         }  
  123.     };  

代码

package com.amaker.ch11.app;

import java.io.File;
import java.io.FileOutputStream;
import java.io.IOException;

import android.app.Activity;
import android.graphics.PixelFormat;
import android.hardware.Camera;
import android.os.AsyncTask;
import android.os.Bundle;
import android.os.Environment;
import android.view.KeyEvent;
import android.view.SurfaceHolder;
import android.view.SurfaceView;

public class MainActivity extends Activity {
    // 声明拍照界面组件SurfaceView
    private SurfaceView surfaceView;
    // 声明界面控制组件SurfaceHolder
    private SurfaceHolder surfaceHolder;
    // 声明照相机
    private Camera camera;
    
    @Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.main);
        // 实例化拍照界面组件
        surfaceView = (SurfaceView)findViewById(R.id.preview);
        // 从SurfaceView中获得SurfaceHolder
        surfaceHolder = surfaceView.getHolder();
        // 为SurfaceHolder 添加回调
        surfaceHolder.addCallback(surfaceCallback);
        surfaceHolder.setType(SurfaceHolder.SURFACE_TYPE_PUSH_BUFFERS);
    }
    
    // 响应按键事件
    @Override
    public boolean onKeyDown(int keyCode, KeyEvent event) {
        if(keyCode==KeyEvent.KEYCODE_CAMERA||keyCode==KeyEvent.KEYCODE_SEARCH){
            takePic();
            return true;
        }
        return super.onKeyDown(keyCode, event);
    }
    // 拍照方法
    private void takePic(){
        // 停止预览
        camera.stopPreview();
        // 拍照
        camera.takePicture(null,null, pictureCallback);
    }
    // 照片回调
    Camera.PictureCallback pictureCallback = new Camera.PictureCallback() {
        @Override
        public void onPictureTaken(byte[] data, Camera camera) {
            new SavePictureTask().execute(data);
            camera.startPreview();
        }
    };
    
    // 保存照片任务类
    class SavePictureTask extends AsyncTask<byte[],String,String>{
        @Override
        protected String doInBackground(byte[]... params) {
            // 创建文件
            File picture = new File(Environment.getExternalStorageDirectory(),"picture.jpg");
            // 如果文件存在删除掉
            if(picture.exists())picture.delete();
            try {
                // 获得文件输出流
                FileOutputStream  fos = new FileOutputStream(picture.getPath());
                // 写到该文件
                fos.write(params[0]);
                // 关闭文件流
                fos.close();
            } catch (Exception e) {
                e.printStackTrace();
            }
            return null;
        }
    }
    // SurfaceHodler 回调,处理打开相机,关闭相机以及照片尺寸的改变
    SurfaceHolder.Callback surfaceCallback = new SurfaceHolder.Callback() {
        @Override
        public void surfaceCreated(SurfaceHolder holder) {
            // 打开相机
            camera = Camera.open();
            try {
                // 设置预览
                camera.setPreviewDisplay(holder);
            } catch (IOException e) {
                e.printStackTrace();
            }
        }
        
        @Override
        public void surfaceChanged(SurfaceHolder holder, int format, int width,
                int height) {
            // 获得相机参数
            Camera.Parameters parameters = camera.getParameters();
            // 设置照片大小
            parameters.setPreviewSize(width, height);
            // 设置照片格式
            parameters.setPictureFormat(PixelFormat.JPEG);
            // 设置相机参数
            camera.setParameters(parameters);
            // 开始预览
            camera.startPreview();
        }
        
        @Override
        public void surfaceDestroyed(SurfaceHolder holder) {
            // 停止预览
            camera.stopPreview();
            // 释放相机资源
            camera.release();
            camera = null;
        }
    };
}


本文转自linzheng 51CTO博客,原文链接:http://blog.51cto.com/linzheng/1079348

相关文章
|
22天前
|
移动开发 Java Android开发
构建高效Android应用:探究Kotlin与Java的性能差异
【4月更文挑战第3天】在移动开发领域,性能优化一直是开发者关注的焦点。随着Kotlin的兴起,其在Android开发中的地位逐渐上升,但关于其与Java在性能方面的对比,尚无明确共识。本文通过深入分析并结合实际测试数据,探讨了Kotlin与Java在Android平台上的性能表现,揭示了在不同场景下两者的差异及其对应用性能的潜在影响,为开发者在选择编程语言时提供参考依据。
|
23天前
|
数据库 Android开发 开发者
构建高效Android应用:Kotlin协程的实践指南
【4月更文挑战第2天】随着移动应用开发的不断进步,开发者们寻求更流畅、高效的用户体验。在Android平台上,Kotlin语言凭借其简洁性和功能性赢得了开发社区的广泛支持。特别是Kotlin协程,作为一种轻量级的并发处理方案,使得异步编程变得更加简单和直观。本文将深入探讨Kotlin协程的核心概念、使用场景以及如何将其应用于Android开发中,以提高应用性能和响应能力。通过实际案例分析,我们将展示协程如何简化复杂任务,优化资源管理,并为最终用户提供更加流畅的体验。
|
24天前
|
开发框架 安全 Android开发
探索安卓系统的新趋势:智能家居应用的蓬勃发展
随着智能家居概念的兴起,安卓系统在智能家居应用领域的应用日益广泛。本文将探讨安卓系统在智能家居应用开发方面的最新趋势和创新,以及其对用户生活的影响。
14 2
|
27天前
|
缓存 监控 Java
构建高效Android应用:从优化用户体验到提升性能
在竞争激烈的移动应用市场中,为用户提供流畅和高效的体验是至关重要的。本文深入探讨了如何通过多种技术手段来优化Android应用的性能,包括UI响应性、内存管理和多线程处理。同时,我们还将讨论如何利用最新的Android框架和工具来诊断和解决性能瓶颈。通过实例分析和最佳实践,读者将能够理解并实施必要的优化策略,以确保他们的应用在保持响应迅速的同时,还能够有效地利用系统资源。
|
27天前
|
Java Android开发
Android 开发获取通知栏权限时会出现两个应用图标
Android 开发获取通知栏权限时会出现两个应用图标
14 0
|
1月前
|
编解码 算法 Java
构建高效的Android应用:内存优化策略详解
随着智能手机在日常生活和工作中的普及,用户对移动应用的性能要求越来越高。特别是对于Android开发者来说,理解并实践内存优化是提升应用程序性能的关键步骤。本文将深入探讨针对Android平台的内存管理机制,并提供一系列实用的内存优化技巧,以帮助开发者减少内存消耗,避免常见的内存泄漏问题,并确保应用的流畅运行。
|
24天前
|
Java Android开发 开发者
构建高效Android应用:Kotlin协程的实践与优化
在响应式编程范式日益盛行的今天,Kotlin协程作为一种轻量级的线程管理解决方案,为Android开发带来了性能和效率的双重提升。本文旨在探讨Kotlin协程的核心概念、实践方法及其在Android应用中的优化策略,帮助开发者构建更加流畅和高效的应用程序。通过深入分析协程的原理与应用场景,结合实际案例,本文将指导读者如何优雅地解决异步任务处理,避免阻塞UI线程,从而优化用户体验。
|
29天前
|
Java 编译器 Android开发
构建高效Android应用:探究Kotlin与Java的性能差异
在开发高性能的Android应用时,选择合适的编程语言至关重要。近年来,Kotlin因其简洁性和功能性受到开发者的青睐,但其性能是否与传统的Java相比有所不足?本文通过对比分析Kotlin与Java在Android平台上的运行效率,揭示二者在编译速度、运行时性能及资源消耗方面的具体差异,并探讨在实际项目中如何做出最佳选择。
18 4
|
2天前
|
移动开发 Java Android开发
构建高效Android应用:采用Kotlin协程优化网络请求
【4月更文挑战第24天】 在移动开发领域,尤其是对于Android平台而言,网络请求是一个不可或缺的功能。然而,随着用户对应用响应速度和稳定性要求的不断提高,传统的异步处理方式如回调地狱和RxJava已逐渐显示出局限性。本文将探讨如何利用Kotlin协程来简化异步代码,提升网络请求的效率和可读性。我们将深入分析协程的原理,并通过一个实际案例展示如何在Android应用中集成和优化网络请求。
|
2天前
|
调度 Android开发 开发者
构建高效Android应用:探究Kotlin协程的优势与实践
【4月更文挑战第24天】随着移动开发技术的不断演进,提升应用性能和用户体验已成为开发者的核心任务。在Android平台上,Kotlin语言凭借其简洁性和功能性成为主流选择之一。特别是Kotlin的协程功能,它为异步编程提供了一种轻量级的解决方案,使得处理并发任务更加高效和简洁。本文将深入探讨Kotlin协程在Android开发中的应用,通过实际案例分析协程如何优化应用性能,以及如何在项目中实现协程。