专栏首页算法微时光StackView使用(堆叠列表)

StackView使用(堆叠列表)

image.png

目录

StackView

StackView也是AdapterViewAnimator的子类,它也用于显示Adapter提供的一系列View。 StackView将会以堆叠(Stack)的方式来显示多个列表项。

StackView操作

1.拖走StackView中处于顶端的View,下一个View将会显示出来。将上一个View拖进StackView,将使之显示出来。 2.通过调用StackView的showNext()、showPrevious()控制显示下一个、上一个组件。

实战

xml文件:

<?xml version="1.0" encoding="utf-8"?>
<android.support.constraint.ConstraintLayout 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=".MainActivity">

    <StackView
        android:id="@+id/stackview"
        android:layout_width="match_parent"
        android:layout_height="wrap_content" />

    <Button
        android:id="@+id/prev"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:onClick="prev"
        android:text="上一个"
        app:layout_constraintBottom_toBottomOf="parent"
        app:layout_constraintEnd_toStartOf="@+id/next"
        app:layout_constraintStart_toStartOf="parent"
        app:layout_constraintTop_toTopOf="parent"
        app:layout_constraintVertical_bias="0.0" />

    <Button
        android:id="@+id/next"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:onClick="next"
        android:text="下一个"
        app:layout_constraintBottom_toBottomOf="parent"
        app:layout_constraintEnd_toEndOf="parent"
        app:layout_constraintStart_toEndOf="@+id/prev"
        app:layout_constraintTop_toTopOf="parent"
        app:layout_constraintVertical_bias="0.0" />

</android.support.constraint.ConstraintLayout>

代码文件;

package com.example.user.picture;

import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.view.View;
import android.view.ViewGroup;
import android.widget.AdapterViewFlipper;
import android.widget.BaseAdapter;
import android.widget.ImageView;
import android.widget.StackView;

public class MainActivity extends AppCompatActivity {

    // 图片资源
    int[] picture = new int[]{R.drawable.p001,R.drawable.p002,
            R.drawable.p003,R.drawable.p004};
    StackView stackView;
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);

        // 获取stackView
        stackView = (StackView)findViewById(R.id.stackview);

        // 为获取stackView添加适配器
        BaseAdapter adapter = new BaseAdapter() {
            @Override
            public int getCount() {
                return picture.length;
            }

            @Override
            public Object getItem(int position) {
                return position;
            }

            @Override
            public long getItemId(int position) {
                return position;
            }

            @Override
            public View getView(int position, View convertView, ViewGroup parent) {
                // 创建图片控件
                ImageView imageview = new ImageView(MainActivity.this);
                // 为控件添加资源
                imageview.setImageResource(picture[position]);

                imageview.setScaleType(ImageView.ScaleType.FIT_XY);

                imageview.setLayoutParams(new ViewGroup.LayoutParams(ViewGroup.LayoutParams.MATCH_PARENT,
                        ViewGroup.LayoutParams.MATCH_PARENT));

                return imageview;
            }
        };

        stackView.setAdapter(adapter);
    }

    // 设定按钮函数
    public void prev(View source){
        stackView.showPrevious();
    }

    // 设定按钮函数
    public void next(View source){
        stackView.showNext();
    }
}

运行效果

image.png

image.png

参考

StackView实现卡片堆叠如此简单

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

我来说两句

0 条评论
登录 后参与评论

相关文章

  • 拖动条(SeekBar)使用

    SeekBar 是水平进度条 ProgressBar 的间接子类,相当于一个可以拖动的水平进度条。

    李小白是一只喵
  • 相对布局RelativeLayout(三)

    最新Android开发视频教程(共6章)Android Studio教程(2017-2018) 19 Android 相对布局的使用(视频+笔记,从01开始点...

    李小白是一只喵
  • RadioGroup控件(五)

    单选框组,顾名思义.只能选择其中的一项. android中使用RadioGroup表示.

    李小白是一只喵
  • Android-PullToRefresh自动加载更多

    Android-PullToRefresh(github地址)是个十分方便的下拉刷新库(也有上拉加载的功能),各个app中常见到滑到底部自动加载的功能,这里提供...

    夏洛克的猫
  • 一款基于Material Desgin设计的APP

    版权声明:本文为博主原创文章,转载请标明出处。 https://blog.csdn.net/lyhhj/article/details/50...

    Hankkin
  • Kotlin 第二弹:Android 中 PDF 创建与渲染实践

    这是 Kotlin 练习的的第二篇。这一篇的由来是因为刚刚在 Android 开发者官网查看 API 的时候,偶然看到了角落里面的 pdf 相关。

    Frank909
  • 【翻译】MotionLayout实现折叠工具栏(Part 1)

    2018-08-13 by Liuqingwen | Tags: Android 翻译 | Hits

    IT自学不成才
  • 拖动条(SeekBar)使用

    SeekBar 是水平进度条 ProgressBar 的间接子类,相当于一个可以拖动的水平进度条。

    李小白是一只喵
  • Android - 自定义View,实现不一样的输入框

    最近看到一个效果,就是在登陆界面输入账号密码的时候,会有一个动画效果,感觉不错,找了一些资料,学习了一下。已经实现效果,效果如下:

    android_薛之涛
  • 《Monkey Android》第6课点击事件的四种写法

    我们在“Button”上按住“ctrl”键,并点击鼠标左键,跟踪到Button的源码类,发现它是继承于TextView,继续跟踪,发现TextView继承于Vi...

    GitOPEN

扫码关注云+社区

领取腾讯云代金券