Android个人中心的头像上传,图片编码及截取实例
发布时间 - 2026-01-10 21:51:22 点击率:次首先需要有网络权限,然后我们这里匹配的网络请求是之前封装好的Okhttp。

非常的简单方便,直接复制进去,依赖一下包,然后调用方法即可。
这里是把图片转换成Base64.decode(imageString, Base64.DEFAULT);
转成Base64编码上传。具体内容也不少,需要完全整明白,还是要花点时间慢慢看的。
先看看简单的效果图:
那么万事具备,只欠东风了。直接上代码:
public class MainActivity extends AppCompatActivity implements View.OnClickListener {
private ImageView iv_img;
private Button bt_camera;
private Button bt_xiangce;
private static final int PHOTO_REQUEST_CAREMA = 1;// 拍照
private static final int PHOTO_REQUEST_GALLERY = 2;// 从相册中选择
private static final int PHOTO_REQUEST_CUT = 3;// 结果
/* 头像名称 */
private static final String PHOTO_FILE_NAME = "temp_photo.jpg";
private File tempFile;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
//加载控件
initView();
}
private void initView() {
iv_img = (ImageView) findViewById(R.id.iv_img);
bt_camera = (Button) findViewById(R.id.bt_camera);
bt_xiangce = (Button) findViewById(R.id.bt_xiangce);
//从SharedPreferences获取图片
getBitmapFromSharedPreferences();
//监听两个按钮,相册按钮和相机按钮
bt_camera.setOnClickListener(this);
bt_xiangce.setOnClickListener(this);
}
@Override
public void onClick(View v) {
switch (v.getId()) {
case R.id.bt_camera:
// 激活相机
Intent intent = new Intent("android.media.action.IMAGE_CAPTURE");
// 判断存储卡是否可以用,可用进行存储
if (hasSdcard()) {
tempFile = new File(Environment.getExternalStorageDirectory(), PHOTO_FILE_NAME);
// 从文件中创建uri
Uri uri = Uri.fromFile(tempFile);
intent.putExtra(MediaStore.EXTRA_OUTPUT, uri);
}
// 开启一个带有返回值的Activity,请求码为PHOTO_REQUEST_CAREMA
startActivityForResult(intent, PHOTO_REQUEST_CAREMA);
break;
case R.id.bt_xiangce:
// 激活系统图库,选择一张图片
Intent intent1 = new Intent(Intent.ACTION_PICK);
intent1.setType("image/*");
// 开启一个带有返回值的Activity,请求码为PHOTO_REQUEST_GALLERY
startActivityForResult(intent1, PHOTO_REQUEST_GALLERY);
break;
}
}
/*
* 判断sdcard是否被挂载
*/
private boolean hasSdcard() {
//判断SD卡手否是安装好的 media_mounted
if (Environment.getExternalStorageState().equals(Environment.MEDIA_MOUNTED)) {
return true;
} else {
return false;
}
}
/*
* 剪切图片
*/
private void crop(Uri uri) {
// 裁剪图片意图
Intent intent = new Intent("com.android.camera.action.CROP");
intent.setDataAndType(uri, "image/*");
intent.putExtra("crop", "true");
// 裁剪框的比例,1:1
intent.putExtra("aspectX", 1);
intent.putExtra("aspectY", 1);
// 裁剪后输出图片的尺寸大小
intent.putExtra("outputX", 250);
intent.putExtra("outputY", 250);
intent.putExtra("outputFormat", "JPEG");// 图片格式
intent.putExtra("noFaceDetection", true);// 取消人脸识别
intent.putExtra("return-data", true);
// 开启一个带有返回值的Activity,请求码为PHOTO_REQUEST_CUT
startActivityForResult(intent, PHOTO_REQUEST_CUT);
}
/**
*
* @param requestCode
* @param resultCode
* @param data
*/
@Override
protected void onActivityResult(int requestCode, int resultCode, Intent data) {
if (requestCode == PHOTO_REQUEST_GALLERY) {
// 从相册返回的数据
if (data != null) {
// 得到图片的全路径
Uri uri = data.getData();
crop(uri);
}
} else if (requestCode == PHOTO_REQUEST_CAREMA) {
// 从相机返回的数据
if (hasSdcard()) {
crop(Uri.fromFile(tempFile));
} else {
Toast.makeText(MainActivity.this, "未找到存储卡,无法存储照片!", Toast.LENGTH_SHORT).show();
}
} else if (requestCode == PHOTO_REQUEST_CUT) {
// 从剪切图片返回的数据
if (data != null) {
Bitmap bitmap = data.getParcelableExtra("data");
/**
* 获得图片
*/
iv_img.setImageBitmap(bitmap);
//保存到SharedPreferences
saveBitmapToSharedPreferences(bitmap);
}
try {
// 将临时文件删除
tempFile.delete();
} catch (Exception e) {
e.printStackTrace();
}
}
super.onActivityResult(requestCode, resultCode, data);
}
//保存图片到SharedPreferences
private void saveBitmapToSharedPreferences(Bitmap bitmap) {
// Bitmap bitmap=BitmapFactory.decodeResource(getResources(), R.drawable.ic_launcher);
//第一步:将Bitmap压缩至字节数组输出流ByteArrayOutputStream
ByteArrayOutputStream byteArrayOutputStream = new ByteArrayOutputStream();
bitmap.compress(Bitmap.CompressFormat.PNG, 80, byteArrayOutputStream);
//第二步:利用Base64将字节数组输出流中的数据转换成字符串String
byte[] byteArray = byteArrayOutputStream.toByteArray();
String imageString = new String(Base64.encodeToString(byteArray, Base64.DEFAULT));
//第三步:将String保持至SharedPreferences
SharedPreferences sharedPreferences = getSharedPreferences("testSP", Context.MODE_PRIVATE);
SharedPreferences.Editor editor = sharedPreferences.edit();
editor.putString("image", imageString);
editor.commit();
//上传头像
setImgByStr(imageString,"");
}
/**
* 上传头像
* @param imgStr
* @param imgName
*/
public void setImgByStr(String imgStr, String imgName) {
//这里是头像接口,通过Post请求,拼接接口地址和ID,上传数据。
String url = "http://这里写的是接口地址(具体接收格式要看后台怎么给)";
Map<String, String> params = new HashMap<String, String>();
params.put("id", "11111111");// 11111111
params.put("data", imgStr);
OkHttp.postAsync(url, params, new OkHttp.DataCallBack() {
@Override
public void requestFailure(Request request, IOException e) {
Log.i("上传失败", "失败" + request.toString() + e.toString());
}
@Override
public void requestSuccess(String result) throws Exception {
Toast.makeText(MainActivity.this,"上传成功",Toast.LENGTH_SHORT).show();
Log.i("上传成功", result);
}
});
}
//从SharedPreferences获取图片
private void getBitmapFromSharedPreferences(){
SharedPreferences sharedPreferences=getSharedPreferences("testSP", Context.MODE_PRIVATE);
//第一步:取出字符串形式的Bitmap
String imageString=sharedPreferences.getString("image", "");
//第二步:利用Base64将字符串转换为ByteArrayInputStream
byte[] byteArray= Base64.decode(imageString, Base64.DEFAULT);
if(byteArray.length==0){
iv_img.setImageResource(R.mipmap.ic_launcher);
}else{
ByteArrayInputStream byteArrayInputStream=new ByteArrayInputStream(byteArray);
//第三步:利用ByteArrayInputStream生成Bitmap
Bitmap bitmap= BitmapFactory.decodeStream(byteArrayInputStream);
iv_img.setImageBitmap(bitmap);
}
}
}
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
# android
# 头像截取
# 图片截取头像
# 仿qq头像截取
# Android实现头像上传功能
# Android retrofit上传文件实例(包含头像)
# Android头像上传功能的实现代码(获取头像加剪切)
# Android实现本地上传图片并设置为圆形头像
# Android实现上传头像
# 上传
# 返回值
# 转换成
# 第二步
# 存储卡
# 第三步
# 装好
# 的是
# 只欠东风
# 可以用
# 要看
# 转换为
# 要花
# 具体内容
# 转成
# 大家多多
# 未找到
# 临时文件
# 加载
# onClick
相关栏目:
【
网站优化151355 】
【
网络推广146373 】
【
网络技术251813 】
【
AI营销90571 】
相关推荐:
高防网站服务器:DDoS防御与BGP线路的AI智能防护方案
Laravel中间件起什么作用_Laravel Middleware请求生命周期与自定义详解
Python文件流缓冲机制_IO性能解析【教程】
Laravel如何实现多语言支持_Laravel本地化与国际化(i18n)配置教程
高端企业智能建站程序:SEO优化与响应式模板定制开发
Laravel数据库迁移怎么用_Laravel Migration管理数据库结构的正确姿势
如何利用DOS批处理实现定时关机操作详解
laravel服务容器和依赖注入怎么理解_laravel服务容器与依赖注入解析
Swift中switch语句区间和元组模式匹配
在线教育网站制作平台,山西立德教育官网?
Laravel如何使用Blade组件和插槽?(Component代码示例)
Laravel怎么配置不同环境的数据库_Laravel本地测试与生产环境动态切换【方法】
如何在阿里云通过域名搭建网站?
香港服务器租用每月最低只需15元?
Laravel storage目录权限问题_Laravel文件写入权限设置
Laravel怎么实现微信登录_Laravel Socialite第三方登录集成
免费的流程图制作网站有哪些,2025年教师初级职称申报网上流程?
如何在IIS服务器上快速部署高效网站?
EditPlus中的正则表达式 实战(4)
软银砸40亿美元收购DigitalBridge 强化AI资料中心布局
Linux网络带宽限制_tc配置实践解析【教程】
jimdo怎样用html5做选项卡_jimdo选项卡html5实现与切换效果【指南】
ChatGPT怎么生成Excel公式_ChatGPT公式生成方法【指南】
如何快速配置高效服务器建站软件?
文字头像制作网站推荐软件,醒图能自动配文字吗?
JavaScript如何实现错误处理_try...catch如何捕获异常?
Bootstrap整体框架之CSS12栅格系统
如何实现建站之星域名转发设置?
Laravel如何实现数据导出到PDF_Laravel使用snappy生成网页快照PDF【方案】
西安市网站制作公司,哪个相亲网站比较好?西安比较好的相亲网站?
Laravel怎么使用Collection集合方法_Laravel数组操作高级函数pluck与map【手册】
企业在线网站设计制作流程,想建设一个属于自己的企业网站,该如何去做?
中国移动官方网站首页入口 中国移动官网网页登录
Laravel怎么实现搜索功能_Laravel使用Eloquent实现模糊查询与多条件搜索【实例】
如何基于云服务器快速搭建网站及云盘系统?
Laravel事件监听器怎么写_Laravel Event和Listener使用教程
如何在服务器上配置二级域名建站?
敲碗10年!Mac系列传将迎来「触控与联网」双革新
如何撰写建站申请书?关键要点有哪些?
如何在局域网内绑定自建网站域名?
如何快速选择适合个人网站的云服务器配置?
南京网站制作费用,南京远驱官方网站?
奇安信“盘古石”团队突破 iOS 26.1 提权
Laravel怎么定时执行任务_Laravel任务调度器Schedule配置与Cron设置【教程】
北京网站制作公司哪家好一点,北京租房网站有哪些?
如何在七牛云存储上搭建网站并设置自定义域名?
Laravel怎么判断请求类型_Laravel Request isMethod用法
Laravel如何创建自定义Artisan命令?(代码示例)
怎么制作一个起泡网,水泡粪全漏粪育肥舍冬季氨气超过25ppm,可以有哪些措施降低舍内氨气水平?
JS中对数组元素进行增删改移的方法总结

