首先需要有网络权限,然后我们这里匹配的网络请求是之前封装好的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. IPython、python shell(command line)、pycharm,python,python IDLE的区别是什么?
  2. android 自动登录机制,Android登录记住密码以及自动登录的实现
  3. java如何追加写入txt文件
  4. sharepoint中一些gridview的使用方法
  5. iOS layer 动画
  6. 记录是一段旅程:记录Scribus可获得3课
  7. kafka tool报错:Error fetching datea.Offset out of range
  8. python click
  9. python入门教程 非常详细-Python编程入门教程:从入门到高级,非常详细
  10. 【UE4从零开始 082】全局光照
  11. 黑马python培训视频网盘下载
  12. Android 常用颜色值及半透明效果配置
  13. PDF文件中的文字怎么修改?来试试这种修改方法
  14. 恒指赵鑫:8.9恒指德指实盘指导记录总结与晚盘前瞻
  15. 浏览器前进后退静默刷新页面
  16. 有10名学生,每个学生的数据要求包括学号、姓名。3门课的成成绩,从键盘输入10个学生数据,要求打印出3门课总平均成绩以及最高分学生的数据(包括学号、姓名、三门课成绩、平均分数)。C++。
  17. 多个Repeater嵌套
  18. NFC天线匹配调试简介1
  19. Power Platform基本介绍
  20. Wintel联盟走向末日,AMD或成催化剂

热门文章

  1. 苹果“降频门”之《军师联盟》
  2. 字符串处理函数(strcpy strcat strcmp strlen)
  3. vue前端项目老缺少XXX文件,或者XXX文件丢失错误,最好的解决办法
  4. 62、63 不同路径
  5. python抓取斗鱼的主播及热度
  6. 什么是Vite:现代和超快速项目工具指南---下一代前端工具
  7. 多方收集的Winodws Xp相关技术文章
  8. 扬尘噪声智能监测云平台
  9. CAD墙体加亮有什么用?CAD加亮墙体教程
  10. win10系统常用的几种截图方式