Androidはカメラの撮影、選択、写真の裁断機能を実現します。
最近の学習心得:
機能は実現します。丸い顔の写真をクリックして、アルバムのアップロードやカメラをオンにして、得られた画像をトリミングして、トリミングした写真を画像の背景図に設定します。
ステップ:最初のステップ:カテゴリーをカスタマイズし、ImageViewを継承し、DRawメソッドを書き換えて、外観が円形になることを実現します。
ステップ2:コントロールをxmlファイルから参照する
第三ステップ:丸い顔写真のクリックイベントを実現し、クリックしてダイアログ画面を表示し、アルバムを開くかカメラを開くかを確認します。(自動的にはダイアログのコードを省略します。)
第四ステップ:ユーザの選択状況に応じて、アルバムまたはカメラを開く。
ステップ5:撮った写真やアルバムで選択した画像をトリミングし、結果を指定のメモリ領域に保存します。
ステップ6:顔写真の更新
具体的な実現:
第一歩:カテゴリーをカスタマイズし、ImageViewを継承し、DRawメソッドを書き換えて、外観が円形になることを実現する。
機能は実現します。丸い顔の写真をクリックして、アルバムのアップロードやカメラをオンにして、得られた画像をトリミングして、トリミングした写真を画像の背景図に設定します。
ステップ:最初のステップ:カテゴリーをカスタマイズし、ImageViewを継承し、DRawメソッドを書き換えて、外観が円形になることを実現します。
ステップ2:コントロールをxmlファイルから参照する
第三ステップ:丸い顔写真のクリックイベントを実現し、クリックしてダイアログ画面を表示し、アルバムを開くかカメラを開くかを確認します。(自動的にはダイアログのコードを省略します。)
第四ステップ:ユーザの選択状況に応じて、アルバムまたはカメラを開く。
ステップ5:撮った写真やアルバムで選択した画像をトリミングし、結果を指定のメモリ領域に保存します。
ステップ6:顔写真の更新
具体的な実現:
第一歩:カテゴリーをカスタマイズし、ImageViewを継承し、DRawメソッドを書き換えて、外観が円形になることを実現する。
//
public class MyRoundPhoto extends ImageView{
private Paint p;
private Bitmap bitmap;
private Context context;
private int wAndHeight[]=new int[2];
private File file;
public MyRoundPhoto(Context context, AttributeSet attrs, int defStyle) {
super(context, attrs, defStyle);
// TODO Auto-generated constructor stub
// (px)
wAndHeight = getWidthAndHeight(context,attrs);
this.context = context;
//
init();
}
public MyRoundPhoto(Context context) {
super(context);
// TODO Auto-generated constructor stub
// (px)
wAndHeight=getWidthAndHeight(context,attrs);
this.context = context;
init();
}
public MyRoundPhoto(Context context, AttributeSet attrs) {
super(context, attrs);
// (px)
wAndHeight=getWidthAndHeight(context,attrs);
// TODO Auto-generated constructor stub
this.context = context;
init();
}
@Override
protected void onDraw(Canvas canvas) {
// TODO Auto-generated method stub
super.onDraw(canvas);
canvas.drawBitmap(bitmap, new Matrix(), p);
}
private void init(){
// ( )
file = new File(Environment.getExternalStorageDirectory(),Info.PHOTO_NAME);
// , ,
if(file.exists()){
Log.v(" ", " ");
this.bitmap = BitmapFactory.decodeFile(file.getAbsolutePath());
}
else{
Log.v(" ", " ");
//
this.bitmap=BitmapFactory.decodeStream(context.getResources().openRawResource(R.drawable.defalut));
//person.setPicture()
FileOutputStream fos=null;
try {
fos = new FileOutputStream(file);
} catch (FileNotFoundException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
bitmap.compress(Bitmap.CompressFormat.PNG, 100, fos); //
try {
fos.flush();
fos.close();
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
//
this.bitmap = toRoundBitmap(this.bitmap);
p = new Paint();
}
private Bitmap toRoundBitmap(Bitmap map){
//int height = map.getHeight()+100;
int height=convertDIP2PX(context,this.wAndHeight[1]); // (px)
int width = convertDIP2PX(context,this.wAndHeight[0]);// (px)
//
Bitmap bit = Bitmap.createBitmap(width, height, Config.ARGB_8888);
Canvas canvas = new Canvas(bit);
//
Paint paint = new Paint();
paint.setAntiAlias(false);
int r = (width>height)?height:width;
//
RectF rectF = new RectF(0,0,r,r);
canvas.drawRoundRect(rectF, r/2, r/2, paint);
//
//canvas.drawARGB(0, 0, 0, 0);
paint.setXfermode(new PorterDuffXfermode(Mode.SRC_IN));
canvas.drawBitmap(map, null,rectF, paint);
//
return bit;
}
// ,
public void myValidate(){
bitmap = BitmapFactory.decodeFile(file.getAbsolutePath());
bitmap=toRoundBitmap(bitmap);
invalidate();
}
// dp px
private static int convertDIP2PX(Context context, int dip) {
float scale = context.getResources().getDisplayMetrics().density;
return (int)(dip*scale + 0.5f*(dip>=0?1:-1));
}
// xml , (px)
private static int[] getWidthAndHeight(Context context,AttributeSet attrs){
int height,width;
int n = attrs.getAttributeCount();
int wAndH[] = new int[2];
for(int i=0;i<n;i++){
String str = attrs.getAttributeName(i);
//
if(str.equals("layout_width")){
//System.out.println(attrs.getAttributeName(0));
String sttr = attrs.getAttributeValue(i);
String temp = "";
int j=0;
while(sttr.charAt(j)>='0'&&sttr.charAt(j)<='9'){
temp+=sttr.charAt(j);
j++;
}
wAndH[0]=Integer.parseInt(temp);
temp="";
continue;
}
//
if(str.equals("layout_height")){
//System.out.println(attrs.getAttributeName(1));
String sttr = attrs.getAttributeValue(i);
String temp = "";
int j=0;
while(sttr.charAt(j)>='0'&&sttr.charAt(j)<='9'){
temp+=sttr.charAt(j);
j++;
}
//System.out.println("temp"+temp);
wAndH[1]=Integer.parseInt(temp);
temp="";
continue;
}
}
return wAndH;
}
}
ステップ2:コントロールをxmlファイルから参照する
<com. .MyRoundPhoto
android:id="@+id/myRoundPhoto"
android:layout_width="100dp"
android:layout_height="100dp" >
</com. .MyRoundPhoto>
第三ステップ:丸い顔写真のクリックイベントを実現し、クリックしてダイアログ画面を表示し、アルバムを開くかカメラを開くかを確認します。(自動的にはダイアログのコードを省略します。)
public void onClick(View v) {
// TODO Auto-generated method stub
//
if(v.getId()==R.id.myRoundPhoto){
// DialogActivity,
Intent intent = new Intent(GuideActivity.this,DialogActivity.class);
startActivityForResult(intent, Info.PICK_PHOTO);
}
}
第四ステップ:ユーザの選択状況に応じて、アルバムまたはカメラを開く。
image =new File(Environment.getExternalStorageDirectory(),Info.PHOTO_NAME);
public void onClick(View v) {
// TODO Auto-generated method stub
switch(v.getId()){
//
case R.id.imageButton1:{
Intent intent = new Intent("android.media.action.IMAGE_CAPTURE");
intent.putExtra(MediaStore.EXTRA_OUTPUT, Uri.fromFile(image));
startActivityForResult(intent, Info.OPEN_CAMERA);
break;
}
//
case R.id.imageButton2:{
Intent intent = new Intent(Intent.ACTION_PICK);
intent.putExtra(MediaStore.EXTRA_OUTPUT, Uri.fromFile(image));
intent.setType("image/*");
startActivityForResult(intent, Info.OPEN_GALLERY);
break;
}
}
}
ステップ5:撮った写真やアルバムで選択した画像をトリミングし、結果を指定のメモリ領域に保存します。
protected void onActivityResult(int requestCode, int resultCode, Intent data) {
// TODO Auto-generated method stub
super.onActivityResult(requestCode, resultCode, data);
switch(requestCode){
//
case Info.OPEN_CAMERA:{
if(resultCode==RESULT_OK){
// activity
Log.v(" ", " ");
Intent intent1 = new Intent("com.android.camera.action.CROP");
intent1.setDataAndType(Uri.fromFile(image), "image/*");
intent1.putExtra("crop", "true");
intent1.putExtra(MediaStore.EXTRA_OUTPUT, Uri.fromFile(image));//
intent1.putExtra("aspectX", 1);
intent1.putExtra("aspectY", 1);
intent1.putExtra("outputFormat", Bitmap.CompressFormat.JPEG);
intent1.putExtra("outputX", 720);
intent1.putExtra("outputY", 720);
intent1.putExtra("return-data", false);
startActivityForResult(intent1, Info.CROP_PHOTO);
}
break;
}
//
case Info.OPEN_GALLERY:{
if(resultCode==RESULT_OK){
//
Log.v(" ", " ");
Intent intent1 = new Intent("com.android.camera.action.CROP");
intent1.setDataAndType(Uri.fromFile(image), "image/*");
intent1.putExtra("crop", "true");
intent1.putExtra(MediaStore.EXTRA_OUTPUT, Uri.fromFile(image));//
intent1.putExtra("aspectX", 1);
intent1.putExtra("aspectY", 1);
intent1.putExtra("outputFormat", Bitmap.CompressFormat.JPEG);
intent1.putExtra("outputX", 720);
intent1.putExtra("outputY", 720);
intent1.putExtra("return-data", false);
startActivityForResult(intent1, Info.CROP_PHOTO);
}
break;
}
//
case Info.CROP_PHOTO:{
Intent intent=new Intent();
setResult(this.RESULT_OK, intent);
finish();
break;
}
}
}
ステップ6:顔写真の更新
protected void onActivityResult(int requestCode, int resultCode, Intent data) {
// TODO Auto-generated method stub
super.onActivityResult(requestCode, resultCode, data);
switch(requestCode){
//
case Info.PICK_PHOTO:{
//
if(resultCode==RESULT_OK){
Log.v("requstCodeGuideOne", "PICK_PHOTO");
btn_choosePhoto.myValidate(); // ,
}
break;
}
default:{
break;
}
}
}
注意:追加する権限が必要です。
<uses-permission
android:name="android.permission.READ_EXTERNAL_STORAGE"
/>
<uses-permission
android:name="android.permission.WRITE_EXTERNAL_STORAGE"/>
以上が本文の全部です。皆さんの勉強に役に立つように、私たちを応援してください。