Android雁翎刀之ImageView之定制头像

传送门 ☞ 轮子的专栏 ☞ 转载请注明 ☞ http://blog.csdn.net/leverage_1229


雁翎刀

        《飞狐外传》鹰爪雁行门弟子:门中大弟子周铁鹪、二弟子曾铁鸥在江湖上成名已久。程灵素曾听师父说起过,知道他门中这一代的弟子,取名第三字多用“鸟”旁,这时听汪铁鹗一报名,又见他使的是雁翎刀,自然一猜便中。 

        今天我们学习如何利用Android平台“雁翎刀”ImageView实现图片适屏裁剪功能。在实际生活中,我们常常会为了设置来电人的大头贴而对接收到的图片进行局部裁剪和缩放,并存储到联系人应用中去。下面给出该情景的案例:

1案例技术要点

(1)使用BitmapFactory.Options类相关方法获取图片真实的宽与高。
(2)使用WindowManager对象的getDefaultDisplay()方法获取屏幕的宽与高。
(3)一个用于打开手机图库的Intent,设置如下:
Intent intent = new Intent(Intent.ACTION_PICK, android.provider.MediaStore.Images.Media.EXTERNAL_CONTENT_URI);

2案例代码陈列

工程包目录


AndroidManifest.xml

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

    <uses-sdk
        android:minSdkVersion="8"
        android:targetSdkVersion="15" />

    <application
        android:icon="@drawable/ic_launcher"
        android:label="@string/app_name" >
        <activity
            android:name=".ImageViewMainActivity"
            android:label="@string/app_name" >
            <intent-filter>
                <action android:name="android.intent.action.MAIN" />

                <category android:name="android.intent.category.LAUNCHER" />
            </intent-filter>
        </activity>
    </application>

</manifest> 

strings.xml

<resources>
    <string name="app_name">ImageView适屏裁剪图片</string>
</resources>

main.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="match_parent"
     android:orientation="vertical">

    <Button
        android:id="@+id/select_btn" 
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:text="选择图片"/>
    <Button
        android:id="@+id/cut_btn" 
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:text="裁剪图片"/>
    <ImageView
        android:id="@+id/show_iv" 
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"/>

</LinearLayout>

ImageViewMainActivity.java

package com.android.imageview;

import android.app.Activity;
import android.content.Intent;
import android.graphics.Bitmap;
import android.graphics.BitmapFactory;
import android.net.Uri;
import android.os.Bundle;
import android.view.View;
import android.view.View.OnClickListener;
import android.widget.Button;
import android.widget.ImageView;

/**
 * ImageView案例二:ImageView实现图片适屏裁剪
 * ImageView主要是用来显示图片的控件,支持对图片进行放大、缩小和旋转等;
 * @author lynnli1229
 */
public class ImageViewMainActivity extends Activity implements OnClickListener {
    private Button selectButton;
    private Button cutButton;
    private ImageView showImage;
    
    private static final int IMAGE_SELECT = 1;
    private static final int IMAGE_CUT = 2;
    
    @Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.main);
        
        selectButton = (Button) findViewById(R.id.select_btn);
        cutButton = (Button) findViewById(R.id.cut_btn);
        showImage = (ImageView) findViewById(R.id.show_iv);
        selectButton.setOnClickListener(this);
        cutButton.setOnClickListener(this);
    }
    
    @Override
    protected void onActivityResult(int requestCode, int resultCode, Intent data) {
        
        super.onActivityResult(requestCode, resultCode, data);
        if(resultCode == RESULT_OK) {
            if(requestCode == IMAGE_SELECT) {
                // 获取图片的路径
                Uri uri = data.getData();
                // 获取屏幕宽度
                int scnwidth = getWindowManager().getDefaultDisplay().getWidth();
                // 获取屏幕高度/2
                int scnheight = getWindowManager().getDefaultDisplay().getHeight()/2;
                try {
                    // Options实现对图片的裁剪
                    BitmapFactory.Options options = new BitmapFactory.Options();
                    // 允许查询图片按照非像素分配给内存
                    options.inJustDecodeBounds = true;
                    Bitmap bitmap = BitmapFactory.decodeStream(getContentResolver().openInputStream(uri), null, options);
                    // 对图片的宽高度对应手机屏幕进行匹配
                    int heightRadio = (int) Math.ceil(options.outHeight / (float) scnheight);// 如果大于1表示图片的高度大于手机屏幕的高度
                    int widthRadio = (int) Math.ceil(options.outWidth / (float) scnwidth);// 如果大于1表示图片的宽度大于手机屏幕的宽度
                    //缩放到1/radio的尺寸和1/radio^2像素
                    if(heightRadio > 1 || widthRadio > 1) { // 图片需要裁剪
                        if(heightRadio > widthRadio) {
                            options.inSampleSize = heightRadio; // 以高度为准
                        }else {
                            options.inSampleSize=widthRadio;
                        }
                    }
                    options.inJustDecodeBounds = false;
                    // BitmapFactory实现对图片适屏
                    bitmap = BitmapFactory.decodeStream(getContentResolver().openInputStream(uri), null, options);
                    showImage.setImageBitmap(bitmap);
                } catch (Exception e) {
                    
                }
            }else if(requestCode == IMAGE_CUT){
                Bitmap bitmap = data.getParcelableExtra("data");
                showImage.setImageBitmap(bitmap);
            }
        } 
    }
    
    @Override
    public void onClick(View v) {
        switch (v.getId()) {
        case R.id.select_btn:
            Intent selectIntent = new Intent(Intent.ACTION_PICK, android.provider.MediaStore.Images.Media.EXTERNAL_CONTENT_URI);//打开图片库
            startActivityForResult(selectIntent, IMAGE_SELECT);
            break;

        case R.id.cut_btn:
            Intent cutIntent = getImageClipIntent();
            startActivityForResult(cutIntent, IMAGE_CUT);
            break;
        }
    }

    private Intent getImageClipIntent() {
        Intent intent = new Intent(Intent.ACTION_GET_CONTENT, null);
        //实现图片裁剪前必须要设置图片的属性和大小
        intent.setType("image/*");//获取任意图片类型
        intent.putExtra("crop", "true");//滑动选中图片区域.
        intent.putExtra("aspectX", 1);//剪切框的比例1:1
        intent.putExtra("aspectY", 1);
        intent.putExtra("outputX", 80);//输出图片大小
        intent.putExtra("outputY", 80);
        intent.putExtra("return-data", true);
        return intent;
    }

}

        友情提示:在使用豌豆荚(2.2以前不支持)或91助手等工具将两张图片导入到模拟器的图片库之后,才能进行图片选择和裁剪操作。

3案例效果展示

  

 

posted @ 2013-05-29 23:09  Innosight  阅读(238)  评论(0编辑  收藏  举报