目前对应okhttp版本3.3.1.
okhttp-utils Github:
https://github.com/hongyangAndroid/okhttputils
导入依赖:
compile ‘com.android.support:recyclerview-v7:26.1.0’
compile 'com.zhy:okhttputils:2.6.2'
compile
'com.github.bumptech.glide:glide:3.7.0'
AndroidManifest.xml
<uses-permission android:name="android.permission.INTERNET"/>
<uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE"/>
运行效果
XML布局
<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent">
<!-- <ListView
android:id="@+id/listview"
android:layout_width="match_parent"
android:layout_height="wrap_content" /> -->
<android.support.v7.widget.RecyclerView
android:id="@+id/recyclerview"
android:layout_width="match_parent"
android:layout_height="wrap_content">
</android.support.v7.widget.RecyclerView>
<ProgressBar
android:id="@+id/progressBar"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_centerInParent="true" />
<TextView
android:visibility="gone"
android:id="@+id/tv_nodata"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_centerInParent="true"
android:text="没有数据..."
android:textColor="#000000" />
</RelativeLayout>
<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="100dp"
android:gravity="center_vertical">
<RelativeLayout
android:id="@+id/rl_image"
android:layout_width="120dp"
android:layout_height="80dp"
android:layout_centerVertical="true">
<ImageView
android:id="@+id/iv_icon"
android:layout_width="120dp"
android:layout_height="80dp"
android:layout_marginLeft="8dp"
android:scaleType="fitXY"
android:src="@drawable/video_default" />
<ImageView
android:id="@+id/imageView"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_alignParentBottom="true"
android:layout_alignParentRight="true"
android:layout_marginBottom="8dp"
android:layout_marginRight="8dp"
android:src="@drawable/center_collect_play" />
</RelativeLayout>
<LinearLayout
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_centerVertical="true"
android:layout_marginLeft="8dp"
android:layout_toRightOf="@id/rl_image"
android:orientation="vertical">
<TextView
android:id="@+id/tv_name"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:singleLine="true"
android:text="视频的名称"
android:textColor="#000000"
android:textSize="18sp" />
<TextView
android:id="@+id/tv_desc"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginTop="8dp"
android:singleLine="true"
android:text="视频的描述"
android:textColor="#55000000"
android:textSize="18sp" />
</LinearLayout>
</RelativeLayout>
第二个是item的布局
JAVA代码
CacheUtils缓存类
import android.content.Context;
import android.content.SharedPreferences;
//缓存类
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,"");
}
}
DataBean
import java.util.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;
public void setId(int id) {
this.id = id;
}
public void setMovieName(String movieName) {
this.movieName = movieName;
}
public void setCoverImg(String coverImg) {
this.coverImg = coverImg;
}
public void setMovieId(int movieId) {
this.movieId = movieId;
}
public void setUrl(String url) {
this.url = url;
}
public void setHightUrl(String hightUrl) {
this.hightUrl = hightUrl;
}
public void setVideoTitle(String videoTitle) {
this.videoTitle = videoTitle;
}
public void setVideoLength(int videoLength) {
this.videoLength = videoLength;
}
public void setRating(int rating) {
this.rating = rating;
}
public void setSummary(String summary) {
this.summary = summary;
}
public void setType(List<String> type) {
this.type = type;
}
public int getId() {
return id;
}
public String getMovieName() {
return movieName;
}
public String getCoverImg() {
return coverImg;
}
public int getMovieId() {
return movieId;
}
public String getUrl() {
return url;
}
public String getHightUrl() {
return hightUrl;
}
public String getVideoTitle() {
return videoTitle;
}
public int getVideoLength() {
return videoLength;
}
public int getRating() {
return rating;
}
public String getSummary() {
return summary;
}
public List<String> getType() {
return type;
}
}
}
RecyclerViewAdapter
import android.content.Context;
import android.support.v7.widget.RecyclerView;
import android.view.View;
import android.view.ViewGroup;
import android.widget.ImageView;
import android.widget.TextView;
import com.bumptech.glide.Glide;
import com.example.administrator.okhttp_utilsdemo.R;
import com.example.administrator.okhttp_utilsdemo.domain.DataBean;
import java.util.List;
/**
* Created by Administrator on 2018/6/2.
*/
public class RecyclerViewAdapter extends RecyclerView.Adapter<RecyclerViewAdapter.MyViewHolder> {
private Context context;
private List<DataBean.ItemData> datas;
public RecyclerViewAdapter(Context context,List<DataBean.ItemData> datas){
this.context=context;
this.datas=datas;
}
@Override
public MyViewHolder onCreateViewHolder(ViewGroup parent, int viewType) {
View view=View.inflate(parent.getContext(), R.layout.item_okhttp_list_image,null);
return new MyViewHolder(view);
}
@Override
public void onBindViewHolder(MyViewHolder holder, int position) {
//根据位置得到数据
DataBean.ItemData itemData = datas.get(position);
holder.tv_name.setText(itemData.getMovieName());
holder.tv_desc.setText(itemData.getVideoTitle());
Glide.with(context)
.load(itemData.getCoverImg())
.into(holder.iv_icon);
}
@Override
public int getItemCount() {
return datas==null? 0:datas.size();
}
public class MyViewHolder extends RecyclerView.ViewHolder {
private TextView tv_name;
private TextView tv_desc;
private ImageView iv_icon;
public MyViewHolder(View itemView) {
super(itemView);
iv_icon = (ImageView) itemView.findViewById(R.id.iv_icon);
tv_name = (TextView) itemView.findViewById(R.id.tv_name);
tv_desc = (TextView) itemView.findViewById(R.id.tv_desc);
}
}
}
OkHttpListAdapter
import android.content.Context;
import android.graphics.Bitmap;
import android.util.Log;
import android.view.View;
import android.view.ViewGroup;
import android.widget.BaseAdapter;
import android.widget.ImageView;
import android.widget.TextView;
import com.bumptech.glide.Glide;
import com.example.administrator.okhttp_utilsdemo.OKHttpListActivity;
import com.example.administrator.okhttp_utilsdemo.R;
import com.example.administrator.okhttp_utilsdemo.domain.DataBean;
import com.zhy.http.okhttp.OkHttpUtils;
import com.zhy.http.okhttp.callback.BitmapCallback;
import java.util.List;
import okhttp3.Call;
import static com.example.administrator.okhttp_utilsdemo.R.id.iv_icon;
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;
}
//得到item的总数
@Override
public int getCount() {
return datas.size();
}
//得到item代表的对象
@Override
public Object getItem(int position) {
return null;
}
//得到item的id
@Override
public long getItemId(int position) {
return 0;
}
//得到item的View视图
@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);
}
});
//listView中使用Glide
/* Glide.with(context)
.load(itemData.getCoverImg())
.into(viewHolder.iv_icon);
*/
return convertView;
}
//想使用这些控件必须要定义这个ViewHolder类
static class ViewHolder{
ImageView iv_icon;
TextView tv_name;
TextView tv_desc;
}
}
两个Adapter,选择使用一个即可。
OkhttpListActivity
import android.app.Activity;
import android.os.Bundle;
import android.support.v7.widget.LinearLayoutManager;
import android.support.v7.widget.RecyclerView;
import android.text.TextUtils;
import android.util.Log;
import android.view.View;
import android.widget.ListView;
import android.widget.ProgressBar;
import android.widget.TextView;
import android.widget.Toast;
import com.example.administrator.okhttp_utilsdemo.R;
import com.example.administrator.okhttp_utilsdemo.adapter.OKHttpListAdapter;
import com.example.administrator.okhttp_utilsdemo.adapter.RecyclerViewAdapter;
import com.example.administrator.okhttp_utilsdemo.domain.DataBean;
import com.example.administrator.okhttp_utilsdemo.uitls.CacheUtils;
import com.zhy.http.okhttp.OkHttpUtils;
import com.zhy.http.okhttp.callback.StringCallback;
import org.json.JSONArray;
import org.json.JSONException;
import org.json.JSONObject;
import java.util.ArrayList;
import java.util.List;
import okhttp3.Call;
import okhttp3.Request;
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 RecyclerViewAdapter recyclerViewAdapter;
private RecyclerView recyclerView;
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);
recyclerView=findViewById(R.id.recyclerview);
// 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);
recyclerViewAdapter=new RecyclerViewAdapter(OKHttpListActivity.this,datas);
recyclerView.setLayoutManager(new LinearLayoutManager(OKHttpListActivity.this, LinearLayoutManager.VERTICAL, false));
recyclerView.setAdapter(recyclerViewAdapter);
// 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"); //第一层解析,获取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); //DataBean.ItemData
}
}
}
} catch (JSONException e) {
e.printStackTrace();
}
return dataBean;
}
}
Glide使用
//加载图片
Glide.with(MainActivity.this).load(url).into(iv);
本demo对于Glide的使用还是很简单的,推荐一个大神写的Glide使用
https://blog.csdn.net/qq_32368129/article/details/69526148
好了,到这里本demo就此结束,完结撒花。