Android实战简易教程-第二十八枪(Uri转String型实例)

接上一篇文章。我们能够轻易的获取所选图片的uri,那么我们考虑怎样将获取的uri转换成String型的地址呢?

接下来我们通过实例来研究。布局文件和上篇(二十七枪)一致,我们就不再列出,直接看MainActivity.java:

package com.example.userphoto;

import java.io.File;

import android.app.Activity;
import android.content.Intent;
import android.database.Cursor;
import android.graphics.Bitmap;
import android.graphics.drawable.BitmapDrawable;
import android.graphics.drawable.Drawable;
import android.net.Uri;
import android.os.Bundle;
import android.os.Environment;
import android.provider.MediaStore;
import android.view.View;
import android.view.View.OnClickListener;
import android.widget.Button;
import android.widget.ImageView;
import android.widget.Toast;
import cn.bmob.v3.Bmob;
import cn.bmob.v3.datatype.BmobFile;
import cn.bmob.v3.listener.UploadFileListener;

public class MainActivity extends Activity implements OnClickListener {
	private static final int IMAGE_REQUEST_CODE = 0;
	private static final int CAMERA_REQUEST_CODE = 1;
	private static final int RESIZE_REQUEST_CODE = 2;

	private static final String IMAGE_FILE_NAME = "header.jpg";

	private ImageView mImageHeader;

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

		Bmob.initialize(this, "8f3ffb2658d8a3366a70a0b0ca0b71b2");//初始化Bmob
		setupViews();
	}

	private void setupViews() {
		mImageHeader = (ImageView) findViewById(R.id.image_header);
		final Button selectBtn1 = (Button) findViewById(R.id.btn_selectimage);
		final Button selectBtn2 = (Button) findViewById(R.id.btn_takephoto);
		selectBtn1.setOnClickListener(this);
		selectBtn2.setOnClickListener(this);
	}

	@Override
	public void onClick(View v) {
		switch (v.getId()) {
		case R.id.btn_selectimage:
			Intent galleryIntent = new Intent(Intent.ACTION_GET_CONTENT);
			galleryIntent.addCategory(Intent.CATEGORY_OPENABLE);
			galleryIntent.setType("image/*");//图片
			startActivityForResult(galleryIntent, IMAGE_REQUEST_CODE);
			break;
		case R.id.btn_takephoto:
			if (isSdcardExisting()) {
				Intent cameraIntent = new Intent(
						"android.media.action.IMAGE_CAPTURE");//拍照
				cameraIntent.putExtra(MediaStore.EXTRA_OUTPUT, getImageUri());
				cameraIntent.putExtra(MediaStore.EXTRA_VIDEO_QUALITY, 0);
				startActivityForResult(cameraIntent, CAMERA_REQUEST_CODE);
			} else {
				Toast.makeText(v.getContext(), "请插入sd卡", Toast.LENGTH_LONG)
						.show();
			}
			break;
		}
	}

	@Override
	protected void onActivityResult(int requestCode, int resultCode, Intent data) {
		if (resultCode != RESULT_OK) {
			return;
		} else {
			switch (requestCode) {
			case IMAGE_REQUEST_CODE:
				Uri originalUri=data.getData();//获取图片uri
				resizeImage(originalUri);
				//以下方法将获取的uri转为String类型哦!
				String []imgs={MediaStore.Images.Media.DATA};//将图片URI转换成存储路径
				Cursor cursor=this.managedQuery(originalUri, imgs, null, null, null);
				int index=cursor.getColumnIndexOrThrow(MediaStore.Images.Media.DATA);
				cursor.moveToFirst();
				String img_url=cursor.getString(index);
				showToast(img_url);
				break;
			case CAMERA_REQUEST_CODE:
				if (isSdcardExisting()) {
					resizeImage(getImageUri());

					/*// 上传图片
					String imgpath = getImageUri();
					final BmobFile icon = new BmobFile(new File(imgpath));
					icon.upload(this, new UploadFileListener() {

						@Override
						public void onSuccess() {
							// TODO Auto-generated method stub
							Person person = new Person();
							person.setIcon(icon);
							person.save(MainActivity.this);
							showToast("图片上传成功");
						}

						@Override
						public void onProgress(Integer arg0) {
							// TODO Auto-generated method stub

						}

						@Override
						public void onFailure(int arg0, String arg1) {
							// TODO Auto-generated method stub
							showToast("图片上传失败:"+arg1);
						}
					});*/
				} else {
					Toast.makeText(MainActivity.this, "未找到存储卡,无法存储照片!

",
							Toast.LENGTH_LONG).show();
				}
				break;

			case RESIZE_REQUEST_CODE:
				if (data != null) {
					showResizeImage(data);
				}
				break;
			}
		}

		super.onActivityResult(requestCode, resultCode, data);
	}
	private void showToast(String msg){
		Toast.makeText(this, msg, Toast.LENGTH_SHORT).show();
	}

	private boolean isSdcardExisting() {//推断SD卡是否存在
		final String state = Environment.getExternalStorageState();
		if (state.equals(Environment.MEDIA_MOUNTED)) {
			return true;
		} else {
			return false;
		}
	}

	public void resizeImage(Uri uri) {//重塑图片大小
		Intent intent = new Intent("com.android.camera.action.CROP");
		intent.setDataAndType(uri, "image/*");
		intent.putExtra("crop", "true");//能够裁剪
		intent.putExtra("aspectX", 1);
		intent.putExtra("aspectY", 1);
		intent.putExtra("outputX", 150);
		intent.putExtra("outputY", 150);
		intent.putExtra("return-data", true);
		startActivityForResult(intent, RESIZE_REQUEST_CODE);
	}

	private void showResizeImage(Intent data) {//显示图片
		Bundle extras = data.getExtras();
		if (extras != null) {
			Bitmap photo = extras.getParcelable("data");
			Drawable drawable = new BitmapDrawable(photo);
			mImageHeader.setImageDrawable(drawable);
		}
	}

	private Uri getImageUri() {//获取路径
		return Uri.fromFile(new File(Environment.getExternalStorageDirectory(),
				IMAGE_FILE_NAME));
	}
}

