首先需要有网络权限,然后我们这里匹配的网络请求是之前封装好的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
相关文章:
潮流网站制作头像软件下载,适合母子的网名有哪些?
电脑免费海报制作网站推荐,招聘海报哪个网站多?
相亲简历制作网站推荐大全,新相亲大会主持人小萍萍资料?
阿里云网站制作公司,阿里云快速搭建网站好用吗?
网站微信制作软件,如何制作微信链接?
义乌企业网站制作公司,请问义乌比较好的批发小商品的网站是什么?
建站之星如何防范黑客攻击与数据泄露?
建站之星安装失败:服务器环境不兼容?
C++如何编写函数模板?(泛型编程入门)
如何通过NAT技术实现内网高效建站?
深圳网站制作设计招聘,关于服装设计的流行趋势,哪里的资料比较全面?
如何选择高效响应式自助建站源码系统?
盐城做公司网站,江苏电子版退休证办理流程?
如何配置FTP站点权限与安全设置?
如何高效搭建专业期货交易平台网站?
南宁网站建设制作定制,南宁网站建设可以定制吗?
网站制作服务平台,有什么网站可以发布本地服务信息?
如何快速搭建高效WAP手机网站吸引移动用户?
微网站制作教程,不会写代码,不会编程,怎么样建自己的网站?
移动端手机网站制作软件,掌上时代,移动端网站的谷歌SEO该如何做?
英语简历制作免费网站推荐,如何将简历翻译成英文?
建站之星3.0如何解决常见操作问题?
建站之星备案是否影响网站上线时间?
威客平台建站流程解析:高效搭建教程与设计优化方案
智能起名网站制作软件有哪些,制作logo的软件?
免费的流程图制作网站有哪些,2025年教师初级职称申报网上流程?
常州企业建站如何选择最佳模板?
红河网站制作公司,红河事业单位身份证如何上传?
如何快速生成ASP一键建站模板并优化安全性?
香港服务器WordPress建站指南:SEO优化与高效部署策略
Android自定义listview布局实现上拉加载下拉刷新功能
建站之星客服服务时间及联系方式如何?
如何设计高效校园网站?
建站之星logo尺寸如何设置最合适?
如何制作公司的网站链接,公司想做一个网站,一般需要花多少钱?
家族网站制作贴纸教程视频,用豆子做粘帖画怎么制作?
详解jQuery中基本的动画方法
如何在自有机房高效搭建专业网站?
如何在阿里云域名上完成建站全流程?
深圳企业网站制作设计,在深圳如何网上全流程注册公司?
定制建站流程解析:需求评估与SEO优化功能开发指南
湖州网站制作公司有哪些,浙江中蓝新能源公司官网?
企业微网站怎么做,公司网站和公众号有什么区别?
常州自助建站费用包含哪些项目?
C#怎么使用委托和事件 C# delegate与event编程方法
建站之星×万网:智能建站系统+自助建站平台一键生成
建站一年半SEO优化实战指南:核心词挖掘与长尾流量提升策略
如何选择适配移动端的WAP自助建站平台?
网站广告牌制作方法,街上的广告牌,横幅,用PS还是其他软件做的?
网站制作软件有哪些,制图软件有哪些?
*请认真填写需求信息,我们会在24小时内与您取得联系。