android平台拍照后先剪裁再显示图片实现方法

  mainActivity如下:

  package cn.testcamera;

  import java.io.File;

  import java.text.SimpleDateFormat;

  import java.util.Date;

  import android.app.Activity;

  import android.content.ContentResolver;

  import android.content.ContentUris;

  import android.content.Intent;

  import android.database.Cursor;

  import android.graphics.Bitmap;

  import android.graphics.BitmapFactory;

  import android.net.Uri;

  import android.os.Bundle;

  import android.provider.MediaStore;

  import android.view.View;

  import android.widget.Button;

  import android.widget.ImageView;

  public class MainActivity extends Activity {

  private Button mButton;

  private ImageView mImageView;

  private File mPhotoFile;

  private String mPhotoPath;

  private Uri mPhotoOnSDCardUri;

  public final static int CAMERA_RESULT=777;

  public final static int CAMERA_RESULT_CUT=888;

  public final static int CAMERA_RESULT_CUT_OVER=999;

  public final static String TAG="xx";

  @Override

  public void onCreate(Bundle savedInstanceState) {

  super.onCreate(savedInstanceState);

  setContentView(R.layout.main);

  mButton = (Button) findViewById(R.id.button);

  mButton.setOnClickListener(new ButtonOnClickListener());

  mImageView = (ImageView) findViewById(R.id.imageView);

  }

  private class ButtonOnClickListener implements View.OnClickListener {

  public void onClick(View v) {

  try {

  Intent intent = new Intent("android.media.action.IMAGE_CAPTURE");

  mPhotoPath="mnt/sdcard/DCIM/Camera/"+getPhotoFileName();

  mPhotoFile = new File(mPhotoPath);

  if (!mPhotoFile.exists()) {

  mPhotoFile.createNewFile();

  }

  mPhotoOnSDCardUri=Uri.fromFile(mPhotoFile);

  intent.putExtra(MediaStore.EXTRA_OUTPUT, mPhotoOnSDCardUri);

  //拍照后显示此图片

  //startActivityForResult(intent,CAMERA_RESULT);

  //拍照后先修改再显示此图片

  startActivityForResult(intent,CAMERA_RESULT_CUT);

  } catch (Exception e) {

  }

  }

  }

  @Override

  protected void onActivityResult(int requestCode, int resultCode, Intent data) {

  super.onActivityResult(requestCode, resultCode, data);

  //1 拍照后显示照片

  if (requestCode==CAMERA_RESULT) {

  Bitmap bitmap = BitmapFactory.decodeFile(mPhotoPath, null);

  mImageView.setImageBitmap(bitmap);

  }

  //2 拍照后剪切照片,然后显示

  //2.1拍照且剪裁

  if (requestCode == CAMERA_RESULT_CUT) {

  Intent intent = new Intent(Intent.ACTION_MEDIA_SCANNER_SCAN_FILE,mPhotoOnSDCardUri);

  sendBroadcast(intent);

  try {

  Thread.sleep(2000);

  } catch (InterruptedException e) {

  e.printStackTrace();

  }

  Uri systemImageUri = MediaStore.Images.Media.EXTERNAL_CONTENT_URI;

  ContentResolver contentResolver = getContentResolver();

  Cursor cursor = contentResolver.query(systemImageUri, null,

  MediaStore.Images.Media.DISPLAY_NAME + "='"

  + mPhotoFile.getName() + "'", null, null);

  Uri photoUriInMedia = null;

  if (cursor != null && cursor.getCount() > 0) {

  cursor.moveToLast();

  long id = cursor.getLong(0);

  photoUriInMedia = ContentUris.withAppendedId(systemImageUri, id);

  }

  cursor.close();

  Intent in = new Intent("com.android.camera.action.CROP");

  //需要裁减的图片格式

  in.setDataAndType(photoUriInMedia, "image/*");

  //允许裁减

  in.putExtra("crop", "true");

  //剪裁后ImageView显时图片的宽

  in.putExtra("outputX", 250);

  //剪裁后ImageView显时图片的高

  in.putExtra("outputY", 250);

  //设置剪裁框的宽高比例

  in.putExtra("aspectX", 1);

  in.putExtra("aspectY", 1);

  in.putExtra("return-data", true);

  startActivityForResult(in, CAMERA_RESULT_CUT_OVER);

  }

  //2.2显示

  if (requestCode==CAMERA_RESULT_CUT_OVER) {

  //剪切图片的时候,若"放弃"则回答的data为null

  if (data!=null) {

  Bitmap bitmap = (Bitmap) data.getExtras().get("data");

  mImageView.setImageBitmap(bitmap);

  }

  }

  }

  private String getPhotoFileName() {

  Date date = new Date(System.currentTimeMillis());

  SimpleDateFormat dateFormat = new SimpleDateFormat("'IMG'_yyyyMMdd_HHmmss");

  return dateFormat.format(date) + ".jpg";

  }

  }

main.xml如下:

<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" >

    <Button
        android:id="@+id/button"
        android:layout_width="fill_parent"
        android:layout_height="wrap_content"
        android:text="点击按钮拍照"
     />
    <ImageView
        android:id="@+id/imageView"
        android:layout_below="@id/button"
        android:layout_width="fill_parent"
        android:layout_height="wrap_content"
     />

</RelativeLayout>

manifest.xml如下:

