Android网络编程之简易新闻客户端

发布时间 - 2026-01-11 01:26:27    点击率:

一、 通过一个案例“新闻客户端”向大家演示AsyncHttpClient和SmartImageView的综合使用。

运行结果如下:

1、首先我们了解一下相关知识: 

SmartImageView的使用

市面上一些常见软件,例如手机QQ、天猫、京东商场等,都加载了大量网络上的图片。用Android自带的API实现这一功能十分麻烦而且耗时。为此,编程爱好者开发了一个开源项目——SmartImageView。

https://github.com/loopj/android-smart-image-view (SmartImageView的jar包得下载)

开源项目SmartImageView的出现主要是为了 加速从网络上加载图片,它继承自ImageView类,支持根据URL地址加载图片、支持异步加载图片、支持图片缓存等。

AsyncHttpClient的使用

在Android开发中,发送、处理HTTP请求十分常见,如果每次与服务器进行数据交互都需要去开启一个子线程,这样是非常麻烦的。为了解决这个问题,一些开发者开发出了开源项目——AsyncHttpClient。
http://github.com/loopj/android-async-http
http://hc.apache.org/download.cgi

AsyncHttpClient是对HttpClient的 再次包装。AsyncHttpClient的特点有,发送 异步HTTP 请求、HTTP
请求发生在 在UI线程之外 线程之外、内部采用了 线程池来处理并发请求, ,而且它使用起来比HttpClient更加简便。

配置Tomcat服务器 

http://tomcat.apache.org下载并通过startup.bat启动服务器

在webapps/Root文件夹下:JSON文件和images文件夹

在这里我就不介绍GSON解析了,在我的下一篇博文中会有解释

二、实现步骤如下 


需要创建如上类

• Entity包下创建 包下创建实体类 实体类NewsInfo

package cn.edu.bzu.anew.entity; 
 
/** 
 * Created by Administrator on 2017/5/18. 
 */ 
public class NewsInfo { 
 private String icon;//图片路径 
 private String title;//新闻标题 
 private String description;//新闻描述 
 private int type;//新闻类型 
 private long comment;//新闻评论数 
 
 public NewsInfo(String icon, String title, String description, int type, long comment) { 
  this.icon = icon; 
  this.title = title; 
  this.description = description; 
  this.type = type; 
  this.comment = comment; 
 } 
 
 public String getIcon() { 
  return icon; 
 } 
 
 public void setIcon(String icon) { 
  this.icon = icon; 
 } 
 
 public String getTitle() { 
  return title; 
 } 
 
 public void setTitle(String title) { 
  this.title = title; 
 } 
 
 public String getDescription() { 
  return description; 
 } 
 
 public void setDescription(String description) { 
  this.description = description; 
 } 
 
 public int getType() { 
  return type; 
 } 
 
 public void setType(int type) { 
  this.type = type; 
 } 
 
 public long getComment() { 
  return comment; 
 } 
 
 public void setComment(long comment) { 
  this.comment = comment; 
 } 
} 

• Tools包下创建 包下创建 工具类 类JsonParse 负责解析JSON数据

package cn.edu.bzu.anew.Tools; 
 
import com.google.gson.Gson; 
import com.google.gson.reflect.TypeToken; 
 
import java.lang.reflect.Type; 
import java.util.List; 
 
import cn.edu.bzu.anew.entity.NewsInfo; 
 
/** 
 * Created by Administrator on 2017/5/18. 
 */ 
 
public class JsonParse { 
 public static List<NewsInfo>getNewsInfo(String json){//使用gson库解析Json数据 
  Gson gson =new Gson(); 
  Type listType=new TypeToken<List<NewsInfo>> (){//创建一个typeToken的匿名子类对象,并调用对象得getType()方法 
  }.getType(); 
  List<NewsInfo>newsInfos=gson.fromJson(json,listType);//把获取到的信息集合存到newsInfos中 
  return newsInfos; 
 } 
} 

 adapter 包下创建NewsAdapter类

package cn.edu.bzu.anew.adapter; 
import android.content.Context; 
import android.support.annotation.NonNull; 
import android.view.LayoutInflater; 
import android.view.View; 
import android.view.ViewGroup; 
import android.widget.ArrayAdapter; 
import android.widget.TextView; 
import com.loopj.android.image.SmartImageView; 
import java.util.List; 
import cn.edu.bzu.anew.R; 
import cn.edu.bzu.anew.entity.NewsInfo; 
public class NewsAdapter extends ArrayAdapter<NewsInfo>{ 
 public NewsAdapter(Context context, List<NewsInfo> objects) { 
  super(context, R.layout.news_item, objects); 
 
 } 
 
