网上下载图片并保存到手机里面

本文介绍了一个使用Android中异步任务(AsyncTask)从网络下载图片并显示在ImageView中的示例。通过创建自定义的AsyncTask子类,在后台线程执行图片下载,并将结果展示在UI线程。

MainActivity

里面用的是异步任务下载的图片

package com.jj.rikao_15;

import android.content.Context;
import android.graphics.Bitmap;
import android.graphics.BitmapFactory;
import android.os.AsyncTask;
import android.os.Bundle;
import android.support.v7.app.AppCompatActivity;
import android.widget.ImageView;

import java.io.File;
import java.io.FileNotFoundException;
import java.io.FileOutputStream;
import java.io.IOException;

public class MainActivity extends AppCompatActivity {

    private ImageView iv;
    //地址
    private String path="http://ent.k618.cn/ylzx/201607/W020160718836443319007.jpeg";
    private Context context;
    private Bitmap bitmap=null;
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        iv=(ImageView)findViewById(R.id.iv);
        context=this;
        getDate();
    }
    //异步下载
    private void getDate() {
        new AsyncTask<String,Void,Bitmap>(){

            @Override
            protected Bitmap doInBackground(String... strings) {
                
                byte[] bytes=HttpUtils.getDateFrom(path);
                 //保存图片到手机里面
                Bitmap bitmap= BitmapFactory.decodeByteArray(bytes,0,bytes.length);
                File file=new File(context.getExternalCacheDir(),"9007.jpg");
                try {
                    FileOutputStream fos=new FileOutputStream(file);
                    fos.write(bytes);
                    fos.flush();
                    fos.close();
                } catch (FileNotFoundException e) {
                    e.printStackTrace();
                } catch (IOException e) {
                    e.printStackTrace();
                }
                return bitmap;
            }

            @Override
            protected void onPostExecute(Bitmap bitmap) {
                super.onPostExecute(bitmap);
                if (bitmap!=null){
                    iv.setImageBitmap(bitmap);
                }
            }

        }.execute();
    }

}
  HttpUtils--网上下载

package com.jj.rikao_15;

import android.graphics.Bitmap;
import android.util.Log;

import java.io.ByteArrayOutputStream;
import java.io.IOException;
import java.io.InputStream;
import java.net.HttpURLConnection;
import java.net.MalformedURLException;
import java.net.URL;

/**
 * Created by jj on 2018/1/12.
 */

public class HttpUtils {
    public static byte[] getDateFrom(String path){
        try {

            URL url=new URL(path);
            HttpURLConnection conn=(HttpURLConnection) url.openConnection();
            //GET下载
            conn.setRequestMethod("GET");
            //提交
            conn.connect();
            //判断是否请求成功
            if (conn.getResponseCode()==200){
                Bitmap bitmap=null;
                InputStream is=conn.getInputStream();
                ByteArrayOutputStream os=new ByteArrayOutputStream();
                int len=0;
                byte[] b=new byte[1024];
                while ((len=is.read(b))!=-1){
                    os.write(b,0,len);
                }
                return os.toByteArray();
            }
        } catch (MalformedURLException e) {
            e.printStackTrace();
        } catch (IOException e) {
            e.printStackTrace();
        }
        return null;
    }
}
    权限

    

 <uses-permission android:name="android.permission.INTERNET"/>

### 实现将图片保存手机相册的功能 在 iOS 前端使用 Vue 框架实现将图片保存手机相册的功能,可以通过 `plus` 插件来完成。以下是一个详细的实现方法: 1. **检查 `plus` 插件是否存在**:确保在 H5+ 环境下运行,因为 `plus` 是 H5+ 的一部分,通常在 App 中使用。 2. **下载图片**:使用 `plus.downloader.createDownload` 方法下载图片。 3. **保存图片到相册**:使用 `plus.gallery.save` 方法保存图片到相册。 以下是实现代码: ```javascript function saveImageToAlbum(url) { // 检查plus插件是否存在 if (!window.plus) { alert("当前环境不支持plus插件"); return; } // 显示加载等待提示 plus.nativeUI.showWaiting("加载中..."); // 创建下载任务 var dtask = plus.downloader.createDownload( url, {}, function (d, status) { // 下载完成 if (status == 200) { console.log("下载成功,文件保存在" + d.filename); // 保存到相册 plus.gallery.save( d.filename, function () { // 保存成功 plus.nativeUI.closeWaiting(); alert("保存图片到相册成功"); }, function () { // 保存失败 plus.nativeUI.closeWaiting(); alert("保存失败"); } ); } else { alert("保存失败,请重试!"); } } ); // 开始下载任务 dtask.start(); } ``` ### 修复 iOS 微信长按图片导致的区域选择问题 在 iOS 的微信中,长按图片可能会导致大面积区域被选中的问题。可以通过以下方法修复: 1. **阻止默认的长按行为**:在图片上添加 `@contextmenu.prevent` 和 `@touchstart` 事件来阻止默认的长按行为。 2. **使用 `user-select` CSS 属性**:设置 `user-select: none;` 来防止文本选择。 ```html <img :src="imageUrl" @contextmenu.prevent @touchstart="handleTouchStart" style="user-select: none;" /> ``` 在 Vue 组件中定义 `handleTouchStart` 方法: ```javascript methods: { handleTouchStart(event) { // 阻止默认的触摸事件 event.preventDefault(); } } ``` 通过上述方法,可以在 iOS 前端使用 Vue 框架实现将图片保存手机相册的功能,且修复 iOS 微信长按图片导致的区域选择问题。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值