首先,需要添加权限。

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

整体代码如下:

package com.tarena.viewer;

import java.io.IOException;
import java.io.InputStream;
import java.net.HttpURLConnection;
import java.net.MalformedURLException;
import java.net.URL; import android.app.Activity;
import android.graphics.Bitmap;
import android.graphics.BitmapFactory;
import android.os.Bundle;
import android.os.Handler;
import android.os.Message;
import android.view.Menu;
import android.view.MenuItem;
import android.view.View;
import android.view.View.OnClickListener;
import android.widget.Button;
import android.widget.ImageView;
import android.widget.Toast; /**
* 网络图片查看器,需要添加Internet权限
* @author chenchi
*
*/
public class MainActivity extends Activity implements OnClickListener { Handler handler = new Handler(){
//处理消息的时候我们需要区分这是成功的消息还是失败的消息
//此方法在主线程中调用,可以用来刷新UI
public void handleMessage(android.os.Message msg) {
switch (msg.what) {
case 1:
ImageView imageView = (ImageView) findViewById(R.id.image_view);
imageView.setImageBitmap((Bitmap) msg.obj);
break;
case 2:
Toast.makeText(MainActivity.this, "加载失败", Toast.LENGTH_SHORT).show();
break;
} }
};
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
Button btn_download = (Button) findViewById(R.id.btn_download);
btn_download.setOnClickListener(this);
} @Override
public void onClick(View v) {
Thread thread = new Thread(new Runnable() { @Override
public void run() {
//下载图片
//1.确定网址
String path = "http://192.168.31.225:8088/user.png";
try {
//2.把网址封装成一个URL对象
URL url = new URL(path);
//3.获取客户端和服务器的连接对象,此时还没有建立连接
HttpURLConnection conn = (HttpURLConnection) url.openConnection();
//4.对连接对象进行初始化
//设置请求方法,注意大写
conn.setRequestMethod("GET");
//设置连接超时
conn.setConnectTimeout(10000);
//设置读取超时
conn.setReadTimeout(10000);
//5.发送请求,与服务器建立连接
conn.connect();
//如果响应码为200,说明请求成功
if(conn.getResponseCode() == 200){
//获取服务器响应头中的流,流里的数据就是客户端啊请求的数据
InputStream is = conn.getInputStream();
//读取出流里面的数据,并构造成位图对象
Bitmap bm = BitmapFactory.decodeStream(is); /*
* 这两行代码为什么注释,是因为运行也没有结果的
* 因为只有主线程才能刷新UI操作,子线程是不可以的
*/
// ImageView imageView = (ImageView) findViewById(R.id.image_view);
// imageView.setImageBitmap(bm); //把消息返送到主线程的消息队列
Message msg = new Message();
//消息对象可以携带数据
msg.obj = bm;
msg.what = 1; //成功加载消息,返回1
handler.sendMessage(msg);
}else{
Message msg = handler.obtainMessage();//这样获取message是在池中获取,减少内存负荷
msg.what = 2;//失败加载消息,返回0
handler.sendMessage(msg);
} } catch (MalformedURLException e) {
e.printStackTrace();
} catch (IOException e) {
e.printStackTrace();
}
}
}); thread.start();
} }

还可以继续加上缓存的功能。

package com.tarena.viewer;

