Android使用RecyclerView实现瀑布流

private boolean isVertical = true;

public void setIsVertical(boolean isVertical) {

this.isVertical = isVertical;

}

public StaggeredAdapter(Context context, List datas) {

super(context, datas);

//设置竖直瀑布流的height集合值:

//设置水平瀑布流的height集合值:

mWidths = new HashMap<Integer,Integer>();

mHeights = new HashMap<Integer,Integer>();

onDataChanged();

}

//设置水平瀑布流的height集合值: 如果有该值 则不重复创建

private void setStaggeredWidth() {

if (null != mDatas && 0 != mDatas.size()){

for(int i=0;i<mDatas.size();i++){

if(null==mWidths.get(mDatas.get(i).id)){

mWidths.put(mDatas.get(i).id,(int)(100 + Math.random() * 300));

}

}

}

}

//设置竖直瀑布流的height集合值:

private void setStaggeredHeight() {

Log.i(TAG,“setStaggeredHeight()”);

if (null != mDatas && 0 != mDatas.size()){

Log.i(TAG,“null != mDatas && 0 != mDatas.size()()”);

for(int i=0;i<mDatas.size();i++){

Log.i(TAG,“mHeights.get(mDatas.get(i).id):”+mHeights.get(mDatas.get(i).id));

if(null==mHeights.get(mDatas.get(i).id)){

Log.i(TAG,“null!=mHeights.get(mDatas.get(i).id)”);

mHeights.put(mDatas.get(i).id, (int) (100 + Math.random() * 300));

}

}

}

}

//数据改变后要执行的操作的封装 b

public void onDataChanged(){

//设置竖直瀑布流的height集合值:

setStaggeredHeight();

//设置水平瀑布流的height集合值:

setStaggeredWidth();

}

@Override

public MyViewHolder onCreateViewHolder(ViewGroup viewGroup, int i) {

Log.i(TAG, “onCreateViewHolder:”+i);

View v = mInflater.inflate(R.layout.item_staggered, viewGroup, false);

/*//瀑布流 错误写法  因为每次都会onbindviewholder 但不是每次都是create

ViewGroup.LayoutParams params = v.getLayoutParams();

params.height = mHeights.get(i);

v.setLayoutParams(params);

//瀑布流*/

return new MyViewHolder(v);

}

@Override

public void onBindViewHolder(MyViewHolder viewHolder, int i) {

super.onBindViewHolder(viewHolder,i);

Log.i(TAG, “onBindViewHolder:” + i);

//竖直瀑布流

if(isVertical){

ViewGroup.LayoutParams params = viewHolder.itemView.getLayoutParams();

int temp = mDatas.get(i).id;

Log.i(TAG, “temp:” + temp +“mHeights:”+mHeights);

int temp2 =  mHeights.get(temp);

params.height =temp2;

viewHolder.itemView.setLayoutParams(params);

}

//竖直瀑布流

//水平瀑布流

else{

ViewGroup.LayoutParams params = viewHolder.itemView.getLayoutParams();

params.width = mWidths.get(mDatas.get(i).id);

viewHolder.itemView.setLayoutParams(params);

}

//水平瀑布流

}

//重写父类 否则增加后会越界异常

@Override

public void addData(int pos, DataBean data) {

super.addData(pos, data);

onDataChanged();

}

@Override

public void removeData(int pos) {

super.removeData(pos);

onDataChanged();

}

}

Activity:

package com.mcxtzhang.demo;

import android.os.Bundle;

import android.support.v7.app.AppCompatActivity;

import android.support.v7.widget.DefaultItemAnimator;

import android.support.v7.widget.RecyclerView;

import android.support.v7.widget.StaggeredGridLayoutManager;

import android.view.Menu;

import android.view.MenuItem;

import android.view.View;

import android.widget.Toast;

import java.util.ArrayList;

import java.util.List;

public class StaggeredActivity extends AppCompatActivity {

private RecyclerView mRecyclerView;

private List mDatas;

private StaggeredAdapter mAdapter;

@Override

protected void onCreate(Bundle savedInstanceState) {

super.onCreate(savedInstanceState);

setContentView(R.layout.activity_main);

initDatas();

initViews();

}

private void initViews() {

mRecyclerView = (RecyclerView) findViewById(R.id.recyclerview);

mAdapter = new StaggeredAdapter(StaggeredActivity.this,mDatas);

mRecyclerView.setAdapter(mAdapter);

//设置REcyclerVIew布局管理

//三个参数context,水平/竖直排列数据 ,是否反向显示。

/*RecyclerView.LayoutManager layoutManager = new LinearLayoutManager(StaggeredActivity.this, LinearLayoutManager.VERTICAL, true);

mRecyclerView.setLayoutManager(layoutManager);*/

//设置RecyclerView的Item分割线

//想改变分割线的样式 ,要定义一个drawable,然后在style里覆盖android:listDivider 属性

//mRecyclerView.addItemDecoration(new DividerItemDecoration(MainActivity.this, DividerItemDecoration.VERTICAL_LIST));

//瀑布流

mRecyclerView.setLayoutManager(new StaggeredGridLayoutManager(3,StaggeredGridLayoutManager.VERTICAL));

//设置动画

mRecyclerView.setItemAnimator(new DefaultItemAnimator());

//设置点击事件

mAdapter.setOnClickEventListener(new MyAdapter.onClickEventListener() {

@Override

public void onClickListener(View v, int pos) {

Toast.makeText(StaggeredActivity.this, “pos:” + pos, Toast.LENGTH_SHORT).show();

}

@Override

public void onLongClickListener(View v, int pos) {

Toast.makeText(StaggeredActivity

.this,“long pos:”+pos,Toast.LENGTH_SHORT).show();

mAdapter.removeData(pos);

}

});

自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。

深知大多数初中级Android工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则近万的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

因此收集整理了一份《2024年Android移动开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。

img

img

img

img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Android开发知识点,真正体系化!

由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!

如果你觉得这些内容对你有帮助,可以扫码获取!!(备注:Android)

如何做好面试突击,规划学习方向?

面试题集可以帮助你查漏补缺,有方向有针对性的学习,为之后进大厂做准备。但是如果你仅仅是看一遍,而不去学习和深究。那么这份面试题对你的帮助会很有限。最终还是要靠资深技术水平说话。

网上学习 Android的资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。建议先制定学习计划,根据学习计划把知识点关联起来,形成一个系统化的知识体系。

学习方向很容易规划,但是如果只通过碎片化的学习,对自己的提升是很慢的。

我搜集整理过这几年字节跳动,以及腾讯,阿里,华为,小米等公司的面试题,把面试的要求和技术点梳理成一份大而全的“ Android架构师”面试 Xmind(实际上比预期多花了不少精力),包含知识脉络 + 分支细节

img

在搭建这些技术框架的时候,还整理了系统的高级进阶教程,会比自己碎片化学习效果强太多。

网上学习 Android的资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。希望这份系统化的技术体系对大家有一个方向参考。

《互联网大厂面试真题解析、进阶开发核心学习笔记、全套讲解视频、实战项目源码讲义》点击传送门即可获取!

在搭建这些技术框架的时候,还整理了系统的高级进阶教程,会比自己碎片化学习效果强太多。

网上学习 Android的资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。希望这份系统化的技术体系对大家有一个方向参考。

《互联网大厂面试真题解析、进阶开发核心学习笔记、全套讲解视频、实战项目源码讲义》点击传送门即可获取!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值