先从本地把图片上传到服务器,然后根据URL把头像处理成圆形头像。
因为上传图片用到bmob的平台,所以要到bmob(http://www.bmob.cn)申请密钥。
效果图:
核心代码:
public class MainActivity extends Activity { private ImageView iv; private String appKey=""; //填写你的Application ID private String path=Environment.getExternalStorageDirectory()+"/11.jpeg"; //要上传的图片的路径 public final int SIZE=2*1024; protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); Bmob.initialize(this, appKey); //初始化bmob SDK setContentView(R.layout.activity_main); initView(); } private void initView() { // TODO Auto-generated method stub iv=(ImageView)findViewById(R.id.iv); } /** * 上传文件到bmob后台 * */ public void upload(View v){ final BmobFile file=new BmobFile(new File(path)); file.uploadblock(this, new UploadFileListener() { @Override public void onSuccess() { // TODO Auto-generated method stub Person p=new Person(); p.setUrl(file.getFileUrl(MainActivity.this)); p.save(MainActivity.this); MyTask task=new MyTask(); task.execute(file.getFileUrl(MainActivity.this)); toast("上传成功 "); } @Override public void onFailure(int arg0, String arg1) { // TODO Auto-generated method stub toast("上传失败 "+arg1); Log.i("---------", "------error "+arg1); } }); } /** * 根据URL获取Bitmap * */ public Bitmap getHttpBitmap(String url){ Bitmap bitmap=null; URL myUrl; try { myUrl=new URL(url); HttpURLConnection conn=(HttpURLConnection)myUrl.openConnection(); conn.setConnectTimeout(5000); conn.connect(); InputStream is=conn.getInputStream(); bitmap=BitmapFactory.decodeStream(is); //把bitmap转成圆形 bitmap=toRoundBitmap(bitmap); is.close(); } catch (MalformedURLException e) { // TODO Auto-generated catch block e.printStackTrace(); } catch (IOException e) { // TODO Auto-generated catch block e.printStackTrace(); } //返回圆形bitmap return bitmap; } /** * 把bitmap转成圆形 * */ public Bitmap toRoundBitmap(Bitmap bitmap){ int width=bitmap.getWidth(); int height=bitmap.getHeight(); int r=0; //取最短边做边长 if(width<height){ r=width; }else{ r=height; } //构建一个bitmap Bitmap backgroundBm=Bitmap.createBitmap(width,height,Config.ARGB_8888); //new一个Canvas,在backgroundBmp上画图 Canvas canvas=new Canvas(backgroundBm); Paint p=new Paint(); //设置边缘光滑,去掉锯齿 p.setAntiAlias(true); RectF rect=new RectF(0, 0, r, r); //通过制定的rect画一个圆角矩形,当圆角X轴方向的半径等于Y轴方向的半径时, //且都等于r/2时,画出来的圆角矩形就是圆形 canvas.drawRoundRect(rect, r/2, r/2, p); //设置当两个图形相交时的模式,SRC_IN为取SRC图形相交的部分,多余的将被去掉 p.setXfermode(new PorterDuffXfermode(Mode.SRC_IN)); //canvas将bitmap画在backgroundBmp上 canvas.drawBitmap(bitmap, null, rect, p); return backgroundBm; } class MyTask extends AsyncTask<String, String, Bitmap>{ @Override protected Bitmap doInBackground(String... arg0) { // TODO Auto-generated method stub String url=arg0[0]; Bitmap bm=getHttpBitmap(url); return bm; } @Override protected void onPostExecute(Bitmap result) { // TODO Auto-generated method stub iv.setImageBitmap(result); } } public void toast(String msg){ Toast.makeText(this, msg, Toast.LENGTH_SHORT).show(); } }
以上所述就是本文的全部内容了,希望大家能喜欢。
本文向大家介绍Android实现圆形图片或者圆角图片,包括了Android实现圆形图片或者圆角图片的使用技巧和注意事项,需要的朋友参考一下 Android圆形图片或者圆角图片的快速实现,具体内容如下 话不多说直接上code xml文件布局 初始化控件之后用工具类加载 //第一个参数上下文,第二个控件名称,第三个图片url地址,第四个参数圆角大小 ViewUtils.loadImageRadius(
本文向大家介绍PHP实现本地图片转base64格式并上传,包括了PHP实现本地图片转base64格式并上传的使用技巧和注意事项,需要的朋友参考一下 我们在开发系统时,处理图片上传是不可避免的,例如使用thinkphp的肯定很熟悉import("@.ORG.UploadFile");的上传方式,今天我们来讲一个使用html5 base64上传图片的方法。 主要是用到html5 FileReader的
本文向大家介绍Android webview打开本地图片上传实现代码,包括了Android webview打开本地图片上传实现代码的使用技巧和注意事项,需要的朋友参考一下 Webview打开本地图片选择器十分之麻烦,其在安卓系统3x 4x 5x上的行为都不同,处理也不同,所以之前差点崩溃。经过测试和完善,最终其在各个版本上都能完美工作。 直接上代码 以上就是本文的全部内容,希望对大家的学习有所帮助
本文向大家介绍Android实现圆形图片的两种方式,包括了Android实现圆形图片的两种方式的使用技巧和注意事项,需要的朋友参考一下 在项目中,我们经常会用到圆形图片,但是android本身又没有提供,那我只能我们自己来完成。 第一种方式,自定义CircleImageView: 使用的时候,切记不要引用成V4报下的CircleImageView!! 另一篇文章分享的第二种方式:把图片修剪为圆形,
本文向大家介绍Android设置拍照或者上传本地图片的示例,包括了Android设置拍照或者上传本地图片的示例的使用技巧和注意事项,需要的朋友参考一下 前几天,我们客户端这边收到了市场部的一个需求,需要在我们订单成交后,我们的客户端有一个上传交易凭证的功能,那么如何在Android实现上传图片的这个功能呢?在我进行编码之前,我先问自己几个问题。 第一, 图片是直接选择图库里的,还是需要拍照和选择图
本文向大家介绍Android一行代码实现圆形头像,包括了Android一行代码实现圆形头像的使用技巧和注意事项,需要的朋友参考一下 效果图 在开发APP中,经常要实现圆形头像,那么该如何实现呢? 要裁剪吗,要重写draw函数吗?不用,只用一行代码就可以实现 Glide实现圆形图像 其中load后为载入的图像,error后为出错时载入的图像,transform是对其修改,我们也是通过这个GlideC