Android实现相册中图片上传或下载

本文实例为大家分享了Android实现相册中图片上传或下载的具体代码,供大家参考,具体内容如下

目标效果:

打开相册选择一张图片,会显示到上方的ImageView中并存储到Bmob中,存储后进入Bmob后台,复制刚才添加的数据的objectId,粘贴到代码指定出,然后运行,点击下载会在下方的ImageView显示刚才上传的图片,这里的下载是指定objectId,可以进行动态获取objectId进行下载。

1.activity_main.xml页面设置布局。

activity_main.xml页面:

<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
  xmlns:tools="http://schemas.android.com/tools"
  android:layout_width="match_parent"
  android:layout_height="match_parent"
  tools:context=".MainActivity" >

 <ImageView
   android:id="@+id/ivHead"
   android:layout_marginTop="20dp"
   android:layout_centerHorizontal="true"
   android:layout_width="150dp"
   android:layout_height="150dp"/>

 <Button
   android:id="@+id/btnSelectImage"
   android:layout_width="match_parent"
   android:layout_height="wrap_content"
   android:layout_alignParentLeft="true"
   android:layout_below="@+id/ivHead"
   android:layout_marginTop="16dp"
   android:text="打开相册" />

 <Button
   android:id="@+id/btnDownloadImage"
   android:layout_width="match_parent"
   android:layout_height="wrap_content"
   android:layout_alignParentLeft="true"
   android:layout_below="@+id/btnSelectImage"
   android:text="下载图片" />

 <ImageView
   android:id="@+id/ivDownload"
   android:layout_width="150dp"
   android:layout_height="150dp"
   android:layout_marginTop="20dp"
   android:layout_centerHorizontal="true"
   android:layout_below="@+id/btnDownloadImage" />

</RelativeLayout>

2.MainActivity.java页面定义上传与下载方法。

MainActivity.java页面:

package com.example.text;

import java.io.File;

import cn.bmob.v3.Bmob;
import cn.bmob.v3.BmobQuery;
import cn.bmob.v3.datatype.BmobFile;
import cn.bmob.v3.listener.DownloadFileListener;
import cn.bmob.v3.listener.GetListener;
import cn.bmob.v3.listener.UploadBatchListener;
import cn.bmob.v3.listener.UploadFileListener;

import com.android.volley.toolbox.ImageLoader;
import com.example.text.MainActivity;

import entity.Person;

import android.net.Uri;
import android.os.Bundle;
import android.os.Environment;
import android.provider.MediaStore;
import android.app.Activity;
import android.content.Intent;
import android.database.Cursor;
import android.graphics.Bitmap;
import android.graphics.BitmapFactory;
import android.graphics.drawable.BitmapDrawable;
import android.graphics.drawable.Drawable;
import android.view.View;
import android.view.View.OnClickListener;
import android.widget.Button;
import android.widget.ImageView;
import android.widget.Toast;

public class MainActivity extends Activity implements OnClickListener {

 private ImageView ivHead, ivDownload;
 private Button btnSelectImage, btnDownloadImage;

 private static final int IMAGE_CODE = 0;// 打开相册
 private static final int RESIZE_CODE = 2;// 调整大小

 private static final String IMAGE_NAME = " ";// 图片字符串

 @Override
 protected void onCreate(Bundle savedInstanceState) {
 super.onCreate(savedInstanceState);
 setContentView(R.layout.activity_main);

 Bmob.initialize(this, "8ef8a4752f48682eadb32d3c8c8e398f");// 初始化Bmob

 // 初始化控件
 init();

 // 绑定点击事件
 bindClick();
 }

 // 初始化控件
 private void init() {
 ivHead = (ImageView) findViewById(R.id.ivHead);
 ivDownload = (ImageView) findViewById(R.id.ivDownload);
 btnSelectImage = (Button) findViewById(R.id.btnSelectImage);
 btnDownloadImage = (Button) findViewById(R.id.btnDownloadImage);
 }

 // 绑定点击事件
 private void bindClick() {
 btnSelectImage.setOnClickListener(this);
 btnDownloadImage.setOnClickListener(this);
 }

