Android个人中心的头像上传,图片编码及截取实例

首先需要有网络权限,然后我们这里匹配的网络请求是之前封装好的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);
    }

  }

}

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持我们。

(0)

相关推荐

  • Android中截取当前屏幕图片的实例代码

    复制代码 代码如下: /**     * 获取和保存当前屏幕的截图     */    private void GetandSaveCurrentImage()      {          //1.构建Bitmap          WindowManager windowManager = getWindowManager();          Display display = windowManager.getDefaultDisplay();          int w = d

  • Android 仿QQ头像自定义截取功能

    看了Android版QQ的自定义头像功能,决定自己实现,随便熟悉下android绘制和图片处理这一块的知识. 先看看效果: 思路分析: 这个效果可以用两个View来完成,上层View是一个遮盖物,绘制半透明的颜色,中间挖了一个圆:下层的View用来显示图片,具备移动和缩放的功能,并且能截取某区域内的图片. 涉及到的知识点: 1.Matrix,图片的移动和缩放 2.Paint的setXfermode方法 3.图片放大移动后,截取一部分 编码实现: 自定义三个View: 1.下层View:ClipP

  • Android实现bitmap指定区域滑动截取功能

    突然不知道什么心态,说要做这个,网上找了半天没找到合适的,就自己做了一个. 先上效果图: 透明区域为将要截取的区域,其他阴影部位为舍弃区域 图片资源我写死储存在了raw中,有需要可以自己写获取bitmap. 界面layout: <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns:app="http://schemas.android.com/apk/res-au

  • android 手机截取长屏实例代码

    最近项目遇到一个需求:把当前页面保存到手机相册.想了想 我还不会呢,就百度了下大神的足迹,踏着大神的足迹,一路向前.废话不说,记录下,后期学习. public class ScreenUtils { /** * 截取scrollview的屏幕 * @param scrollView * @return */ public static Bitmap getBitmapByView(ScrollView scrollView) { int h = 0; Bitmap bitmap = null;

  • Android实现拍照截取和相册图片截取

    关于拍照截取和相册截取,看了网上很多资料,自己整理了一份比较详细的,供有需要的人参考 1  拍照 原理就是通过intent调用系统的相机,拍完照在回调进行操作,成功获取到拍完照的图片根据uri调用系统的裁剪页面,裁剪完也是在回调中进行处理,显示在页面的imageview中. 2  相册选取图片 原理也是通过intent打开系统的图片,用户选择完成以后在回调中根据图片的uri调用系统的裁剪页面,同上. 首先,定义几个常量 public static final int TAKE_PHOTO = 1

  • Android 截取手机屏幕两种实现方法

    Android 截取手机屏幕两种实现方法 最近在开发的过程中,遇到了一个需要截取屏幕保存为图片的需求,具体为截取webview的视图保存图片. 方法1:首先想到的思路是利用SDK提供的View.getDrawingCache()方法: public void printScreen(View view) { String imgPath = "/sdcard/test.png"; view.setDrawingCacheEnabled(true); view.buildDrawingC

  • Android开发获取短信的内容并截取短信

    1.首先我们要写一个广播接收器,当我们的手机收到短信时,系统会自动发送一个广播,我们只需要接收到这条广播就可以了 2.在广播里面,我们重写的onReceive()方法,通过里面的Intent写到的Bundle就可以拿到短信的内容, 3.清单文件里面我们必须要添加权限,否则无法接收到. 4.为了防止我们的广播接收不到,我们自己写的广播接收器的权限必须要大,以防万一,我设置了1000. 下面上代码,里面的注释也比较详细.. <?xml version="." encoding=&qu

  • 解析Android截取手机屏幕两种实现方案

    最近在开发的过程中,遇到了一个需要截取屏幕保存为图片的需求,具体为截取webview的视图保存图片. 方法1:首先想到的思路是利用SDK提供的View.getDrawingCache()方法: public void printScreen(View view) { String imgPath = "/sdcard/test.png"; view.setDrawingCacheEnabled(true); view.buildDrawingCache(); Bitmap bitmap

  • Android截取视频帧并转化为Bitmap示例

    MainActivity如下: 复制代码 代码如下: package cn.testmediametadataretriever; import java.io.File; import java.io.FileOutputStream; import android.media.MediaMetadataRetriever; import android.os.Bundle; import android.os.Environment; import android.app.Activity;

  • Android个人中心的头像上传,图片编码及截取实例

    首先需要有网络权限,然后我们这里匹配的网络请求是之前封装好的Okhttp. 非常的简单方便,直接复制进去,依赖一下包,然后调用方法即可. 这里是把图片转换成Base64.decode(imageString, Base64.DEFAULT); 转成Base64编码上传.具体内容也不少,需要完全整明白,还是要花点时间慢慢看的. 先看看简单的效果图: 那么万事具备,只欠东风了.直接上代码: public class MainActivity extends AppCompatActivity imp

  • input file上传 图片预览功能实例代码

    input file上传图片预览其实很简单,只是没做过的感觉很神奇,今天我就扒下她神秘的面纱,其实原理真的很简单,下面通过一段代码大家都明白了. 具体代码如下所示: <!DOCTYPE html> <html> <head> <meta charset="utf-8" /> <title></title> <script src="jquery.js"></script>

  • jQuery点击头像上传并预览图片

    先给大家展示下效果图: HTML代码 <div class="img_show img_show1"> <img src="img2/img06.jpg" width="103" height="103" alt=""> <input type="file" class="upfile" accept="*/*">

  • Android将图片上传到php服务器的实例代码

    layout中很普通,就是两个button和一个ImageView <?xml version="1.0" encoding="utf-8"?> <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="match_parent" android:layout_height=&q

  • Element 头像上传的实战

    本篇文章用到 element官网 和 七牛云官网 element-ui 官网:https://element.eleme.io/#/zh-CN 七牛云官网:https://www.qiniu.com/ 1.七牛云注册 登录 之后 然后实名认证 2.进入对象存储后 进入空间管理 3.新建空间 在这里就能拿到 cdn测试域名 python SDK 在开发者中心可以查看 使用七牛云 就需要安装他 pip install qiniu 我们使用封装的思想 进行封装使用 文件名:comm.py # 七牛云

  • Vue vant-ui使用van-uploader实现头像上传功能

    效果图: 项目中是使用有赞vant-ui框架实现的头像上传替换功能 代码布局结构: <van-row class="sendInfo"> <van-col span="24" class="flex colorf topInfo p20"> <!--左边头像部分--> <van-uploader :after-read="afterCard" :before-read="be

  • php实现头像上传预览功能

    本文实例为大家分享了php实现头像上传预览功能的具体代码,供大家参考,具体内容如下 主页面1.php <html> <head> <meta http-equiv="Content-Type" content="text/html; charset=utf-8" /> <title>上传头像</title> <style type="text/css"> *{ font-fa

  • 针对多用户实现头像上传功能PHP代码 适用于登陆页面制作

    一个网站,其实说白了就是某几个特定功能的组合,而更换用户头像就在这些功能之中.今天就来做个测试,针对不同的用户,实现头像上传功能. -------------------------------------------------------------------------------- 成品图 思路  •针对不同的用户上传头像,我们要为每一个已登录的用户创建一个文件夹,文件夹的名称以当前用户的用户名为准. •用户上传成功后,跳转到用户登录成功后的页面,并刷新用户头像. 登陆页面 表单制作

  • Android ksoap调用webservice批量上传多张图片详解

    Android ksoap调用webservice批量上传多张图片详解 这几天一直在开发app,哎呀,什么都是第一接触,想想自己自学Java,然后自学Android,一直没有放弃,曾想放弃的,但是想到爸妈供我上学,不能在宿舍里面玩游戏,加入学校实验室,一天没课就来着里学习,当然这里也有志同道合的人,一起努力一起进步!虽然大学这几年都在努力的学习技术,也没有参加什么活动的,更别说找个女伴了!还是老老实实的敲代码,成功给我带来巨大的潜能,新技术总是吸引着我.自己做项目,哎呀!好像说偏题了,言归正传吧

  • 全屏js头像上传插件源码高清版

    本文实例为大家分享了全屏js头像上传插件源码,供大家参考,具体内容如下 index.html <!DOCTYPE html> <html> <head> <meta name="viewport" content="width=device-width" /> <title>ccp</title> <link href="Content/ccp.css" rel=&qu

随机推荐