import java.io.File;
import java.io.FileOutputStream;
import java.io.IOException;
import java.io.InputStream;
import java.net.HttpURLConnection;
import java.net.MalformedURLException;
import java.net.URL; import android.R.integer;
import android.app.Activity;
import android.graphics.Bitmap;
import android.graphics.BitmapFactory;
import android.os.Bundle;
import android.os.Handler;
import android.os.Message;
import android.view.Menu;
import android.view.MenuItem;
import android.view.View;
import android.view.View.OnClickListener;
import android.widget.Button;
import android.widget.ImageView;
import android.widget.Toast; /**
* 网络图片查看器,需要添加Internet权限
* @author chenchi
*
*/
public class MainActivity extends Activity implements OnClickListener { private String getFilesName(String path) {
int index = path.lastIndexOf("/");
return path.substring(index + 1);
} Handler handler = new Handler(){
//处理消息的时候我们需要区分这是成功的消息还是失败的消息
//此方法在主线程中调用,可以用来刷新UI
public void handleMessage(android.os.Message msg) {
switch (msg.what) {
case 1:
ImageView imageView = (ImageView) findViewById(R.id.image_view);
imageView.setImageBitmap((Bitmap) msg.obj);
break;
case 2:
Toast.makeText(MainActivity.this, "加载失败", Toast.LENGTH_SHORT).show();
break;
} }
};
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
Button btn_download = (Button) findViewById(R.id.btn_download);
btn_download.setOnClickListener(this);
} @Override
public void onClick(View v) {
//下载图片
//1.确定网址
final String path = "http://192.168.31.225:8088/user.png";
//读取数据库返回的流里的数据,把数据写到本地文件,缓存起来
final File file = new File(getCacheDir(), getFilesName(path));
//判断,缓存中是否存在该文件
if(file.exists()){
//如果缓存存在,从缓存中读取数据
System.out.println("从缓存读取的");
Bitmap bm = BitmapFactory.decodeFile(file.getAbsolutePath());
ImageView imageView = (ImageView) findViewById(R.id.image_view);
imageView.setImageBitmap(bm);
return;
}
System.out.println("从网络下载的");
Thread thread = new Thread(new Runnable() { @Override
public void run() { try {
//2.把网址封装成一个URL对象
URL url = new URL(path);
//3.获取客户端和服务器的连接对象,此时还没有建立连接
HttpURLConnection conn = (HttpURLConnection) url.openConnection();
//4.对连接对象进行初始化
//设置请求方法,注意大写
conn.setRequestMethod("GET");
//设置连接超时
conn.setConnectTimeout(10000);
//设置读取超时
conn.setReadTimeout(10000);
//5.发送请求,与服务器建立连接
conn.connect();
//如果响应码为200,说明请求成功
if(conn.getResponseCode() == 200){
//获取服务器响应头中的流,流里的数据就是客户端啊请求的数据
InputStream is = conn.getInputStream(); byte[] b = new byte[1024];
FileOutputStream fos = new FileOutputStream(file);
int len = -1;
while((len = is.read(b)) != -1){
fos.write(b, 0, len);
} //读取出流里面的数据,并构造成位图对象
//Bitmap bm = BitmapFactory.decodeStream(is);
Bitmap bm = BitmapFactory.decodeFile(file.getAbsolutePath());
/*
* 这两行代码为什么注释,是因为运行也没有结果的
* 因为只有主线程才能刷新UI操作,子线程是不可以的
*/
// ImageView imageView = (ImageView) findViewById(R.id.image_view);
// imageView.setImageBitmap(bm); //把消息返送到主线程的消息队列
Message msg = new Message();
//消息对象可以携带数据
msg.obj = bm;
msg.what = 1; //成功加载消息,返回1
handler.sendMessage(msg);
}else{
Message msg = handler.obtainMessage();//这样获取message是在池中获取,减少内存负荷
msg.what = 2;//失败加载消息,返回0
handler.sendMessage(msg);
} } catch (MalformedURLException e) {
e.printStackTrace();
} catch (IOException e) {
e.printStackTrace();
}
} }); thread.start();
} }