将方法单列出来即:

                                Uri originalUri=data.getData();//获取图片uri
				resizeImage(originalUri);
				//以下方法将获取的uri转为String类型哦!
				String []imgs={MediaStore.Images.Media.DATA};//将图片URI转换成存储路径
				Cursor cursor=this.managedQuery(originalUri, imgs, null, null, null);
				int index=cursor.getColumnIndexOrThrow(MediaStore.Images.Media.DATA);
				cursor.moveToFirst();
				String img_url=cursor.getString(index);
				showToast(img_url);

执行实例会出现例如以下错误:

不懂英文的也大概能看懂,提示权限不足,我们加入例如以下权限:

执行实例,顺利通过:

Toast中显示出了图片的路径,话说获取这路径有什么用?请看下篇文章(二十九枪)。

欢迎转载、点赞、关注,多谢大家的支持!

时间: 2024-10-05 06:37:47

Android实战简易教程-第二十八枪(Uri转String型实例)的相关文章

Android实战简易教程-第二十八枪(基于Bmob实现头像图片设置和网络上传功能!)

上一篇我们介绍了怎样由uri转换成String ,本文就用到了上篇文章的方法.以下我们介绍一下怎样设置头像后将头像图片上传到云端的方法,本文基于Bmob提供的服务. 看一下代码:(布局文件和前两篇文章依然一样,不再提供) package com.example.userphoto; import java.io.File; import android.app.Activity; import android.content.Intent; import android.database.Cur

Android实战简易教程-第二十九枪(基于Face++实现年龄识别APP(一))

我们通过Face++提供的api和服务实现HowOld App的开发.首先我们实现图片的选择功能. 1.main.xml: <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns:tools="http://schemas.android.com/tools" android:id="@+id/container" android:la

Android实战简易教程-第二十五枪(基于Baas的数据表查询下拉刷新和上拉加载实现!)

上一节我们实现了数据表的加载,但是,当数据表数据很多时,我们就要考虑数据的分页,这里我们选用了PullToRefreshListView控件,先看一下该控件的说明: 效果图:                                 正在刷新                                                                       刷新后        一.导入Library 下载源码后(https://github.com/chrisba

Android实战简易教程-第十八枪(ViewPager组件详解)

对于ViewPager组件我们知道: 1)ViewPager类直接继承了ViewGroup类,所有它是一个容器类,可以在其中添加其他的view类. 2)ViewPager类需要一个PagerAdapter适配器类给它提供数据. 3)ViewPager经常和Fragment一起使用,并且提供了专门的FragmentPagerAdapter和FragmentStatePagerAdapter类供Fragment中的ViewPager使用. 下面我们通过实例看一下ViewPager的使用. 一 实现V

Android实战简易教程-第二十六枪(基于ViewPager实现微信页面切换效果)

1.头部布局文件top.xml: <?xml version="1.0" encoding="utf-8"?> <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="match_parent" android:layout_height="40dp" an

Android实战简易教程-第二十二枪(基于Baas的用户注册功能)

基于Baas实现用户的注册功能. 我们使用Bmob提供的API进行实战开发,首先在Bmob官网上下载SDK,然后将jar包拷入工程内. 创建应用,获取应用key: 1.main.xml: <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"     xmlns:tools="http://schemas.android.com/tools"     android:

Android实战简易教程-第十六枪(LineChart实现数据趋势展示)

aChartEngine中的line Chart是线图,是数据显示的一种.首先我们要下载aChartEngine的jar包,然后导入到工程中. 直接看一下代码(部分注释): package com.yayun.linechart; import java.util.ArrayList; import java.util.List; import org.achartengine.ChartFactory; import org.achartengine.chart.PointStyle; imp

Android实战简易教程-第十五枪(实现ListView中Button点击事件监听)

1.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" androi

Android实战简易教程-第十九枪(SwipeRefreshLayout下拉刷新使用实例)

我们来看SwipeRefreshLayout的具体用法,顾名思义此组件就是一个布局,只不过要注意的是此布局内只能有一个直接子View.其实通过文档我们可以知道SwipeRefreshLayout只不过是继承了ViewGroup. 查看文档,我们可以知道,在SwipRefreshLayout中存在一个接口,通过此接口我们可以监听滑动手势,其实使用此组件最重要的步骤就是实现此接口的onRefresh方法,在此方法中实现数据的更新操作.如下: 接口中的方法: 除了OnRefreshListener接口