 @Override
 public void onClick(View view) {
 switch (view.getId()) {
 case R.id.btnSelectImage:
  Intent galleryIntent = new Intent(Intent.ACTION_GET_CONTENT);
  galleryIntent.addCategory(Intent.CATEGORY_OPENABLE);
  galleryIntent.setType("image/*");//图片
  startActivityForResult(galleryIntent, IMAGE_CODE);  //跳转,传递打开相册请求码
  break;
 case R.id.btnDownloadImage:
  BmobQuery<Person> query=new BmobQuery<Person>();
  query.getObject(this,"ef292ff6ef",new GetListener<Person>() { //第二个参数为想要下载的BmobFile数据的objectId

  @Override
  public void onSuccess(Person person) {
   Toast.makeText(MainActivity.this,"获取成功",Toast.LENGTH_SHORT).show();

   //下载图片
   downloadImage(person);
  }

  @Override
  public void onFailure(int arg0, String arg1) {
   Toast.makeText(MainActivity.this,"获取失败",Toast.LENGTH_SHORT).show();
  }
  });
  break;
 default:
  break;
 }

 }

 @Override
 protected void onActivityResult(int requestCode, int resultCode, Intent data) {
 if (resultCode != RESULT_OK) {
  return;
 } else {
  switch (requestCode) {
  case IMAGE_CODE:
  Uri uri = data.getData();
  resizeImage(uri);
  // 将获取到的uri转换为String型
  String[] images = { MediaStore.Images.Media.DATA };// 将图片URI转换成存储路径
  Cursor cursor = this
   .managedQuery(uri, images, null, null, null);
  int index = cursor
   .getColumnIndexOrThrow(MediaStore.Images.Media.DATA);
  cursor.moveToFirst();
  String img_url = cursor.getString(index);
  upload(img_url);
  break;

  case RESIZE_CODE:
  if (data != null) {
   showResizeImage(data);
  }
  break;
  }
 }
 super.onActivityResult(requestCode, resultCode, data);
 }

 // 判断SD卡是否存在
 private boolean isSdcardExisting() {
 final String state = Environment.getExternalStorageState();
 if (state.equals(Environment.MEDIA_MOUNTED)) {
  return true;
 } else {
  return false;
 }
 }

 // 重塑图片大小
 public void resizeImage(Uri uri) {
 Intent intent = new Intent("com.android.camera.action.CROP");
 intent.setDataAndType(uri, "image/*");
 intent.putExtra("crop", "true");// 可以裁剪
 intent.putExtra("aspectX", 1);
 intent.putExtra("aspectY", 1);
 intent.putExtra("outputX", 150);
 intent.putExtra("outputY", 150);
 intent.putExtra("return-data", true);
 startActivityForResult(intent, RESIZE_CODE);// 跳转,传递调整大小请求码
 }

 // 获取路径
 private Uri getImageUri() {
 return Uri.fromFile(new File(Environment.getExternalStorageDirectory(),
  IMAGE_NAME));
 }

 // 显示图片
 private void showResizeImage(Intent data) {
 Bundle extras = data.getExtras();
 if (extras != null) {
  Bitmap photo = extras.getParcelable("data");
  Drawable drawable = new BitmapDrawable(photo);
  ivHead.setImageDrawable(drawable);
 }
 }

 // 图片上传
 private void upload(String imgpath) {
 final BmobFile icon = new BmobFile(new File(imgpath));
 icon.upload(this, new UploadFileListener() {

  @Override
  public void onSuccess() {
  Person person = new Person();
  person.setIcon(icon);
  person.save(MainActivity.this);
  Toast.makeText(MainActivity.this,"图片上传成功",Toast.LENGTH_SHORT).show();
  }

  @Override
  public void onFailure(int arg0, String arg1) {
  Toast.makeText(MainActivity.this,"图片上传失败",Toast.LENGTH_SHORT).show();
  }
 });
 }

