Fresco,Retrofit 和 RecyclerView 实现瀑布流
2016-03-15 22:36
465 查看
代码 :网络图片RecyclerView瀑布流的实现
图片是通过Retrofit进行网络请求得到的地址
RecyclerView的使用分为四步
0:导入RecyclerView和例如Fresco,Retrofit,然后在代码里面添加RecyclerView
1:然后是设置每个项的布局和实体类,
2:创建RecyclerView的Adapter,当然要先在里面创建ViewHolder
3:在主函数中设置数据,设置LayoutMananger以及ItemDecrator,
+++++++++++++++++++++++++++++++++++++++++++++++++++++
但是这里的数据是从网络来的所以会多一步,网络请求HttpUtils的创建,这个是通过Retrofit 来实现的。
Retrofit 就是将网址变成接口的形式。
0:首先导入RecyclerView,Fresco,和Retrofit,记住这个Retrofit 一定要是com.squareup.retrofit2:converter-gson:2.0.0-beta4
在布局里面添加RecyclerView
1:然后是设置每个项的布局和实体类,
创建每个项的布局:
然后新建MyApplication,
修改清单文件,添加这个name,然后再添加网络权限
创建一个新的实体类ProductEntity
然后在浏览器输入下面的网址
得到json的数据,(前提是浏览器已经安装了JSONView的插件,如果没有请查看JSONView
插件的添加。给Chrom浏览器添加JSONView的插件)
然后在AndroidStudio中,使用GsonFormat 直接生成这个ProductEntity的内部信息。
2:创建RecyclerView的Adapter,当然要先在里面创建ViewHolder
3:网络请求HttpUtils的创建,这个是通过Retrofit 来实现的。
4: 在主函数中设置数据,设置LayoutMananger以及ItemDecrator,
首先创建自己的 ItemDecrator
MainActivity 里面设置LayoutManager等以及网络请求等。
图片是通过Retrofit进行网络请求得到的地址
RecyclerView的使用分为四步
0:导入RecyclerView和例如Fresco,Retrofit,然后在代码里面添加RecyclerView
1:然后是设置每个项的布局和实体类,
2:创建RecyclerView的Adapter,当然要先在里面创建ViewHolder
3:在主函数中设置数据,设置LayoutMananger以及ItemDecrator,
+++++++++++++++++++++++++++++++++++++++++++++++++++++
但是这里的数据是从网络来的所以会多一步,网络请求HttpUtils的创建,这个是通过Retrofit 来实现的。
Retrofit 就是将网址变成接口的形式。
0:首先导入RecyclerView,Fresco,和Retrofit,记住这个Retrofit 一定要是com.squareup.retrofit2:converter-gson:2.0.0-beta4
在布局里面添加RecyclerView
<?xml version="1.0" encoding="utf-8"?> <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns:tools="http://schemas.android.com/tools" android:layout_width="match_parent" android:layout_height="match_parent" android:paddingLeft="@dimen/activity_horizontal_margin" android:paddingRight="@dimen/activity_horizontal_margin" android:paddingTop="@dimen/activity_vertical_margin" android:paddingBottom="@dimen/activity_vertical_margin" tools:context=".MainActivity"> <android.support.v7.widget.RecyclerView android:layout_width="match_parent" android:layout_height="match_parent" android:id="@+id/recyclerview"/> </RelativeLayout>
1:然后是设置每个项的布局和实体类,
创建每个项的布局:
<?xml version="1.0" encoding="utf-8"?> <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" android:orientation="vertical" android:layout_width="match_parent" android:layout_height="match_parent"> <com.facebook.drawee.view.SimpleDraweeView android:layout_width="match_parent" android:layout_height="wrap_content" android:id="@+id/item_simpledraweeview"></com.facebook.drawee.view.SimpleDraweeView> <TextView android:layout_width="wrap_content" android:layout_height="wrap_content" android:id="@+id/item_description"/> </LinearLayout>
然后新建MyApplication,
public class MyApplication extends Application { @Override public void onCreate() { super.onCreate(); Fresco.initialize(this); } }
修改清单文件,添加这个name,然后再添加网络权限
<?xml version="1.0" encoding="utf-8"?> <manifest xmlns:android="http://schemas.android.com/apk/res/android" package="tech.androidstudio.recyclerviewhttpdemo" > <uses-permission android:name="android.permission.INTERNET"/> <application android:allowBackup="true" android:icon="@mipmap/ic_launcher" android:label="@string/app_name" android:supportsRtl="true" android:theme="@style/AppTheme" android:name=".MyApplication"> <activity android:name=".MainActivity" > <intent-filter> <action android:name="android.intent.action.MAIN" /> <category android:name="android.intent.category.LAUNCHER" /> </intent-filter> </activity> </application> </manifest>
创建一个新的实体类ProductEntity
然后在浏览器输入下面的网址
http://app.u17.com/v3/app/android/phone/list/index?size=40&page=1&argName=theme&argValue=9&con=3&t=1452669865&v=2250099&android_id=d8601b468f8b27e5&key=null&come_from=MEIZU&model=MX4+Pro
得到json的数据,(前提是浏览器已经安装了JSONView的插件,如果没有请查看JSONView
插件的添加。给Chrom浏览器添加JSONView的插件)
然后在AndroidStudio中,使用GsonFormat 直接生成这个ProductEntity的内部信息。
package tech.androidstudio.recyclerviewhttpdemo.entity; import java.util.List; /** * Created by Kodulf on 2016/3/15. */ public class ProductEntity { private DataEntity data; public void setCode(int code) { this.code = code; } public void setMsg(String msg) { this.msg = msg; } public void setData(DataEntity data) { this.data = data; } public int getCode() { return code; } public String getMsg() { return msg; } public DataEntity getData() { return data; } public static class DataEntity { private int stateCode; private String message; private List<ReturnDataEntity> returnData; public void setStateCode(int stateCode) { this.stateCode = stateCode; } public void setMessage(String message) { this.message = message; } public void setReturnData(List<ReturnDataEntity> returnData) { this.returnData = returnData; } public int getStateCode() { return stateCode; } public String getMessage() { return message; } public List<ReturnDataEntity> getReturnData() { return returnData; } public static class ReturnDataEntity { private int comic_id; private String name; private String cover; private int accredit; private int last_update_time; private String last_update_chapter_name; private String description; private int user_id; private String nickname; private String series_status; private String theme_ids; private String is_vip; private String chapter_num; private String last_update_chapter_id; private int is_dujia; private int is_free; private String extraValue; private String click_total; private List<String> tags; public void setComic_id(int comic_id) { this.comic_id = comic_id; } public void setName(String name) { this.name = name; } public void setCover(String cover) { this.cover = cover; } public void setAccredit(int accredit) { this.accredit = accredit; } public void setLast_update_time(int last_update_time) { this.last_update_time = last_update_time; } public void setLast_update_chapter_name(String last_update_chapter_name) { this.last_update_chapter_name = last_update_chapter_name; } public void setDescription(String description) { this.description = description; } public void setUser_id(int user_id) { this.user_id = user_id; } public void setNickname(String nickname) { this.nickname = nickname; } public void setSeries_status(String series_status) { this.series_status = series_status; } public void setTheme_ids(String theme_ids) { this.theme_ids = theme_ids; } public void setIs_vip(String is_vip) { this.is_vip = is_vip; } public void setChapter_num(String chapter_num) { this.chapter_num = chapter_num; } public void setLast_update_chapter_id(String last_update_chapter_id) { this.last_update_chapter_id = last_update_chapter_id; } public void setIs_dujia(int is_dujia) { this.is_dujia = is_dujia; } public void setIs_free(int is_free) { this.is_free = is_free; } public void setExtraValue(String extraValue) { this.extraValue = extraValue; } public void setClick_total(String click_total) { this.click_total = click_total; } public void setTags(List<String> tags) { this.tags = tags; } public int getComic_id() { return comic_id; } public String getName() { return name; } public String getCover() { return cover; } public int getAccredit() { return accredit; } public int getLast_update_time() { return last_update_time; } public String getLast_update_chapter_name() { return last_update_chapter_name; } public String getDescription() { return description; } public int getUser_id() { return user_id; } public String getNickname() { return nickname; } public String getSeries_status() { return series_status; } public String getTheme_ids() { return theme_ids; } public String getIs_vip() { return is_vip; } public String getChapter_num() { return chapter_num; } public String getLast_update_chapter_id() { return last_update_chapter_id; } public int getIs_dujia() { return is_dujia; } public int getIs_free() { return is_free; } public String getExtraValue() { return extraValue; } public String getClick_total() { return click_total; } public List<String> getTags() { return tags; } } } }
2:创建RecyclerView的Adapter,当然要先在里面创建ViewHolder
package tech.androidstudio.recyclerviewhttpdemo.adaptetr; import android.content.Context; import android.net.Uri; import android.support.v7.widget.RecyclerView; import android.view.LayoutInflater; import android.view.View; import android.view.ViewGroup; import android.widget.TextView; import com.facebook.drawee.drawable.ScalingUtils; import com.facebook.drawee.view.SimpleDraweeView; import java.util.Collection; import java.util.List; import tech.androidstudio.recyclerviewhttpdemo.R; import tech.androidstudio.recyclerviewhttpdemo.entity.ProductEntity; /** * Created by Kodulf on 2016/3/15. */ public class PicRecyclerViewAdapter extends RecyclerView.Adapter<PicRecyclerViewAdapter.PicViewHolder> { List<ProductEntity.DataEntity.ReturnDataEntity> list; Context context; public PicRecyclerViewAdapter(List<ProductEntity.DataEntity.ReturnDataEntity> list, Context context) { this.list = list; this.context=context; } //这里的返回值ret里面的布局就是每一项的布局 @Override public PicViewHolder onCreateViewHolder(ViewGroup parent, int viewType) { View ret = LayoutInflater.from(context).inflate(R.layout.item_layout,parent,false); return new PicViewHolder(ret); } @Override public void onBindViewHolder(PicViewHolder holder, int position) { ProductEntity.DataEntity.ReturnDataEntity returnDataEntity = list.get(position); holder.simpleDraweeView.setImageURI(Uri.parse(returnDataEntity.getCover())); holder.textView.setText(returnDataEntity.getDescription()); } @Override public int getItemCount() { return list.size(); } //通过这个来进行数据的添加 public void addAll(Collection<? extends ProductEntity.DataEntity.ReturnDataEntity> collection){ int size = list.size(); list.addAll(collection); notifyItemRangeChanged(size,collection.size()); } //必须首先创建这个ViewHolder,才能够创建RecyclerView.Adapter public class PicViewHolder extends RecyclerView.ViewHolder{ public SimpleDraweeView simpleDraweeView; public TextView textView; public PicViewHolder(View itemView) { super(itemView); simpleDraweeView=(SimpleDraweeView)itemView.findViewById(R.id.item_simpledraweeview); //设置宽高比例 simpleDraweeView.setAspectRatio(0.9f); //设置对其方式 simpleDraweeView.getHierarchy().setActualImageScaleType(ScalingUtils.ScaleType.FIT_CENTER); textView=(TextView)itemView.findViewById(R.id.item_description); } } }
3:网络请求HttpUtils的创建,这个是通过Retrofit 来实现的。
package tech.androidstudio.recyclerviewhttpdemo.utils;
import java.util.Map;
import retrofit2.Call;
import retrofit2.Retrofit;
import retrofit2.converter.gson.GsonConverterFactory;
import retrofit2.http.GET;
import retrofit2.http.QueryMap;
import tech.androidstudio.recyclerviewhttpdemo.entity.ProductEntity;
/**
* Created by Kodulf on 2016/3/15.
*/
public class HttpUtils {
//http://app.u17.com/v3/app/android/phone/list/index?size=40&page=1&argName=theme&argValue=9&con=3&t=1452669865&v=2250099&android_id=d8601b468f8b27e5&key=null&come_from=MEIZU&model=MX4+Propublic interface ProductService {
@GET("v3/app/android/phone/list/index?size=40")
Call<ProductEntity> getLeiBieDetail(@QueryMap Map<String,String> options);
}
private static ProductService productService;
static{
productService = new Retrofit.Builder()
.baseUrl("http://app.u17.com/")
.addConverterFactory(GsonConverterFactory.create())
.build()
.create(ProductService.class);
}
public static ProductService getLeiBieXiJiService(){
return productService;
}
}
4: 在主函数中设置数据,设置LayoutMananger以及ItemDecrator,
首先创建自己的 ItemDecrator
package tech.androidstudio.recyclerviewhttpdemo; import android.graphics.Rect; import android.support.v7.widget.RecyclerView; import android.view.View; /** * Created by Kodulf on 2016/3/15. */ public class MyItemDecorator extends RecyclerView.ItemDecoration { private int space; public MyItemDecorator(int space) { this.space = space; } //设置上下左右的间距,第一行是没有top上的间距的 @Override public void getItemOffsets(Rect outRect, View view, RecyclerView parent, RecyclerView.State state) { // super.getItemOffsets(outRect, view, parent, state);state outRect.bottom=space; outRect.right=space; outRect.left=space; if(parent.getChildPosition(view)!=0){ outRect.top=space; } } }
MainActivity 里面设置LayoutManager等以及网络请求等。
package tech.androidstudio.recyclerviewhttpdemo;
import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.support.v7.widget.RecyclerView;
import android.support.v7.widget.StaggeredGridLayoutManager;
import android.util.Log;
import android.widget.Toast;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import retrofit2.Call;
import retrofit2.Callback;
import retrofit2.Response;
import tech.androidstudio.recyclerviewhttpdemo.adaptetr.PicRecyclerViewAdapter;
import tech.androidstudio.recyclerviewhttpdemo.entity.ProductEntity;
import tech.androidstudio.recyclerviewhttpdemo.utils.HttpUtils;
public class MainActivity extends AppCompatActivity implements Callback<ProductEntity> {
private ArrayList<ProductEntity.DataEntity.ReturnDataEntity> mList;
private RecyclerView mRecyclerView;
private PicRecyclerViewAdapter mAdapter;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
mList = new ArrayList<ProductEntity.DataEntity.ReturnDataEntity>();
mAdapter = new PicRecyclerViewAdapter(mList,this);
mRecyclerView = (RecyclerView)findViewById(R.id.recyclerview);
mRecyclerView.setLayoutManager(new StaggeredGridLayoutManager(2, StaggeredGridLayoutManager.VERTICAL));
//设置上下左右的空格
MyItemDecorator myItemDecorator=new MyItemDecorator(10);
mRecyclerView.addItemDecoration(myItemDecorator);
mRecyclerView.setAdapter(mAdapter);
//http://app.u17.com/v3/app/android/phone/list/index?size=40&page=1&argName=theme&argValue=9&con=3&t=1452669865&v=2250099&android_id=d8601b468f8b27e5&key=null&come_from=MEIZU&model=MX4+ProHashMap<String,String> map = new HashMap<String,String>();
map.put("page","1");
map.put("argName","theme");
map.put("argValue","9");
map.put("con","3");
map.put("t","1452669865");
//网络请求
HttpUtils.getLeiBieXiJiService().getLeiBieDetail(map).enqueue(this);
}
//网络请求成功
@Override
public void onResponse(Call<ProductEntity> call, Response<ProductEntity> response) {
Log.d("Kodulf","Successful");
Toast.makeText(this, "Successful", Toast.LENGTH_LONG).show();
List<ProductEntity.DataEntity.ReturnDataEntity> list = response.body().getData().getReturnData();
mAdapter.addAll(list);
}
//网络请求失败
@Override
public void onFailure(Call<ProductEntity> call, Throwable t) {
Log.d("Kodulf","Failed");
Toast.makeText(this,"Failed",Toast.LENGTH_LONG).show();
}
}
相关文章推荐
- AngularJS实现鼠标右键事件
- C++基础::mutable 关键字
- 高性能平台上提交任务的两种方式
- Java中implements和extends的小记
- java数据结构与算法分析之递归
- android内存优化工具篇之MAT
- 7.投票系统(1)
- EXCEL导入数据到mysql
- Bzoj 1703: [Usaco2007 Mar]Ranking the Cows 奶牛排名 传递闭包,bitset
- Eclipse将android项目打包jar文件
- Eclipse常用快捷键汇总(转)
- Range Sum Query - Immutable
- 多字符集和编码格式
- Android双缓冲技术
- 状态模式
- C语言关键字 - 铁布衫:const 转载
- GCD深入了解
- PythonChallenge Mission 13
- Shader and Program编程基本概念
- RHEL6.5下更新python至2.7版本