ViewPager 的简单使用(一)

ViewPager与ImagePagerAdapter的实现详解
本文详细介绍了ViewPager作为AdapterView模式的实现,及其如何通过自定义ImagePagerAdapter适配器来展示图片。重点阐述了ImagePagerAdapter类的实现,包括获取页面总数、设置页面宽度、创建与销毁页面视图的方法。

ViewPager 是 AdapterView 模式修改后的实现,ListView 和 GridView 小部件也使用了框架的这种模式。ViewPager 需要一个继承自 PagerAdpter 的子类适配器来实现。

ViewPager 本身不能实现分页控件的回收,但它每时每刻都提供了回调方法来进行条目的创建和销毁。所以在特定的时间内,内存中运行的内容视图的数量是固定的(屏幕以外的页数默认限制值为 3,跟踪页面的编号总是围绕着当前可见的页面居中进行的)。效果如下:


图一:


图二:




ImagePagerAdapter.java :

package com.crazy.viewpagertest;

import android.content.Context;
import android.graphics.Color;
import android.support.v4.view.PagerAdapter;
import android.view.View;
import android.view.ViewGroup;
import android.widget.ImageView;


public class ImagePagerAdapter extends PagerAdapter {

    private Context mContext;

    private static final int[] IMAGES = {
            R.drawable.bg_01, R.drawable.bg_02, R.drawable.bg_03,
            R.drawable.bg_04, R.drawable.bg_05
    };

    private static final int[] COLORS = {
            Color.RED, Color.BLUE, Color.GREEN,
            Color.GRAY, Color.MAGENTA
    };

    public ImagePagerAdapter(Context context) {
        super();
        mContext = context;
    }

    /**
     *  页面的总数
     */
    @Override
    public int getCount() {
        return IMAGES.length;
    }

    /**
     *  如果需要在 ViewPager 内一次显示超过一页的内容,那么需要重写该方法
     */
    @Override
    public float getPageWidth(int position) {
        return 1f;
        // 每个页面的宽度是视图的 1/3 (如效果图2)
      //  return 0.333f;
    }

    /**
     *  返回唯一的键对象来表示某个条目(此处是 imageView)
     */
    @Override
    public Object instantiateItem(ViewGroup container, int position) {
        // 创建一个新的 ImageView 并把它添加到提供的容器中
        ImageView imageView = new ImageView(mContext);
        // 设置此位置的内容
        imageView.setImageResource(IMAGES[position]);
        imageView.setBackgroundColor(COLORS[position]);

        imageView.setScaleType(ImageView.ScaleType.FIT_CENTER);

        // 添加视图
        container.addView(imageView);

        return imageView;
    }

    /**
     *  当创建的新视图或者某个视图滚动超出了页数限制的范围后,
     *  需要删除该视图时,就会分别调用 instantiateItem() 和 destroyItem()
     */
    @Override
    public void destroyItem(ViewGroup container, int position, Object object) {
        // 从容器中删除视图
        container.removeView((View)object);
    }

    /**
     *  把从 instantiateItem() 返回的 view 关联到给定的 ViewGroup 上(不一定要相等)。
     */
    @Override
    public boolean isViewFromObject(View view, Object object) {
        // 检查从 instantiateItem() 返回的对象与添加到容器相应位置的视图是否是同一个对象。
        // 此处是同一个对象
        return (view == object);
    }


}




MainActivity.java :

package com.crazy.viewpagertest;

import android.os.Bundle;
import android.support.v4.view.ViewPager;
import android.support.v7.app.AppCompatActivity;

public class MainActivity extends AppCompatActivity {

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);

        ViewPager viewPager = new ViewPager(this);
        viewPager.setAdapter(new ImagePagerAdapter(this));
        setContentView(viewPager);
        
    }

}



**项目名称:** 基于Vue.js与Spring Cloud架构的博客系统设计与开发——微服务分布式应用实践 **项目概述:** 本项目为计算机科学与技术专业本科毕业设计成果,旨在设计并实现个采用前后端分离架构的现代化博客平台。系统前端基于Vue.js框架构建,提供响应式用户界面;后端采用Spring Cloud微服务架构,通过服务拆分、注册发现、配置中心及网关路由等技术,构建高可用、易扩展的分布式应用体系。项目重点探讨微服务模式下的系统设计、服务治理、数据致性及部署运维等关键问题,体现了分布式系统在Web应用中的实践价值。 **技术架构:** 1. **前端技术栈:** Vue.js 2.x、Vue Router、Vuex、Element UI、Axios 2. **后端技术栈:** Spring Boot 2.x、Spring Cloud (Eureka/Nacos、Feign/OpenFeign、Ribbon、Hystrix、Zuul/Gateway、Config) 3. **数据存储:** MySQL 8.0(主数据存储)、Redis(缓存与会话管理) 4. **服务通信:** RESTful API、消息队列(可选RabbitMQ/Kafka) 5. **部署与运维:** Docker容器化、Jenkins持续集成、Nginx负载均衡 **核心功能模块:** - 用户管理:注册登录、权限控制、个人中心 - 文章管理:富文本编辑、分类标签、发布审核、评论互动 - 内容展示:首页推荐、分类检索、全文搜索、热门排行 - 系统管理:后台仪表盘、用户与内容监控、日志审计 - 微服务治理:服务健康检测、动态配置更新、熔断降级策略 **设计特点:** 1. **架构解耦:** 前后端完全分离,通过API网关统接入,支持独立开发与部署。 2. **服务拆分:** 按业务域划分为用户服务、文章服务、评论服务、文件服务等独立微服务。 3. **高可用设计:** 采用服务注册发现机制,配合负载均衡与熔断器,提升系统容错能力。 4. **可扩展性:** 模块化设计支持横向扩展,配置中心实现运行时动态调整。 **项目成果:** 完成了个具备完整博客功能、具备微服务典型特征的分布式系统原型,通过容器化部署验证了多服务协同运行的可行性,为云原生应用开发提供了实践参考。 资源来源于网络分享,仅用于学习交流使用,请勿用于商业,如有侵权请联系我删除!
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值