 //下载图片
 private void downloadImage(Person person) {
 BmobFile icon=person.getIcon();
 icon.download(MainActivity.this,new DownloadFileListener() {

  @Override
  public void onSuccess(String url) {
  ivDownload.setImageBitmap(BitmapFactory.decodeFile(url));  //根据地址解码并显示图片

  }

  @Override
  public void onFailure(int arg0, String arg1) {
  Toast.makeText(MainActivity.this,"下载失败",Toast.LENGTH_SHORT).show();
  }
 });

 }
}

3.Person.java页面为实体类,运行自动生成一个Person表,这个表只有一个字段存储图片。

Person.java页面:

package entity;

import cn.bmob.v3.BmobObject;
import cn.bmob.v3.datatype.BmobFile;

public class Person extends BmobObject{

 private BmobFile icon;

 public BmobFile getIcon() {
 return icon;
 }

 public void setIcon(BmobFile icon) {
 this.icon = icon;
 }

}

4.因为使用了Bmob,所以需要添加权限。

AndroidManifest.xml页面:

<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
  package="com.example.text"
  android:versionCode="1"
  android:versionName="1.0" >

  <uses-sdk
    android:minSdkVersion="8"
    android:targetSdkVersion="18" />
  <uses-permission android:name="android.permission.WRITE_CONTACTS"/>
  <uses-permission android:name="android.permission.READ_EXTERNAL_STORAGE"/>
  <uses-permission android:name="android.permission.INTERNET"/>

  <!-- 允许联网 -->
  <uses-permission android:name="android.permission.INTERNET" />
  <!-- 获取GSM(2g)、WCDMA(联通3g)等网络状态的信息 -->
  <uses-permission android:name="android.permission.ACCESS_NETWORK_STATE" />
  <!-- 获取wifi网络状态的信息 -->
  <uses-permission android:name="android.permission.ACCESS_WIFI_STATE" />
  <!-- 保持CPU 运转,屏幕和键盘灯有可能是关闭的,用于文件上传和下载 -->
  <uses-permission android:name="android.permission.WAKE_LOCK" />
  <!-- 获取sd卡写的权限,用于文件上传和下载 -->
  <uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE" />
  <!-- 允许读取手机状态 用于创建BmobInstallation -->
  <uses-permission android:name="android.permission.READ_PHONE_STATE" />

  <application
    android:allowBackup="true"
    android:icon="@drawable/ic_launcher"
    android:label="@string/app_name"
    android:theme="@style/AppTheme" >
    <activity
      android:name="com.example.text.MainActivity"
      android:label="@string/app_name" >
      <intent-filter>
        <action android:name="android.intent.action.MAIN" />

        <category android:name="android.intent.category.LAUNCHER" />
      </intent-filter>
    </activity>
  </application>

</manifest>

5.注意之前讲过使用Bmob需要下载第三方SDK,将libs文件夹中的所有内容都复制到项目libs目录下,然后Properties->Java Build Path->Libraries->Add JARs...添加刚复制的四个jar包

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

(0)

