xUtils 获取网络数据 + RecycleView 显示数据+ F resco 加载图片 + ButterKnife 初始化控件

本文主要是介绍xUtils 获取网络数据 + RecycleView 显示数据+ F resco 加载图片 + ButterKnife 初始化控件,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

导入 xUtils 和 gson 的jar包

导入依赖

compile 'com.android.support:recyclerview-v7:25.3.1'
compile 'com.jakewharton:butterknife:8.8.1'
compile 'com.jakewharton:butterknife-compiler:8.8.1'
compile 'com.facebook.fresco:fresco:1.5.0'

页面

     activity_main.xml

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    tools:context="bw.com.week2_test.MainActivity">

    <android.support.v7.widget.RecyclerView
        android:layout_width="match_parent"
        android:layout_height="match_parent"
       android:id="@+id/rv_id" />

</LinearLayout>
item_rv.xml

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:fresco="http://schemas.android.com/apk/res-auto"
    android:orientation="vertical"
    android:layout_width="match_parent"
    android:layout_height="wrap_content">

    <!--
         fresco:placeholderImage="@mipmap/ic_launcher"  占位图片
         fresco:roundAsCircle="false"   //设置圆形图片

          fresco:roundedCornerRadius="1dp" 设置圆角的度数
          fresco:roundTopLeft="true"   左上角是否为圆形
          fresco:roundTopRight="false"
          fresco:roundBottomLeft="false"
          fresco:roundBottomRight="true"

         fresco:roundWithOverlayColor="@color/colorAccent"  填充颜色
        fresco:roundingBorderWidth="20dp" 边界线的宽度
        fresco:roundingBorderColor="@color/colorPrimary"  边界线的颜色
    -->
    <com.facebook.drawee.view.SimpleDraweeView
        android:layout_width="300dp"
        android:layout_height="200dp"
        android:id="@+id/iv_id"
        fresco:placeholderImage="@mipmap/ic_launcher"
        fresco:roundAsCircle="false" />

    <TextView
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:id="@+id/tv_id"
        android:text="标题"
        android:textSize="20sp"
        />

    <View
        android:layout_width="match_parent"
        android:layout_height="2dp"
        android:background="@color/colorAccent"
        android:layout_margin="10dp"
        />

</LinearLayout>
代码

   MyApp.java

public class MyApp extends Application {@Override
    public void onCreate() {super.onCreate();
        //初始化xUtils
        x.Ext.init(this);
        x.Ext.setDebug(true);

        //初始化Fresco
        Fresco.initialize(this);
    }
}
清单文件中:AndroidManifest.xml

<uses-permission android:name="android.permission.INTERNET"/>
<uses-permission android:name="android.permission.READ_EXTERNAL_STORAGE"/>
<uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE"/>

<application
    android:name=".MyApp"

MainActivity.java

public class MainActivity extends AppCompatActivity {@BindView(value = R.id.rv_id)RecyclerView mRv;

    private List<VMoiver.DataBean> data;
    private RecycleAdapter adapter;

    private Unbinder unbinder;

    private String path = "http://app.vmoiver.com/apiv3/post/getPostInCate?cateid=0&p=1";


    @Override
    protected void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);

        //绑定ButterKnife
        unbinder = ButterKnife.bind(this);

        //设置RecycleView展示的方式
        LinearLayoutManager manager = new LinearLayoutManager(this,LinearLayoutManager.VERTICAL,false);
        mRv.setLayoutManager(manager);

        //通过xUtils获取数据
        RequestParams params = new RequestParams(path);
        x.http().get(params, new Callback.CommonCallback<String>() {@Override
            public void onSuccess(String s) {//解析数据, 得到数据源
                VMoiver vMoiver = new Gson().fromJson(s,VMoiver.class);
                data = vMoiver.getData();

                //初始化适配器
                adapter = new RecycleAdapter(MainActivity.this,data);
                mRv.setAdapter(adapter);

            }@Override
            public void onError(Throwable throwable, boolean b) {}@Override
            public void onCancelled(CancelledException e) {}@Override
            public void onFinished() {}});



    }@Override
    protected void onDestroy() {super.onDestroy();
        //解绑
        unbinder.unbind();
    }
}

RecycleActivity.java

public class RecycleAdapter extends RecyclerView.Adapter<RecycleAdapter.ViewHolder> {private Context context;
    private List<VMoiver.DataBean> data;

    public RecycleAdapter(Context context,List<VMoiver.DataBean> data){this.context = context;
        this.data = data;
    }@Override
    public ViewHolder onCreateViewHolder(ViewGroup parent, int viewType) {//TODO 绑定页面
        View view = LayoutInflater.from(context).inflate(R.layout.item_rv,parent,false);
        ViewHolder viewHolder = new ViewHolder(view);
        return viewHolder;
    }@Override
    public void onBindViewHolder(ViewHolder holder, int position) {holder.tv.setText(data.get(position).getTitle());

        //Fresco 加载图片
        Uri uri = Uri.parse(data.get(position).getImage());
        holder.sdv.setImageURI(uri);
    }@Override
    public int getItemCount() {return data.size();
    }class  ViewHolder extends RecyclerView.ViewHolder{//使用ButterKnife注解
        @BindView(R.id.iv_id)SimpleDraweeView sdv;
        @BindView(R.id.tv_id)TextView tv;

        public ViewHolder(View itemView) {super(itemView);
            //绑定
            ButterKnife.bind(this,itemView);
        }}
}
VMoiver.java   ------ GsonFormat 生成的实体类

