Android-->RecyclerView的上手教程(模仿画廊效果)

效果图:

这里写图片描述

考虑到图片体积, 上一个和下一个的按钮,没有截图出来.


RecyclerView使用教程

1:创建RecyclerView,也可以在布局中创建

recyclerView = new RecyclerView(this);

2:创建LinearLayoutManager对象,这个对象可以设置 垂直和水平滚动的方向

manager = new LinearLayoutManager(this);
manager.setOrientation(LinearLayoutManager.HORIZONTAL);//设置方向为横向

3:创建一个RecyclerView.ViewHolder对象,用来保存每个Item的View对象

public final class MyViewHolder extends RecyclerView.ViewHolder {

    public ImageView img;//我这里只有一张图片

    public MyViewHolder(View itemView) {
        img = (ImageView) itemView;
    }

}

4:创建一个RecyclerView.Adapter<ViewHolder>对象

public class MyAdapter extends RecyclerView.Adapter<ViewHolder> {

    @Override
    public int getItemCount() {//返回item的数量
        return imgs.length;
    }

    @Override
    public void onBindViewHolder(//这里设置Item中View的值
            android.support.v7.widget.RecyclerView.ViewHolder arg0, int arg1) {

        ((MyViewHolder) arg0).img.setImageResource(imgs[arg1]);

    }

    @Override
    public android.support.v7.widget.RecyclerView.ViewHolder onCreateViewHolder(
            ViewGroup arg0, int arg1) {//创建Item的View,并交给ViewHolder管理
        ImageView img = new ImageView(MainActivity.this);
        img.setLayoutParams(new LayoutParams(getWidth(), 400));

        return new MyViewHolder(img);
    }
}

5:最后一步:

adapter = new MyAdapter();
recyclerView.setLayoutManager(manager);//关联布局管理,水平方向或者垂直方向
recyclerView.setAdapter(adapter);//关联数据,需要展示的数据

源代码下载: http://download.csdn.net/detail/angcyo/8792845

源码:

public class MainActivity extends ActionBarActivity {

    RecyclerView recyclerView;
    LinearLayoutManager manager;
    RecyclerView.Adapter adapter;
    RelativeLayout rootView;

    int[] imgs = new int[] { R.drawable.dvd_decrypter, R.drawable.eac,
            R.drawable.elo, R.drawable.norton_alt, R.drawable.elo_alt2,
            R.drawable.elster_formular, R.drawable.eset_endpoint_security };

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        rootView = (RelativeLayout) findViewById(R.id.root);

        recyclerView = new RecyclerView(this);
        recyclerView.setHasFixedSize(true);
        manager = new LinearLayoutManager(this);
        manager.setOrientation(LinearLayoutManager.HORIZONTAL);

        adapter = new MyAdapter();
        recyclerView.setLayoutManager(manager);
        recyclerView.setAdapter(adapter);

        recyclerView.setBackgroundColor(Color.parseColor("#3E3E3E"));

        RelativeLayout.LayoutParams params = new LayoutParams(
                LayoutParams.MATCH_PARENT, 400);
        rootView.addView(recyclerView, params);
        recyclerView.addOnScrollListener(new OnScrollListener() {
            @Override
            public void onScrollStateChanged(RecyclerView recyclerView,
                    int newState) {
                super.onScrollStateChanged(recyclerView, newState);
                if (newState == RecyclerView.SCROLL_STATE_IDLE) {
                    int width = getWidth() / 2; // 图片的一半宽
                    int offset = recyclerView.computeHorizontalScrollOffset()
                            % getWidth() > width ? getWidth()
                            - recyclerView.computeHorizontalScrollOffset()
                            % getWidth() : -recyclerView
                            .computeHorizontalScrollOffset() % getWidth();

                    recyclerView.smoothScrollBy(offset, 0);
                }
            }

            @Override
            public void onScrolled(RecyclerView recyclerView, int dx, int dy) {
                super.onScrolled(recyclerView, dx, dy);

                // Log.e(dx + "", dy + "");
            }
        });
    }

    public final class MyViewHolder extends RecyclerView.ViewHolder {

        public ImageView img;

        public MyViewHolder(View itemView) {
            super(itemView);
            img = (ImageView) itemView;
        }

    }

    public class MyAdapter extends RecyclerView.Adapter<ViewHolder> {

        @Override
        public int getItemCount() {
            return imgs.length;
        }

        @Override
        public void onBindViewHolder(
                android.support.v7.widget.RecyclerView.ViewHolder arg0, int arg1) {

            ((MyViewHolder) arg0).img.setImageResource(imgs[arg1]);

        }

        @Override
        public android.support.v7.widget.RecyclerView.ViewHolder onCreateViewHolder(
                ViewGroup arg0, int arg1) {
            ImageView img = new ImageView(MainActivity.this);
            img.setLayoutParams(new LayoutParams(getWidth(), 400));

            return new MyViewHolder(img);
        }
    }

    public int getWidth() {
        Log.e("width", recyclerView.getMeasuredWidth() / 3 + "");
        return recyclerView.getMeasuredWidth() / 3;
    }

    public void prev(View view) {
        recyclerView.smoothScrollBy(-getWidth(), 0);
    }

    public void next(View view) {
        recyclerView.smoothScrollBy(getWidth(), 0);
    }
}

至此: 文章就结束了,如有疑问: QQ群:274306954 欢迎您的加入.

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 199,902评论 5 468
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 84,037评论 2 377
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 146,978评论 0 332
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 53,867评论 1 272
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 62,763评论 5 360
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,104评论 1 277
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,565评论 3 390
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,236评论 0 254
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,379评论 1 294
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,313评论 2 317
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,363评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,034评论 3 315
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,637评论 3 303
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,719评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 30,952评论 1 255
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,371评论 2 346
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 41,948评论 2 341

推荐阅读更多精彩内容

  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 171,275评论 25 707
  • 这篇文章分三个部分,简单跟大家讲一下 RecyclerView 的常用方法与奇葩用法;工作原理与ListView比...
    LucasAdam阅读 4,368评论 0 27
  • 自Android 5.0之后,谷歌公司推出了RecylerView控件,RecylerView,我想看到一个新名词...
    苦可乐阅读 2,260评论 0 5
  • 在该回答下方的评论区,许多网友表达自己的看法,总体而言支持和反对的声音皆有。 当然,还有另一种情况——不涉及按揭贷...
    房多一点阅读 214评论 0 0
  • 看见你, 那是多年前的一个约定。 你记不记得清? 你不记得也行, 我时时把你放在心里。 风雨来了, 我不能把你的名...
    小剧在成长阅读 183评论 2 4