 @NonNull 
 @Override 
 public View getView(int position, View convertView, ViewGroup parent) { 
  NewsInfo newsinfo= getItem(position);//传递position,获取当前位置对应的newsinfo新闻信息 
  View view=null; 
  viewHolder viewHolder; 
  if(convertView==null){ //判断convertView中是否加载了布局,有没有缓存。为空说明没有缓存 
   view=LayoutInflater.from(getContext()).inflate(R.layout.news_item,null); 
   viewHolder=new viewHolder(); 
   viewHolder.siv= (SmartImageView) view.findViewById(R.id.siv_icon); 
   viewHolder.tv_title= (TextView) view.findViewById(R.id.tv_title); 
   viewHolder.tv_description= (TextView) view.findViewById(R.id.tv_description); 
   viewHolder.tv_type= (TextView) view.findViewById(R.id.tv_type); 
   view.setTag(viewHolder); //保存 
  }else{ 
   view=convertView; 
   viewHolder=(viewHolder) view.getTag(); 
  } 
  viewHolder.siv.setImageUrl(newsinfo.getIcon());//传递图片地址 
  viewHolder.tv_title.setText(newsinfo.getTitle());//传递题目 
  viewHolder.tv_description.setText(newsinfo.getDescription()); 
  viewHolder.tv_type.setText(newsinfo.getType()+""); 
  return view; 
 } 
 class viewHolder{//添加类,封装需要查找的控件 
  TextView tv_title; 
  TextView tv_description; 
  TextView tv_type; 
  SmartImageView siv; 
 
 } 
} 

 界面逻辑代码的设计与实现(MainActivity)

package cn.edu.bzu.anew; 
import android.support.v7.app.AppCompatActivity; 
import android.os.Bundle; 
import android.view.View; 
import android.widget.LinearLayout; 
import android.widget.ListView; 
import android.widget.Toast; 
import com.loopj.android.http.AsyncHttpClient; 
import com.loopj.android.http.AsyncHttpResponseHandler; 
import java.io.UnsupportedEncodingException; 
import java.util.List; 
import cn.edu.bzu.anew.Tools.JsonParse; 
import cn.edu.bzu.anew.adapter.NewsAdapter; 
import cn.edu.bzu.anew.entity.NewsInfo; 
public class MainActivity extends AppCompatActivity { 
 private ListView lvNews; 
 private List<NewsInfo> newsInfos; 
 private LinearLayout loading; 
 
 @Override 
 protected void onCreate(Bundle savedInstanceState) { 
  super.onCreate(savedInstanceState); 
  setContentView(R.layout.activity_main); 
  lvNews=(ListView)findViewById(R.id.lv_news); 
  loading=(LinearLayout)findViewById(R.id.loading); 
  fillData(); 
 
 } 
 private void fillData(){ 
  AsyncHttpClient client =new AsyncHttpClient(); 
 
  client.get("http://10.61.28.176:8080/NewsInfo.json",new AsyncHttpResponseHandler(){ 
   @Override 
   public void onSuccess(int i, org.apache.http.Header[] headers, byte[] bytes) { 
    try{ 
     String json=new String(bytes,"utf-8"); 
     newsInfos= JsonParse.getNewsInfo(json); 
     if(newsInfos==null){ 
      Toast.makeText(MainActivity.this,"解析失败", Toast.LENGTH_LONG).show(); 
     }else{ 
      loading .setVisibility(View.INVISIBLE); 
      lvNews.setAdapter(new NewsAdapter(MainActivity.this,newsInfos)); 
     } 
    } catch (UnsupportedEncodingException e) { 
     e.printStackTrace(); 
    } 
   } 
 
   @Override 
   public void onFailure(int i, org.apache.http.Header[] headers, byte[] bytes, Throwable throwable) { 
 
   } 
  } ); 
 
 
 } 
} 

在AndroidManifest.xml添加访问权限在</application>外<uses-permission android:name="android.permission.INTERNET"></uses-permission>

最后项目就完成了

有以*意事项需要我们注意:
(1)我们在自己的电脑上运行项目时要用自己的ip地址 json文件中也是如此

(2)在这里我们需要添加三个jar包,记得as library(在Projects---app---libs)

(3)

 