这篇关于xUtils 获取网络数据 + RecycleView 显示数据+ F resco 加载图片 + ButterKnife 初始化控件的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/379887

相关文章

JVM 的类初始化机制

前言 当你在 Java 程序中new对象时,有没有考虑过 JVM 是如何把静态的字节码(byte code)转化为运行时对象的呢,这个问题看似简单,但清楚的同学相信也不会太多,这篇文章首先介绍 JVM 类初始化的机制,然后给出几个易出错的实例来分析,帮助大家更好理解这个知识点。 JVM 将字节码转化为运行时对象分为三个阶段,分别是:loading 、Linking、initialization

大模型研发全揭秘:客服工单数据标注的完整攻略

在人工智能(AI)领域,数据标注是模型训练过程中至关重要的一步。无论你是新手还是有经验的从业者,掌握数据标注的技术细节和常见问题的解决方案都能为你的AI项目增添不少价值。在电信运营商的客服系统中,工单数据是客户问题和解决方案的重要记录。通过对这些工单数据进行有效标注,不仅能够帮助提升客服自动化系统的智能化水平,还能优化客户服务流程,提高客户满意度。本文将详细介绍如何在电信运营商客服工单的背景下进行

基于MySQL Binlog的Elasticsearch数据同步实践

一、为什么要做 随着马蜂窝的逐渐发展,我们的业务数据越来越多,单纯使用 MySQL 已经不能满足我们的数据查询需求,例如对于商品、订单等数据的多维度检索。 使用 Elasticsearch 存储业务数据可以很好的解决我们业务中的搜索需求。而数据进行异构存储后,随之而来的就是数据同步的问题。 二、现有方法及问题 对于数据同步,我们目前的解决方案是建立数据中间表。把需要检索的业务数据,统一放到一张M

关于数据埋点,你需要了解这些基本知识

产品汪每天都在和数据打交道,你知道数据来自哪里吗? 移动app端内的用户行为数据大多来自埋点,了解一些埋点知识,能和数据分析师、技术侃大山,参与到前期的数据采集,更重要是让最终的埋点数据能为我所用,否则可怜巴巴等上几个月是常有的事。   埋点类型 根据埋点方式,可以区分为: 手动埋点半自动埋点全自动埋点 秉承“任何事物都有两面性”的道理:自动程度高的,能解决通用统计,便于统一化管理,但个性化定

使用SecondaryNameNode恢复NameNode的数据

1)需求: NameNode进程挂了并且存储的数据也丢失了,如何恢复NameNode 此种方式恢复的数据可能存在小部分数据的丢失。 2)故障模拟 (1)kill -9 NameNode进程 [lytfly@hadoop102 current]$ kill -9 19886 (2)删除NameNode存储的数据(/opt/module/hadoop-3.1.4/data/tmp/dfs/na

异构存储(冷热数据分离)

异构存储主要解决不同的数据,存储在不同类型的硬盘中,达到最佳性能的问题。 异构存储Shell操作 (1)查看当前有哪些存储策略可以用 [lytfly@hadoop102 hadoop-3.1.4]$ hdfs storagepolicies -listPolicies (2)为指定路径(数据存储目录)设置指定的存储策略 hdfs storagepolicies -setStoragePo

Hadoop集群数据均衡之磁盘间数据均衡

生产环境,由于硬盘空间不足,往往需要增加一块硬盘。刚加载的硬盘没有数据时,可以执行磁盘数据均衡命令。(Hadoop3.x新特性) plan后面带的节点的名字必须是已经存在的,并且是需要均衡的节点。 如果节点不存在,会报如下错误: 如果节点只有一个硬盘的话,不会创建均衡计划: (1)生成均衡计划 hdfs diskbalancer -plan hadoop102 (2)执行均衡计划 hd

第10章 中断和动态时钟显示

第10章 中断和动态时钟显示 从本章开始,按照书籍的划分,第10章开始就进入保护模式(Protected Mode)部分了,感觉从这里开始难度突然就增加了。 书中介绍了为什么有中断(Interrupt)的设计,中断的几种方式:外部硬件中断、内部中断和软中断。通过中断做了一个会走的时钟和屏幕上输入字符的程序。 我自己理解中断的一些作用: 为了更好的利用处理器的性能。协同快速和慢速设备一起工作

使用opencv优化图片(画面变清晰)

文章目录 需求影响照片清晰度的因素 实现降噪测试代码 锐化空间锐化Unsharp Masking频率域锐化对比测试 对比度增强常用算法对比测试 需求 对图像进行优化,使其看起来更清晰,同时保持尺寸不变,通常涉及到图像处理技术如锐化、降噪、对比度增强等 影响照片清晰度的因素 影响照片清晰度的因素有很多,主要可以从以下几个方面来分析 1. 拍摄设备 相机传感器:相机传

【Prometheus】PromQL向量匹配实现不同标签的向量数据进行运算

✨✨ 欢迎大家来到景天科技苑✨✨ 🎈🎈 养成好习惯,先赞后看哦~🎈🎈 🏆 作者简介:景天科技苑 🏆《头衔》:大厂架构师,华为云开发者社区专家博主,阿里云开发者社区专家博主,CSDN全栈领域优质创作者,掘金优秀博主,51CTO博客专家等。 🏆《博客》:Python全栈,前后端开发,小程序开发,人工智能,js逆向,App逆向,网络系统安全,数据分析,Django,fastapi