<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="fill_parent" android:layout_height="fill_parent" android:background="#F3F1DA" android:orientation="vertical" > <!-- title --> <LinearLayout android:layout_width="fill_parent" android:layout_height="wrap_content" android:layout_gravity="center" android:background="@drawable/corner_stroke" android:gravity="center" android:orientation="horizontal" > <TextView android:layout_width="fill_parent" android:layout_height="wrap_content" android:gravity="center" android:text="我的靓照" android:textColor="@android:color/black" /> </LinearLayout> <!-- image switch --> <RelativeLayout android:id="@+id/switch_face_rl" android:layout_width="fill_parent" android:layout_height="wrap_content" android:layout_gravity="center" android:layout_margin="20dip" android:background="@drawable/corner_stroke_black" android:clickable="true" android:padding="5dip" > <ImageView android:id="@+id/face" android:layout_width="60dip" android:layout_height="60dip" android:layout_alignParentLeft="true" android:layout_marginLeft="10dip" android:background="@drawable/corner_stroke" android:src="@drawable/family_ice_say_relatives" /> <TextView android:layout_width="wrap_content" android:layout_height="60dp" android:layout_marginLeft="5dip" android:layout_marginTop="5dip" android:layout_toRightOf="@id/face" android:layout_gravity="center" android:text="点击设置头像" android:textColor="@android:color/black" /> </RelativeLayout> </LinearLayout>
package com.mm.mmcalendar.activity; import java.io.BufferedOutputStream; import java.io.File; import java.io.FileOutputStream; import android.app.AlertDialog; import android.content.DialogInterface; import android.content.Intent; 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.support.v4.app.FragmentActivity; import android.view.View; import android.widget.ImageView; import android.widget.RelativeLayout; import android.widget.Toast; import com.mm.mmcalendar.R; import com.mm.mmcalendar.dao.SharedPreferencesUtils; import com.mm.mmcalendar.utils.Tools; public class MyFaceActivity extends FragmentActivity { /* 组件 */ private RelativeLayout switchAvatar; private ImageView faceImage; private String[] items = new String[] { "选择本地图片", "拍照" }; /* 头像名称 */ private static final String IMAGE_FILE_NAME = "faceImage.jpg"; /* 请求码 */ private static final int IMAGE_REQUEST_CODE = 0; private static final int CAMERA_REQUEST_CODE = 1; private static final int RESULT_REQUEST_CODE = 2; @Override public void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); //requestWindowFeature(Window.FEATURE_NO_TITLE); // 去掉标题 setContentView(R.layout.myface); switchAvatar = (RelativeLayout) findViewById(R.id.switch_face_rl); faceImage = (ImageView) findViewById(R.id.face); String photo=SharedPreferencesUtils.getStringValue(this, SharedPreferencesUtils.PHOTO_PATH, null); if(photo!=null){ byte[] content = Tools.getImageContentInSize(photo, 310, 310); Bitmap b=Tools.Bytes2Bimap(content); if(b!=null) faceImage.setImageBitmap(b); } // 设置事件监听 switchAvatar.setOnClickListener(listener); } private View.OnClickListener listener = new View.OnClickListener() { @Override public void onClick(View v) { showDialog(); } }; /** * 显示选择对话框 */ private void showDialog() { new AlertDialog.Builder(this) .setTitle("设置头像") .setItems(items, new DialogInterface.OnClickListener() { @Override public void onClick(DialogInterface dialog, int which) { switch (which) { case 0: Intent intentFromGallery = new Intent(); intentFromGallery.setType("image/*"); // 设置文件类型 intentFromGallery .setAction(Intent.ACTION_GET_CONTENT); startActivityForResult(intentFromGallery, IMAGE_REQUEST_CODE); break; case 1: Intent intentFromCapture = new Intent( MediaStore.ACTION_IMAGE_CAPTURE); // 判断存储卡是否可以用,可用进行存储 if (Tools.hasSdcard()) { File path = Environment.getExternalStoragePublicDirectory(Environment.DIRECTORY_DCIM); File file = new File(path,IMAGE_FILE_NAME); intentFromCapture.putExtra( MediaStore.EXTRA_OUTPUT, Uri.fromFile(file)); } startActivityForResult(intentFromCapture,CAMERA_REQUEST_CODE); break; } } }) .setNegativeButton("取消", new DialogInterface.OnClickListener() { @Override public void onClick(DialogInterface dialog, int which) { dialog.dismiss(); } }).show(); } @Override protected void onActivityResult(int requestCode, int resultCode, Intent data) { //结果码不等于取消时候 if (resultCode != RESULT_CANCELED) { switch (requestCode) { case IMAGE_REQUEST_CODE: startPhotoZoom(data.getData()); break; case CAMERA_REQUEST_CODE: if (Tools.hasSdcard()) { File path = Environment.getExternalStoragePublicDirectory(Environment.DIRECTORY_DCIM); File tempFile = new File(path,IMAGE_FILE_NAME); startPhotoZoom(Uri.fromFile(tempFile)); } else { Toast.makeText(MyFaceActivity.this, "未找到存储卡,无法存储照片!",Toast.LENGTH_LONG).show(); } break; case RESULT_REQUEST_CODE: //图片缩放完成后 if (data != null) { getImageToView(data); } break; } } super.onActivityResult(requestCode, resultCode, data); } /** * 裁剪图片方法实现 * * @param uri */ public void startPhotoZoom(Uri uri) { Intent intent = new Intent("com.android.camera.action.CROP"); intent.setDataAndType(uri, "image/*"); // 设置裁剪 intent.putExtra("crop", "true"); // aspectX aspectY 是宽高的比例 intent.putExtra("aspectX", 1); intent.putExtra("aspectY", 1); // outputX outputY 是裁剪图片宽高 intent.putExtra("outputX", 340); intent.putExtra("outputY", 340); intent.putExtra("return-data", true); startActivityForResult(intent, RESULT_REQUEST_CODE); } /** * 保存裁剪之后的图片数据 * * @param picdata */ private void getImageToView(Intent data) { Bundle extras = data.getExtras(); if (extras != null) { Bitmap photo = extras.getParcelable("data"); savePic(photo); photo=Tools.toRoundCorner(photo,7); Drawable drawable = new BitmapDrawable(this.getResources(),photo); faceImage.setImageDrawable(drawable); } } private void savePic(Bitmap photo ){ long l2 = System.currentTimeMillis(); String fileName = l2 + ".jpg"; String tempImgPath = getCacheDir().getAbsolutePath() + "/sysfiles/temp/" + fileName; String dir = getDir(tempImgPath); File dirFile = new File(dir); dirFile.mkdirs(); if (!dirFile.exists()) { Toast.makeText(MyFaceActivity.this, "无法创建SD卡目录,图片无法保存", Toast.LENGTH_LONG).show(); } try { BufferedOutputStream bos = new BufferedOutputStream(new FileOutputStream(tempImgPath)); photo.compress(Bitmap.CompressFormat.JPEG, 75, bos);// (0 - 100)压缩文件 SharedPreferencesUtils.setStringValue(MyFaceActivity.this, SharedPreferencesUtils.PHOTO_PATH, tempImgPath); } catch (Exception e) { e.printStackTrace(); } } public String getDir(String filePath) { int lastSlastPos = filePath.lastIndexOf('/'); return filePath.substring(0, lastSlastPos); } }
相关推荐
android 设置头像,用摄像头直接拍照,从相册里直接获取
本教程将深入探讨如何实现"Android照相或选择图片设置头像"的功能,帮助开发者构建这样的用户体验。 首先,我们需要理解Android中的权限管理。在Android 6.0(API级别23)及以上版本,用户需要在运行时授予访问...
在Android应用开发中,"Android更换头像功能"是一个常见的需求,特别是在社交或者个人信息设置类的应用中。这个功能允许用户选择或拍摄一张照片,然后将其作为个人头像显示在应用中。下面将详细讲解实现这一功能所...
在Android应用开发中,创建吸引用户的界面效果是至关重要的,其中一种常见的视觉特效就是“头像散开动画”。这种效果通常用于用户登录、个人资料页面或者社交应用中,当用户加载或选择头像时,头像会以一种动态的...
在Android平台上,为应用开发头像设置和裁剪功能是一项常见的任务,特别是在社交或个人信息管理类应用中。针对Android 6.0 (Marshmallow) 和 7.0 (Nougat) 的兼容性问题,开发者需要特别关注权限管理和UI设计等方面...
例如,可以有一个`setCircleAvatar()`方法用于设置圆形头像,一个`setOvalAvatar()`方法用于设置椭圆形头像,甚至可以通过自定义参数支持任意形状的头像。 4. **动画支持**:为了增加用户体验,可以添加过渡动画,...
在Android平台上,为应用添加拍照或从相册选取图片并裁剪来设置头像是一个常见的功能,尤其在社交应用和个人信息设置中。本教程将详细解释如何实现这一过程,同时解决三星手机上出现的拍照后图片旋转和图片过大导致...
在移动应用开发中,特别是在Android和iOS平台上,允许用户通过内置的相机功能...通过理解并运用上述知识点,开发者可以构建出一个高效、稳定且用户体验良好的头像设置功能,无论是Android还是iOS用户都能流畅地使用。
在Android应用开发中,"Android 个人头像切换"是一个常见的功能,主要目的是允许用户在个人信息设置中选择或拍摄照片作为自己的头像。这个项目涵盖了Android图像处理、用户交互以及资源管理等多个方面,下面将详细...
在Android应用开发中,修改用户头像是一个常见的功能,它涉及到图像处理、权限管理以及UI交互等多个方面。本文将详细讲解如何实现这个功能,主要基于提供的"Android修改用户头像"这一主题,以及标签"相机"、"相册"和...
在Android应用开发中,用户界面的设计与交互是关键部分,其中头像设置和侧滑功能是常见的用户交互元素。本文将深入探讨如何在Android项目中实现这些功能。 首先,我们来关注“头像设置”这一标签。在Android应用中...
在Android应用开发中,"头像更改"是一个常见的功能,特别是在社交...总结起来,实现Android头像更改功能涉及到组件的交互、图片的加载与显示、用户交互逻辑以及权限管理等多个方面,是一个典型的Android应用开发实践。
获取头像加剪切获取头像加剪切android头像上传(获取头像加剪切)android头像上传(获取头像加剪切)android头像上传(获取头像加剪切)android头像上传(获取头像加剪切)android头像上传(获取头像加剪切)android...
在Android开发中,创建带有头像的二维码是一项实用的技术,它可以将个人照片或者标识与二维码信息结合,使得扫描结果不仅包含文字或链接,还能展示出个性化的视觉效果。本篇文章将详细探讨如何在Android中实现这个...
在Android应用开发中,创建一个圆形头像是一个常见的需求,特别是在社交应用或者用户个人资料页面。本教程将向你展示如何在Android Studio中轻松实现这一功能。我们将主要使用BitmapShader类来实现图像的圆形化。 ...
Android头像剪切,解决了上一版剪切结果偏移的问题。这里是Android Studio版,实现过程可到博客http://blog.csdn.net/qmln31821007/article/details/49995657中查看,博客中有Eclipse版demo下载
在Android应用开发中,"修改头像"是一个常见的功能,用户可以上传个人照片作为自己在应用中的头像。本文将详细讲解如何在5分钟内快速实现这个功能。 首先,我们需要在用户界面(UI)上创建一个可以触发头像更换操作...
在Android开发中,创建一个圆形头像的效果是一个常见的需求,特别是在社交应用或者个人资料界面中。这个需求可以参照QQ等应用中的设计,将用户上传的矩形头像转换为圆形展示,以提供更加美观和一致的用户体验。在这...
在Android开发中,头像图片...总的来说,这个“android头像图片资源”压缩包为开发者提供了丰富的头像图片素材,可以方便地集成到Android应用中,并通过合理的资源管理和图片处理技术,实现高效、美观的头像显示功能。
这个"Android头像设置demo"就是一个实现此类功能的小案例,它提供了从相册选择和拍照两种方式来获取并设置用户的头像。下面将详细解释这个Demo中涉及的关键知识点。 1. **Intent**: 在Android中,Intent是用来启动...