okhttp 请求list数据实例
public class DataBean {
/**
* id : 61684
* movieName : 《猜火车2》先导预告片
* coverImg : http://img31.mtime.cn/mg/2016/07/26/143142.64770465.jpg
* movieId : 228230
* url : http://vfx.mtime.cn/Video/2016/07/26/mp4/160726074707321432_480.mp4
* hightUrl : http://vfx.mtime.cn/Video/2016/07/26/mp4/160726074707321432.mp4
* videoTitle : 猜火车2 先导预告片
* videoLength : 46
* rating : 0
* type : ["剧情"]
* summary : 苏格兰四兄弟回来了!
*/
private List<ItemData> trailers;
public void setTrailers(List<ItemData> trailers) {
this.trailers = trailers;
}
public List<ItemData> getTrailers() {
return trailers;
}
public static class ItemData {
private int id;
private String movieName;
private String coverImg;
private int movieId;
private String url;
private String hightUrl;
private String videoTitle;
private int videoLength;
private int rating;
private String summary;
private List<String> type;
get set....
}
}
public class CacheUtils {
/**
* 保持数据
* @param context
* @param key
* @param values
*/
public static void putString(Context context,String key,String values){
SharedPreferences sharedPreferences = context.getSharedPreferences("atguigu",Context.MODE_PRIVATE);
sharedPreferences.edit().putString(key,values).commit();
}
/**
* 得到缓存的数据
* @param context
* @param key
* @return
*/
public static String getString(Context context,String key){
SharedPreferences sharedPreferences = context.getSharedPreferences("atguigu",Context.MODE_PRIVATE);
return sharedPreferences.getString(key,"");
}
}
public class OKHttpListActivity extends Activity{
private static final String TAG = OKHttpListActivity.class.getSimpleName();
private ListView listView;
private ProgressBar progressBar;
private TextView tv_nodata;
private OKHttpListAdapter adapter;
private String url;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
initView();
getDataFromNet();
}
private void getDataFromNet() {
url = "http://api.m.mtime.cn/PageSubArea/TrailerList.api";
//得到缓存的数据
String saveJson = CacheUtils.getString(this,url);
if(!TextUtils.isEmpty(saveJson)){
processData(saveJson);
}
OkHttpUtils
.post()
.url(url)
.id(100)
.build()
.execute(new MyStringCallback());
}
private void initView() {
setContentView(R.layout.activity_okhttplist);
tv_nodata = (TextView) findViewById(R.id.tv_nodata);
listView = (ListView) findViewById(R.id.listview);
progressBar = (ProgressBar) findViewById(R.id.progressBar);
}
public class MyStringCallback extends StringCallback {
@Override
public void onBefore(Request request, int id) {
setTitle("loading...");
}
@Override
public void onAfter(int id) {
setTitle("Sample-okHttp");
}
@Override
public void onError(Call call, Exception e, int id) {
e.printStackTrace();
tv_nodata.setVisibility(View.VISIBLE);
}
@Override
public void onResponse(String response, int id) {
Log.e(TAG, "onResponse:complete");
tv_nodata.setVisibility(View.GONE);
switch (id) {
case 100:
Toast.makeText(OKHttpListActivity.this, "http", Toast.LENGTH_SHORT).show();
break;
case 101:
Toast.makeText(OKHttpListActivity.this, "https", Toast.LENGTH_SHORT).show();
break;
}
//解析数据和显示数据
if(response != null){
//缓存数据
CacheUtils.putString(OKHttpListActivity.this,url,response);
processData(response);
}
}
@Override
public void inProgress(float progress, long total, int id) {
Log.e(TAG, "inProgress:" + progress);
}
}
/**
* 解析和显示数据
* @param json
*/
private void processData(String json) {
//解析数据
DataBean dataBean = parsedJson(json);
List<DataBean.ItemData> datas = dataBean.getTrailers();
if(datas != null && datas.size() >0){
//有数据
tv_nodata.setVisibility(View.GONE);
//显示适配器
adapter = new OKHttpListAdapter(OKHttpListActivity.this,datas);
listView.setAdapter(adapter);
}else{
//没有数据
tv_nodata.setVisibility(View.VISIBLE);
}
progressBar.setVisibility(View.GONE);
}
/**
* 解析json数据
*
* @param response
* @return
*/
private DataBean parsedJson(String response) {
DataBean dataBean = new DataBean();
try {
JSONObject jsonObject = new JSONObject(response);
JSONArray jsonArray = jsonObject.optJSONArray("trailers");
if (jsonArray != null && jsonArray.length() > 0) {
List<DataBean.ItemData> trailers = new ArrayList<>();
dataBean.setTrailers(trailers);
for (int i = 0; i < jsonArray.length(); i++) {
JSONObject jsonObjectItem = (JSONObject) jsonArray.get(i);
if (jsonObjectItem != null) {
DataBean.ItemData mediaItem = new DataBean.ItemData();
String movieName = jsonObjectItem.optString("movieName");//name
mediaItem.setMovieName(movieName);
String videoTitle = jsonObjectItem.optString("videoTitle");//desc
mediaItem.setVideoTitle(videoTitle);
String imageUrl = jsonObjectItem.optString("coverImg");//imageUrl
mediaItem.setCoverImg(imageUrl);
String hightUrl = jsonObjectItem.optString("hightUrl");//data
mediaItem.setHightUrl(hightUrl);
//把数据添加到集合
trailers.add(mediaItem);
}
}
}
} catch (JSONException e) {
e.printStackTrace();
}
return dataBean;
}
}
public class OKHttpListAdapter extends BaseAdapter {
private final Context context;
private final List<DataBean.ItemData> datas;
public OKHttpListAdapter(Context context,List<DataBean.ItemData> datas){
this.context = context;
this.datas = datas;
}
@Override
public int getCount() {
return datas.size();
}
@Override
public Object getItem(int position) {
return null;
}
@Override
public long getItemId(int position) {
return 0;
}
@Override
public View getView(int position, View convertView, ViewGroup parent) {
final ViewHolder viewHolder;
if(convertView ==null){
convertView = View.inflate(context, R.layout.item_okhttp_list_image,null);
viewHolder = new ViewHolder();
viewHolder.iv_icon = (ImageView) convertView.findViewById(R.id.iv_icon);
viewHolder.tv_name = (TextView) convertView.findViewById(R.id.tv_name);
viewHolder.tv_desc = (TextView) convertView.findViewById(R.id.tv_desc);
convertView.setTag(viewHolder);
}else{
viewHolder = (ViewHolder) convertView.getTag();
}
//根据位置得到数据
DataBean.ItemData itemData = datas.get(position);
viewHolder.tv_name.setText(itemData.getMovieName());
viewHolder.tv_desc.setText(itemData.getVideoTitle());
//在列表中使用okhttp-utils请求图片
OkHttpUtils
.get()//
.url(itemData.getCoverImg())//
.tag(this)//
.build()//
.connTimeOut(20000)
.readTimeOut(20000)
.writeTimeOut(20000)
.execute(new BitmapCallback() {
@Override
public void onError(Call call, Exception e, int id) {
// tv_result.setText("onError:" + e.getMessage());
}
@Override
public void onResponse(Bitmap bitmap, int id) {
Log.e("TAG", "onResponse:complete");
viewHolder.iv_icon.setImageBitmap(bitmap);
}
});
return convertView;
}
static class ViewHolder{
ImageView iv_icon;
TextView tv_name;
TextView tv_desc;
}
}
okhttp 请求list数据实例的更多相关文章
- Okhttp 请求流程梳理
最近在看 Okhttp 的源码.不得不说源码设计的很巧妙,从中能学到很多.其实网上关于 Okhttp 的文章已经很多了,自己也看了很多.但是俗话说得好,好记性不如烂笔头,当你动手的时候,你会发现你在看 ...
- Android之三种网络请求解析数据(最佳案例)
AsyncTask解析数据 AsyncTask主要用来更新UI线程,比较耗时的操作可以在AsyncTask中使用. AsyncTask是个抽象类,使用时需要继承这个类,然后调用execute()方法. ...
- Easyui设置动态表格,动态导出数据实例,附Demo
最近开发的过程中碰到一个客户提出的需求,一个指定的页面导出需要提供一个弹出页面选择列表页面需要显示的列,页面确认之后需要修改列表页面显示的表格,导出的数据也需要同步变化. 总结一下可以称为一个列表数据 ...
- Datatables插件1.10.15版本服务器处理模式ajax获取分页数据实例解析
一.问题描述 前端需要使用表格来展示数据,找了一些插件,最后确定使用dataTables组件来做. 后端的分页接口已经写好了,不能修改.接口需要传入页码(pageNumber)和页面显示数据条数(pa ...
- json-lib-2.4-jdk15.jar所需全部JAR包.rar java jsoup解析开彩网api接口json数据实例
json-lib-2.4-jdk15.jar所需全部JAR包.rar java jsoup解析开彩网api接口json数据实例 json-lib-2.4-jdk15.jar所需全部JAR包.rar ...
- ajaxSubmit请求返回数据成功,但是不执行success回调函数
最近项目涉及到附件上传就头痛,一直在用plupload插件在做...ie9偶尔抽风但还是可以的... 然后有个需求,表格每行都有个上传按钮,页面多上传按钮. 一.开始的时候,用plupload做的,多 ...
- JSONP跨域jQuery处理整理(附天气数据实例)
写在前面 跨域的解决方案有多种,其中最常见的是使用同一服务器下的代理来获取远端数据,再通过ajax进行读取,而在这期间经过了两次请求过程,使得获取数据的效率大大降低,这篇文章蓝飞就为大家介绍一下解决跨 ...
- GoWeb开发_Iris框架讲解(二):Get、Post、Put等请求及数据返回格式
数据请求方式的分类 所有的项目中使用的请求都遵循HTTP协议标准,HTTP协议经过了1.0和1.1两个版本的发展. HTTP1.0定义了三种请求方法: GET, POST 和 HEAD方法. HTTP ...
- (转载)Android之三种网络请求解析数据(最佳案例)
[置顶] Android之三种网络请求解析数据(最佳案例) 2016-07-25 18:02 4725人阅读 评论(0) 收藏 举报 分类: Gson.Gson解析(1) 版权声明:本文为博主原创 ...
随机推荐
- [置顶]
一个简单好用的zabbix告警信息发送工具
之前使用邮件和短信发送zabbix告警信息,但告警信息无法实时查看或者无法发送,故障无法及时通知运维人员. 后来使用第三方微信接口发送信息,愉快地用了一年多,突然收费了. zabbix告警一直是我的痛 ...
- jquery 限制文本框只能输入数字
$("input[name='fangwenyudinhuishu']").keyup(function(){ var tmptxt=$(this).val(); $(this). ...
- 测试整合之王Unitils
16.4.1 Unitils概述(1) Unitils测试框架目的是让单元测试变得更加容易和可维护.Unitils构建在DbUnit与EasyMock项目之上并与JUnit和TestNG相结合.支持 ...
- ThinkPHP 3.1、3.2一个通用的漏洞分析
Author:m3d1t10n 前两天看到phithon大大在乌云发的关于ThinkPHP的漏洞,想看看是什么原因造成的.可惜还没有公开,于是就自己回来分析了一下. 0x00官方补丁(DB.class ...
- C++一元多项式相加
实验名称:一元多项式相加 // multiply.cpp : 定义控制台应用程序的入口点. // #include "stdafx.h" #include<iostream& ...
- jquery实现图片的依次加载图片
css代码: ul#portfolio{margin:0;padding:0;} ul#portfolio li{float:left;margin:0 5px 0 0;width:250px;hei ...
- VueJS绑定缩写:可省略v-on、v-bind
v-bind 缩写 Vue.js 为两个最为常用的指令提供了特别的缩写: <!-- 完整语法 --> <a v-bind:href="url"></a ...
- 中兴应用之星携手天翼开放平台:让APP开发更简单
日前,业内率先的APP开发平台运营商中兴应用之星与中国电信天翼开放平台达成战略合作.即广大用户通过天翼开放平台,可直接享受到应用之星提供的"APP开发服务". 应用之星.中兴通 ...
- Linux在中国正在走向没落
在中国,Linux正在走向没落,一片萧条景象. 在这样的大背景下.居然有人愿意接手中科红旗,令人佩服! 在中国,没有一个关于国际Linux的官方刊物(或站点)反映国际Linux运动的真实声音.Linu ...
- TFT、LCD、OLED、LPTS、CRT等显示屏的区别
1.TFT TFT(Thin Film Transistor)是薄膜晶体管的缩写.TFT式显示屏是各类笔记本电脑和台式机上的主流显示设备,该类显示屏上的每个液晶像素点都是由集成在像素点后面的薄膜晶体管 ...