首先需要有网络权限,然后我们这里匹配的网络请求是之前封装好的Okhttp,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;@Overrideprotected 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);}@Overridepublic 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);// 从文件中创建uriUri uri = Uri.fromFile(tempFile);intent.putExtra(MediaStore.EXTRA_OUTPUT, uri);}// 开启一个带有返回值的Activity,请求码为PHOTO_REQUEST_CAREMAstartActivityForResult(intent, PHOTO_REQUEST_CAREMA);break;case R.id.bt_xiangce:// 激活系统图库,选择一张图片Intent intent1 = new Intent(Intent.ACTION_PICK);intent1.setType("image/*");// 开启一个带有返回值的Activity,请求码为PHOTO_REQUEST_GALLERYstartActivityForResult(intent1, PHOTO_REQUEST_GALLERY);break;}}/** 判断sdcard是否被挂载*/private boolean hasSdcard() {//判断SD卡手否是安装好的   media_mountedif (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:1intent.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_CUTstartActivityForResult(intent, PHOTO_REQUEST_CUT);}/**** @param requestCode* @param resultCode* @param data*/@Overrideprotected void onActivityResult(int requestCode, int resultCode, Intent data) {//防止低版本没有返回确认数据,导致奔溃if(data==null){return;}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");//防止低版本没有办法获取数据,导致奔溃if(bitmap ==null){return;}/*** 获得图片*/iv_img.setImageBitmap(bitmap);//保存到SharedPreferencessaveBitmapToSharedPreferences(bitmap);}try {// 将临时文件删除tempFile.delete();} catch (Exception e) {e.printStackTrace();}}super.onActivityResult(requestCode, resultCode, data);}//保存图片到SharedPreferencesprivate void saveBitmapToSharedPreferences(Bitmap bitmap) {// Bitmap bitmap=BitmapFactory.decodeResource(getResources(), R.drawable.ic_launcher);//第一步:将Bitmap压缩至字节数组输出流ByteArrayOutputStreamByteArrayOutputStream byteArrayOutputStream = new ByteArrayOutputStream();bitmap.compress(Bitmap.CompressFormat.PNG, 80, byteArrayOutputStream);//第二步:利用Base64将字节数组输出流中的数据转换成字符串Stringbyte[] byteArray = byteArrayOutputStream.toByteArray();String imageString = new String(Base64.encodeToString(byteArray, Base64.DEFAULT));//第三步:将String保持至SharedPreferencesSharedPreferences 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");// 11111111params.put("data", imgStr);OkHttp.postAsync(url, params, new OkHttp.DataCallBack() {@Overridepublic void requestFailure(Request request, IOException e) {Log.i("上传失败", "失败" + request.toString() + e.toString());}@Overridepublic 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);//第一步:取出字符串形式的BitmapString imageString=sharedPreferences.getString("image", "");//第二步:利用Base64将字符串转换为ByteArrayInputStreambyte[] byteArray= Base64.decode(imageString, Base64.DEFAULT);if(byteArray.length==0){iv_img.setImageResource(R.mipmap.ic_launcher);}else{ByteArrayInputStream byteArrayInputStream=new ByteArrayInputStream(byteArray);//第三步:利用ByteArrayInputStream生成BitmapBitmap bitmap= BitmapFactory.decodeStream(byteArrayInputStream);iv_img.setImageBitmap(bitmap);}}}