Android中用URL模拟一个简单的图片加载器的更多相关文章

  1. 【模块化编程】理解requireJS-实现一个简单的模块加载器

    在前文中我们不止一次强调过模块化编程的重要性,以及其可以解决的问题: ① 解决单文件变量命名冲突问题 ② 解决前端多人协作问题 ③ 解决文件依赖问题 ④ 按需加载(这个说法其实很假了) ⑤ ..... ...

  2. Android开源库--Universal Image Loader通用图片加载器

    如果说我比别人看得更远些,那是因为我站在了巨人的肩上.   github地址:https://github.com/nostra13/Android-Universal-Image-Loader 介绍 ...

  3. Universal-Image-Loader解析(二)——DisplayImageOptions的详细配置与简单的图片加载

    在使用这个框架的时候,我们必须要配置一个DisplayImageOptions对象来作为ImageLoader.getInstance().displayImage()中的参数,所以很有必要讲解这个对 ...

  4. 使用RequireJS并实现一个自己的模块加载器 (一)

    RequireJS & SeaJS 在 模块化开发 开发以前,都是直接在页面上引入 script 标签来引用脚本的,当项目变得比较复杂,就会带来很多问题. JS项目中的依赖只有通过引入JS的顺 ...

  5. 使用RequireJS并实现一个自己的模块加载器 (二)

    2017 新年好 ! 新年第一天对我来说真是悲伤 ,早上兴冲冲地爬起来背着书包跑去实验室,结果今天大家都休息 .回宿舍的时候发现书包湿了,原来盒子装的牛奶盖子松了,泼了一书包,电脑风扇口和USB口都进 ...

  6. Android 框架修炼-自己开发高效异步图片加载框架

    一.概述 目前为止,第三方的图片加载框架挺多的,比如UIL , Volley Imageloader等等.但是最好能知道实现原理,所以下面就来看看设计并开发一个加载网络.本地的图片框架. 总所周知,图 ...

  7. 14. Android框架和工具之 ImageLoader(图片加载)

    1. 这个图片加载框架网友很多都已经使用过,而且分析也很到位,这里我就不写了,直接引用别人,尊重别人的劳动成果. 2. 参考如下: (1)Android 开源框架Universal-Image-Loa ...

  8. 在Qt Quick中一个简单Hello World加载过程

    Qt5基本类图: QQmlEngine    QQmlEngine类提供了一个QML引擎,用于管理由QML文档定义的对象层次架构,QML提供了一个默认的QML上下文(根上下文,获取函数QQmlEngi ...

  9. 高性能异步图片加载器的JS库:lazysizes

    <script src="lazysizes.min.js" async=""></script> 使用示例 <!-- non-r ...

随机推荐

  1. Google Map API 使用总结

    Google Map API (一):显示一个最基本的地图 1 实现一个地图:<head>中引用: <script type="text/javascript" ...

  2. 好玩的-记最近玩的几个经典ipad ios游戏

    最近回了趟家,在家里闲着没事去app store找了找一些高分游戏玩一玩,下面就是我最近玩的游戏. 海岛奇兵 想必大家都很了解,这是由开发过clash of clan部落冲突的公司所开发的另一款多人策 ...

  3. Codeforces Round #257(Div.2) D Jzzhu and Cities --SPFA

    题意:n个城市,中间有m条道路(双向),再给出k条铁路,铁路直接从点1到点v,现在要拆掉一些铁路,在保证不影响每个点的最短距离(距离1)不变的情况下,问最多能删除多少条铁路 分析:先求一次最短路,铁路 ...

  4. poj 1159 Palindrome

    Palindrome Time Limit: 3000MS   Memory Limit: 65536K Total Submissions: 59094   Accepted: 20528 Desc ...

  5. [Android学习笔记]理解焦点处理原理的相关记录

    焦点处理相关记录 以下所涉及的焦点部分,只是按键移动部分,不明确包含Touch Focus部分 需解决问题 控件的下一个焦点是哪? 分析思路 当用户通过按键(遥控器等)触发焦点切换时,事件指令会通过底 ...

  6. Node.js开发环境搭建

    1.安装express npm install express -g 2.express33.6以后把express-generator分离出来了,所以还需安装express-generator,否则 ...

  7. vrrp两用

    早上想了想vrrp的使用,1,网关冗余 2,服务器热备 思想稍微有点不一样.主要在于监控口 服务器的话有心跳线,用户同步一些配置和迁移一些服务.达到热备的目的.:牵涉到四个优先级:建议这样排序: 主机 ...

  8. 利用ViewHolder优化自定义Adapter的典型写法

    1 public class MarkerItemAdapter extends BaseAdapter { private Context mContext = null; private List ...

  9. js运动框架 step by step

    开启setInterval定时器之前,请先清除之前的定时器 window.onload = function() { var btn = document.getElementById('btn'); ...

  10. LeetCode:Clone Graph

    题目如下:实现克隆图的算法  题目链接 Clone an undirected graph. Each node in the graph contains a label and a list of ...