<manifest xmlns:android="http://schemas.android.com/apk/res/android"
    package="cn.testcamera"
    android:versionCode="1"
    android:versionName="1.0" >

    <uses-sdk
        android:minSdkVersion="8"
        android:targetSdkVersion="10" />
    <uses-permission android:name="android.permission.CAMERA"/>
    <uses-permission android:name="android.permission.INTERNET" />
    <uses-permission android:name="android.permission.ACCESS_NETWORK_STATE" />
    <uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE" />

    <application
        android:icon="@drawable/ic_launcher"
        android:label="@string/app_name"
        android:theme="@style/AppTheme" >
        <activity
            android:name=".MainActivity"
            android:launchMode="singleTask"
            android:label="@string/title_activity_main" >
            <intent-filter>
                <action android:name="android.intent.action.MAIN" />
                <category android:name="android.intent.category.LAUNCHER" />
            </intent-filter>
        </activity>
    </application>

</manifest>

以上是小编为您精心准备的的内容,在的博客、问答、公众号、人物、课程等栏目也有的相关内容,欢迎继续使用右上角搜索按钮进行搜索android
, 图片
, private
, hhmmss
, close() scanner java
, intent
, android camera
, import
, contentresolver
, public
, android拍照
, camera 自动拍照
, camera平台android
android camera
android 拍照剪裁、android实现拍照功能、android实现连续拍照、android 实现拍照、微信小程序 拍照 剪裁,以便于您获取更多的相关知识。

时间: 2024-11-05 17:18:09

android平台拍照后先剪裁再显示图片实现方法的相关文章

Android拍照后先剪裁再显示图片

mainActivity如下: package cn.testcamera; import java.io.File; import java.text.SimpleDateFormat; import java.util.Date; import android.app.Activity; import android.content.ContentResolver; import android.content.ContentUris; import android.content.Inte

android相机拍照后上传到指定文件夹,opencv是通过调用文件夹里图片进行处理的吗?

问题描述 android相机拍照后上传到指定文件夹,opencv是通过调用文件夹里图片进行处理的吗? 现在有一个Android拍照上传到指定文件夹的程序和一个opencv图像匹配的程序,能否通过修改某些语句和配置环境可以将两者结合?如果可以求大神赐教!(opencv是在文件夹选取图片进行匹配的.) 解决方案 可以直接调用文件夹里的图片处理,配置的话把路径配置成相对路径就可以了

c# serial port接收信息后转换格式再显示的问题

问题描述 c# serial port接收信息后转换格式再显示的问题 可以确保发送出来的信息是对的,接收到的也是对的.可是我再把它从byte转换成float并显示为string,就不是每次都能成功了.拜托大神们具体说说怎么改.相信问题出在switch statement里面.谢谢! 我的通讯协议是EE, instruction,number of data, data ,FF private void DataReceivedHandler(object sender, SerialDataRe

导致U盘插入后无盘符显示的解决方法

  导致U盘插入后无盘符显示的解决方法           如今U盘真是随处可见,现在不仅仅是从事IT业的人士才会用到的存储工具基本上都会买一个存储数据以及文件. 当然u盘用的多了出现的问题也会相对而言比较多. 那么今天XP系统大全跟大家分享下针对为什么U盘插入后出现了无盘符显示的原因分析和解释. XP系统在安装sp2以后插入U盘,能正确识别,但是资源管理器里却没有盘符,而其他USB设备(如:鼠标)则没有故障,更换U盘测试,故障相同,主要的原因是设置的一个网络硬盘的盘符与分配给U盘的盘符相同,解

Android编程实现等比例显示图片的方法_Android

本文实例讲述了Android编程实现等比例显示图片的方法.分享给大家供大家参考,具体如下: 在android中,由于密度的影响,如果想得到图片的宽高是不行的,具体为什么我就大概说一下,具体的请搜索度娘或者古哥吧. 原因是如果你把图片放在drawable-mdpi里,而手机是属于drawable-hdpi的话,图片是被自动放大,就这样取到的宽与高未必就是正确的.那么如何让android上面显示的图片是基于原来图片的比例呢,首先你可以在res目录下创建一个drawable-nodpi的目录,这个目录

Android编程实现等比例显示图片的方法

本文实例讲述了Android编程实现等比例显示图片的方法.分享给大家供大家参考,具体如下: 在android中,由于密度的影响,如果想得到图片的宽高是不行的,具体为什么我就大概说一下,具体的请搜索度娘或者古哥吧. 原因是如果你把图片放在drawable-mdpi里,而手机是属于drawable-hdpi的话,图片是被自动放大,就这样取到的宽与高未必就是正确的.那么如何让android上面显示的图片是基于原来图片的比例呢,首先你可以在res目录下创建一个drawable-nodpi的目录,这个目录

Android编程实现手绘及保存为图片的方法(附demo源码下载)_Android

本文实例讲述了Android编程实现手绘及保存为图片的方法.分享给大家供大家参考,具体如下: 运行效果图预览: 应 yzuo_08 要求做了此Demo,跟以前那个手写板Demo不同的是可以将画布的内容保存为图片. 附上关键代码: MainView.java package com.tszy.views; import java.io.File; import java.io.FileNotFoundException; import java.io.FileOutputStream; impor

JavaScript实现定时隐藏与显示图片的方法_javascript技巧

本文实例讲述了JavaScript实现定时隐藏与显示图片的方法.分享给大家供大家参考.具体如下: 这里使用JavaScript实现定时隐藏与显示图片,设定图片在几秒后会自动显示,也会自动隐藏,秒数这个自己去定义吧,在JavaScript代码片段内. 运行效果如下图所示: 具体代码如下: <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/lo

js实现下拉框选择要显示图片的方法

 这篇文章主要介绍了js实现下拉框选择要显示图片的方法,涉及针对js操作select的技巧,非常具有实用价值,需要的朋友可以参考下     本文实例讲述了js实现下拉框选择要显示图片的方法.分享给大家供大家参考.具体实现方法如下: ? 1 2 3 4 5 6 7 8 9 10 11 12 <html> <title>下拉框选择要显示的图片</title> <body> <img width=320 height=240 src="images