首先,需要添加权限。

<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. python中的getattr函数

    getattr(object, name[, default]) -> value Get a named attribute from an object; getattr(x, 'y') i ...

  2. python中的自测语句是什么?

    if __name__ == '__main__': main() 以上

  3. POJ 2773 Happy 2006【GCD/欧拉函数】

    根据欧几里德算法,gcd(a,b)=gcd(a+b*t,b) 如果a和b互质,则a+b*t和b也互质,即与a互质的数对a取模具有周期性. 所以只要求出小于n且与n互质的元素即可. #include&l ...

  4. Android组件系列----Android Service组件深入解析

    [声明] 欢迎转载,但请保留文章原始出处→_→ 生命壹号:http://www.cnblogs.com/smyhvae/ 文章来源:http://www.cnblogs.com/smyhvae/p/4 ...

  5. Watir、Selenium2、QTP区别

    1.支持的语言 Watir:ruby Selenium2:支持多种语言,如:python,ruby,java,c#,php,perl,javascript QTP:vbscript 2.支持的浏览器 ...

  6. Redis集群环境的部署记录

    Redis Cluster终于出了Stable,这让人很是激动,等Stable很久了,所以还是先玩玩. 一. 集群简单概念. Redis 集群是一个可以在多个 Redis 节点之间进行数据共享的设施( ...

  7. 对于a标签点击之后可以发邮件和打电话的功能实现

    <ul> <li><i class="phone"></i><a href="tel:021-69976089&qu ...

  8. 查询Sqlserver数据库死锁的一个存储过程(转)

    链接 :http://www.cnblogs.com/mzhanker/archive/2011/06/04/2072739.html 使用sqlserver作为数据库的应用系统,都避免不了有时候会产 ...

  9. ruby 元编程

    一 对象模型 kernel Module Kernel.private_instance_methods.grep(/^pr/)   private method 1 如果一个方法接收者不是你自己,一 ...

  10. Web的形式发布静态文件

    Web的形式发布静态文件 虽然ASP.NET Core是一款"动态"的Web服务端框架,但是在很多情况下都需要处理针对静态文件的请求,最为常见的就是这对JavaScript脚本文件 ...