相关推荐

  • Android实现文件上传和下载倒计时功能的圆形进度条

    screenshot 截图展示 import step1. Add it in your root build.gradle at the end of repositories: allprojects { repositories { ... maven { url 'https://jitpack.io' } } } step2. Add the dependency dependencies { compile 'com.github.yanjiabin:ExtendsRingPrigr

  • Android FTP 多线程断点续传下载\上传的实例

    最近在给我的开源下载框架Aria增加FTP断点续传下载和上传功能,在此过程中,爬了FTP的不少坑,终于将功能实现了,在此把一些核心功能点记录下载. FTP下载原理 FTP单线程断点续传 FTP和传统的HTTP协议有所不同,由于FTP没有所谓的头文件,因此我们不能像HTTP那样通过设置header向服务器指定下载区间. 但是FTP协议提供了一个更好用的命令REST用于从指定位置恢复任务,同时FTP协议也提供了一个命令SIZE用于获取下载的文件大小,有了这两个命令,FTP断点续传也就没有什么问题.

  • Android中使用七牛云存储进行图片上传下载的实例代码

    Android开发中的图片存储本来就是比较耗时耗地的事情,而使用第三方的七牛云,便可以很好的解决这些后顾之忧,最近我也是在学习七牛的SDK,将使用过程在这记录下来,方便以后使用. 先说一下七牛云的存储原理,上面这幅图片是官方给出的原理图,表述当然比较清晰了. 可以看出,要进行图片上传的话可以分为五大步: 1. 客户端用户登录到APP的账号系统里面: 2. 客户端上传文件之前,需要向业务服务器申请七牛的上传凭证,这个凭证由业务服务器使用七牛提供的服务端SDK生成: 3. 客户端使用七牛提供的客户端

  • Android中FTP上传、下载的功能实现(含进度)

    Android中使用的FTP上传.下载,含有进度. 代码部分主要分为三个文件:MainActivity,FTP,ProgressInputStream 1. MainActivity package com.ftp; import java.io.File; import java.io.IOException; import java.util.LinkedList; import com.ftp.FTP.DeleteFileProgressListener; import com.ftp.F

  • Android编程实现仿QQ发表说说,上传照片及弹出框效果【附demo源码下载】

    本文实例讲述了Android编程实现仿QQ发表说说,上传照片及弹出框效果.分享给大家供大家参考,具体如下: 代码很简单,主要就是几个动画而已,图标什么的就随便找了几个,效果图:   动画说明: 1.点击右上角按钮,菜单从顶部下拉弹出,同时背景变暗; 2.再次点击右上角按钮,点击返回键,或者点击空白区域(也就是变暗的部分),菜单向上收回; 3.点击菜单上的按钮响应事件,同时菜单收回(效果同2) 重要说明:动画结束后必须clearAnimation,否则隐藏状态的view依然能响应点击事件 主体代码

  • Android Http实现文件的上传和下载

    最近做一个项目,其中涉及到文件的上传和下载功能,大家都知道,这个功能实现其实已经烂大街了,遂.直接从网上荡了一堆代码用,结果,发现网上的代码真是良莠不齐,不是写的不全面,就是有问题,于是自己重新整理了一番,把它们发出来,希望更多人能受用. 文件上传 通过org.apache.commons.httpclient.HttpClient来实现文件上传,该jar包可以直接从网上所搜.下载. /** * @param mContext 上下文 * @param targetUrl 文件上传地址 * @p

  • Android关于FTP文件上传和下载功能详解

    本文实例为大家分享了Android九宫格图片展示的具体代码,供大家参考,具体内容如下 此篇博客为整理文章,供大家学习. 1.首先下载commons-net  jar包,可以百度下载. FTP的文件上传和下载的工具类: package ryancheng.example.progressbar; import java.io.File; import java.io.FileOutputStream; import java.io.InputStream; import java.io.Outpu

  • 使用Android的OkHttp包实现基于HTTP协议的文件上传下载

    OkHttp的HTTP连接基础 虽然在使用 OkHttp 发送 HTTP 请求时只需要提供 URL 即可,OkHttp 在实现中需要综合考虑 3 种不同的要素来确定与 HTTP 服务器之间实际建立的 HTTP 连接.这样做的目的是为了达到最佳的性能. 首先第一个考虑的要素是 URL 本身.URL 给出了要访问的资源的路径.比如 URL http://www.baidu.com 所对应的是百度首页的 HTTP 文档.在 URL 中比较重要的部分是访问时使用的模式,即 HTTP 还是 HTTPS.这

  • Android编程实现图片的上传和下载功能示例

    本文实例讲述了Android编程实现图片的上传和下载功能.分享给大家供大家参考,具体如下: 在实现一个Android的WEB服务客户端,比如微博,论坛客户端时,经常会使用到图片的上传和下载.在这里介绍如何利用HttpClient实现图片的上传和下载功能. 1 图片上传:上传图片时,首先获得图片的路径,创建文件,并将图片转化为字节流写入到request,并发送该请求. 客户端代码: File file = new File(imageUrl); String httpUrl = httpDomai

  • Android实现相册中图片上传或下载

    本文实例为大家分享了Android实现相册中图片上传或下载的具体代码,供大家参考,具体内容如下 目标效果: 打开相册选择一张图片,会显示到上方的ImageView中并存储到Bmob中,存储后进入Bmob后台,复制刚才添加的数据的objectId,粘贴到代码指定出,然后运行,点击下载会在下方的ImageView显示刚才上传的图片,这里的下载是指定objectId,可以进行动态获取objectId进行下载. 1.activity_main.xml页面设置布局. activity_main.xml页面

  • iOS将相册中图片上传至服务器的方法

    本文为大家分享了iOS图片上传至服务器的具体代码,供大家参考,具体内容如下 在使用app时,从相册中选取图片作为头像是很常用的操作,首先打开相册选择图片,然后将图片保存至本应用的document,最后将document中图片的路径保存至NSUserDefaults和服务器. 从相册中选取图片或拍照 //从相册中选取图片或拍照 - (void)btnActionForEditPortrait:(id) sender { UIImagePickerController *picker = [[UII

  • 在django中图片上传的格式校验及大小方法

    如下所示: Uploadfiles = request.FILES.get('参数', '') for i in Uploadfiles : # 图片大小的属性 i.size suffix = os.path.splitext(i.name)[1] if not suffix: return False elif suffix.lower() == '.jpeg' or suffix.lower() == ".png" or suffix.lower() == ".jpg&q

  • WebApi2 文件图片上传与下载功能

    Asp.Net Framework webapi2 文件上传与下载 前端界面采用Ajax的方式执行 一.项目结构 1.App_Start配置了跨域访问,以免请求时候因跨域问题不能提交.具体的跨域配置方式如下,了解的朋友请自行略过. 跨域配置:NewGet安装dll Microsofg.AspNet.Cors 然后在App_Start 文件夹下的WebApiConfig.cs中写入跨域配置代码. public static class WebApiConfig { public static vo

  • spring boot实现图片上传和下载功能

    这篇博客简单介绍下spring boot下图片上传和下载,已经遇到的问题.首先需要创建一个spring boot项目. 1.核心的controller代码 package com.qwrt.station.websocket.controller; import com.alibaba.fastjson.JSONObject; import com.qwrt.station.common.util.JsonUtil; import org.slf4j.Logger; import org.slf

  • SpringMVC框架实现图片上传与下载

    本文实例为大家分享了SpringMVC框架实现图片上传与下载的具体代码,供大家参考,具体内容如下 1.新建一个Maven webapp项目,引入需要用的夹包,pom.xml文件的依赖包如下: <dependencies> <!-- 用于生成图片的缩略图 --> <dependency> <groupId>net.coobird</groupId> <artifactId>thumbnailator</artifactId>

  • Django 实现图片上传和下载功能

    原生上传图片方式 #新建工程 python manage.py startapp test30 #修改 settings.py INSTALLED_APPS = [ 'django.contrib.admin', 'django.contrib.auth', 'django.contrib.contenttypes', 'django.contrib.sessions', 'django.contrib.messages', 'django.contrib.staticfiles', 'stu'

  • Python Flask实现图片上传与下载的示例详解

    目录 1.效果预览 2.新增逻辑概览 3.tuchuang.py 逻辑介绍 3.1 图片上传 3.2 图片合法检查 3.3 图片下载 4.__init__.py 逻辑介绍 5.upload.html 介绍 5.1 upload Jinja 模板介绍 5.2 upload css 介绍(虚线框) 5.3 upload js 介绍(拖拽) 1.效果预览 我们基于 Flask 官方指导工程,增加一个图片拖拽上传功能,效果如下: 2.新增逻辑概览 我们在官方指导工程上进行增加代码,改动如下: 由于 fl

  • SpringBoot 文件或图片上传与下载功能的实现

    导入依赖(pom.xml) <!-- 上传下载需要设计到的jar包 --> <dependency> <groupId>commons-io</groupId> <artifactId>commons-io</artifactId> <version>2.6</version> </dependency> <dependency> <groupId>commons-fileu

随机推荐