如果出现以上问题 ,图片加载失误 当地址都正确  ,那就是你没有添加网络加载图片还有就是把图片后缀jpg改为PNG
viewHolder.siv.setImageUrl(newsinfo.getIcon());

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


# Android  # 新闻客户端  # Android实现雅虎新闻摘要加载视差动画效果  # Android仿网易新闻图片详情下滑隐藏效果示例代码  # Android开发实现自定义新闻加载页面功能实例  # Android UI设计与开发之PopupWindow仿腾讯新闻底部弹出菜单  # Android RecyclerView仿新闻头条的频道管理功能  # Android模拟实现网易新闻客户端  # Android 模拟新闻APP显示界面滑动优化实例代码  # Android实现基本功能的新闻应用  # 加载  # 自己的  # 开源  # 这一  # 在这里  # 会有  # 出了  # 子类  # 在这  # 就不  # 采用了  # 实体类  # 你没  # 下一篇  # 自带  # 时要  # 创建一个  # 里我  # 解决这个问题  # 大家多多 


相关栏目: 【 网站优化151355 】 【 网络推广146373 】 【 网络技术251813 】 【 AI营销90571


相关推荐: 重庆市网站制作公司,重庆招聘网站哪个好?  Laravel怎么实现API接口鉴权_Laravel Sanctum令牌生成与请求验证【教程】  Laravel怎么实现观察者模式Observer_Laravel模型事件监听与解耦开发【指南】  香港服务器网站推广:SEO优化与外贸独立站搭建策略  利用vue写todolist单页应用  Laravel Seeder怎么填充数据_Laravel数据库填充器的使用方法与技巧  如何在阿里云虚拟服务器快速搭建网站?  如何快速启动建站代理加盟业务?  javascript读取文本节点方法小结  如何在万网主机上快速搭建网站?  如何打造高效商业网站?建站目的决定转化率  php静态变量怎么调试_php静态变量作用域调试技巧【解答】  Python并发异常传播_错误处理解析【教程】  使用spring连接及操作mongodb3.0实例  Laravel如何实现多表关联模型定义_Laravel多对多关系及中间表数据存取【方法】  Laravel如何发送系统通知?(Notification渠道示例)  零基础网站服务器架设实战:轻量应用与域名解析配置指南  Laravel怎么使用Intervention Image库处理图片上传和缩放  Android自定义控件实现温度旋转按钮效果  如何在服务器上配置二级域名建站?  高端建站三要素:定制模板、企业官网与响应式设计优化  如何快速搭建个人网站并优化SEO?  Win11怎么更改系统语言为中文_Windows11安装语言包并设为显示语言  Laravel怎么配置不同环境的数据库_Laravel本地测试与生产环境动态切换【方法】  Laravel如何设置定时任务(Cron Job)_Laravel调度器与任务计划配置  Laravel如何使用集合(Collections)进行数据处理_Laravel Collection常用方法与技巧  EditPlus 正则表达式 实战(3)  大型企业网站制作流程,做网站需要注册公司吗?  C语言设计一个闪闪的圣诞树  微信小程序 scroll-view组件实现列表页实例代码  如何快速生成高效建站系统源代码?  七夕网站制作视频,七夕大促活动怎么报名?  如何快速建站并高效导出源代码?  如何自定义safari浏览器工具栏?个性化设置safari浏览器界面教程【技巧】  Laravel如何配置中间件Middleware_Laravel自定义中间件拦截请求与权限校验【步骤】  制作旅游网站html,怎样注册旅游网站?  如何快速选择适合个人网站的云服务器配置?  详解Android图表 MPAndroidChart折线图  东莞专业网站制作公司有哪些,东莞招聘网站哪个好?  如何在阿里云服务器自主搭建网站?  Win11怎么修改DNS服务器 Win11设置DNS加速网络【指南】  Laravel中间件起什么作用_Laravel Middleware请求生命周期与自定义详解  网站制作软件免费下载安装,有哪些免费下载的软件网站?  车管所网站制作流程,交警当场开简易程序处罚决定书,在交警网站查询不到怎么办?  Claude怎样写结构化提示词_Claude结构化提示词写法【教程】  高性能网站服务器部署指南:稳定运行与安全配置优化方案  Laravel项目结构怎么组织_大型Laravel应用的最佳目录结构实践  rsync同步时出现rsync: failed to set times on “xxxx”: Operation not permitted  Laravel模型事件有哪些_Laravel Model Event生命周期详解  linux写shell需要注意的问题(必看)