Android个人中心的头像上传,图片编码及截取相关推荐

  1. Android实现注册登录头像上传等功能常规开发(Android端,服务器端开发实例)

    Android实现注册登录头像上传等功能常规开发(Android端,服务器端开发实例) 标签: 注册登录Android开发servlet 2017-04-18 20:34  454人阅读  评论(1) ...

  2. Android头像上传--图片转base64,后台接收到的总是null问题

    图片转base64,后台接到为null问题 项目中,在使用头像上传的时候,将图片转为base64,后台总是收到的base64字符串是null.原以为是图片未压缩,导致图片过大,超过了Tomcat配置的 ...

  3. Android开发之用户头像上传

    一,概述 本篇博客总结一下自己在开发过程中应用到的一些知识,在本篇博客中带领大家完成用户头像选择或者拍照上传,并对图片进行大小的压缩,和形状的控制,可以将用户选择到的图片裁剪成圆形上传. ok,我们开 ...

  4. vue项目中实现头像上传的功能型组件

    @vue项目中实现头像上传的功能型组件 功能需求 实现个人中心的头像上传功能: 1.用户未上传过头像,展示设定好的默认头像(区分男女) 2.支持格式png.jpg.jpeg 3.图片大小:小于等于2M ...

  5. 小程序图片裁剪插件image-cropper实现个人头像上传裁剪功能

    小程序图片裁剪插件image-cropper实现个人头像上传裁剪功能 参考文档:小程序图片裁剪插件 image-cropper 整体效果流程图 一.第一步引入image-cropper,放在dist文 ...

  6. 调用android的拍照或本地相册选取再实现相片上传服务器,Android调用系统相机、本地相册上传图片(头像上传(裁剪)、多张图片上传)...

    开发中基本上都会有头像上传的功能,有的app还需要多张图片同时上传,下面简单将头像上传以及多张图片上传功能整理一下.图片选择仿照微信选择图片的界面.[参考] 多图片选择器 !!!推荐一个动态权限请求的 ...

  7. Android 头像上传的实现

    当我们点击头像想要进行头像上传时,我们可以给上传头像设置一个弹框效果,用来给用户提供相册选择和拍照两种选择. 这时我们可以使用PopupWindow实现 1. 定义图片存储位置 public void ...

  8. Android 头像上传

    内容概要 实例演示和原理讲解 从摄像头中获取图像 从图库中获取图像 在Android上对图像进行裁剪 图像上传并在服务器保存图像 实例演示和原理讲解 头像上传流程 从摄像头中获取图像 本课时的主要内容 ...

  9. Android头像上传实战模拟

    Android头像上传实战模拟 在开发中头像的上传应该是必不可少的,话不多说上效果图! 点击头像弹出PopupWindow分别三个按钮. <?xml version="1.0" ...

最新文章

  1. 万万没想到,坤坤洗白的第一步是周琦…
  2. java线程和linux线程,Java线程与Linux内核线程的映射关系
  3. 2020年这10大机器学习研究最具影响力:为什么?接下来如何发展?
  4. HashMap深度解析:一文让你彻底了解HashMap
  5. 【北京】微软技术直通车(第二期) 之 SQL Server 2017饕餮
  6. ArcEngine调用FeatureToLine工具传参问题
  7. 关于ASPNET_Membership用户被锁的解决
  8. NYOJ题目325-zb的生日
  9. 修改element $prompt的文字样式
  10. Pygame小游戏:玩扫雷就在瞎点的,不止你一个人。
  11. 张馨予一幅画拍出几十万,然而范冰冰却一直在向粉丝要画!
  12. Siemens配置许可证服务器,OPC 服务器 配置
  13. unity软粒子softparticle仿真实现
  14. 广州O2O分销系统定制开发
  15. Swagger2学习笔记
  16. MIGO 抬头屏幕自定义字段增强示例
  17. 浅谈ImageList
  18. 单片机+DHT11的温湿度采集监测系统,LCD1602显示,带报警功能,C代码、原理图和Proteus仿真
  19. 仿美团界面之day01
  20. 阿里云服务器的领取及静态页面的上传

热门文章

  1. 干货!VR全景的15种应用渠道和方式。
  2. 如何在word中插入页眉。
  3. Django模型--数据库(MySQL)-初识
  4. Spring配置Quartz实现定时任务
  5. docker:设置仓库镜像地址
  6. java to csharp_Java To CSharp源代码转换
  7. 第一篇博客(自我介绍向)
  8. 已知组成元素可以唯一的确定物体形态吗?
  9. 我创办了一个知识星球
  10. 小红书引流效果不好?小红书账号自检16招分享给你?