SliderLayout实现轮播图

本文介绍了如何使用SliderLayout实现Android应用中的广告轮播图。内容包括AndroidImageSlider库的简介,依赖项的添加,布局文件配置,以及代码实现步骤。文中详细讲解了SliderLayout、SliderView和PagerIndicator的使用,并强调了资源释放的重要性。
摘要由CSDN通过智能技术生成

SliderLayout实现轮播图

源码地址:https://github.com/Bacsonlx/Android-CNiaoShop/tree/master/CNiaoShop_03

(注:代码采用的是第一章的模板,关于轮播图的代码只需要看HomeFragment以及相关的布局文件即可 )

效果图:

在这里插入图片描述

一、AndroidImageSlider简介

​ AndroidImageSlider是GitHub上的一个非常火的开源项目,由“代码家”出品,他的网址是https://github.com/daimajia/AndroidImageSlider。下面的用法介绍很多都是参考他的GitHub主页的常规用法,因此建议大家学习使用开源项目的时候直接参考GitHub主页的用法介绍。

​ 下图是AndroidImageSlider的架构,最核心的类是SliderLayout,他继承自相对布局,包含了可以左右滑动切换的SliderView,以及页面指示器PagerIndicator,也就是上图中的4个小圆点。这两个都可以自定义,常规的用法是:使用TextSliderView+自定义PagerIndicator,下面对常规用法就行介绍。

在这里插入图片描述

二、AndroidImageSlider实现广告轮播条

1、添加依赖性和权限

参考GithHub中AndroidImageSlider主页的介绍,首先将需要的三个依赖项目引入进来,他们分别是:

dependencies {
    	implementation "com.android.support:support-v4:+"
    	implementation 'com.squareup.picasso:picasso:2.3.2'
    	implementation 'com.nineoldandroids:library:2.4.0'
    	implementation 'com.daimajia.slider:library:1.1.5@aar'
}

​ 建议全部的依赖项目统一使用最新的版本,因为依赖的项目之间可能也会存在依赖,如果不想出现版本冲突问题,最后全部使用最新版。

添加权限:

    <!-- if you want to load images from the internet -->
    <uses-permission android:name="android.permission.INTERNET" />

    <!-- if you want to load images from a file OR from the internet -->
    <uses-permission android:name="android.permission.READ_EXTERNAL_STORAGE" />

2、布局文件

在布局文件中放置SliderLayout以及PagerIndicator。注意布局中是通过相对布局把PagerIndicator压在SliderLayout之上的。代码都可以在GitHub上找到参考。

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    xmlns:custom="http://schemas.android.com/apk/res-auto"
    android:orientation="vertical"
    android:layout_width="match_parent"
    android:layout_height="match_parent">
	<!-- 定义SliderLayout -->
    <com.daimajia.slider.library.SliderLayout
        android:id="@+id/slider"
        android:layout_width
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
下面是一个简单的Qt代码示例,用于显示温度和湿度的界面。在这个示例中,我们使用QLCDNumber控件来显示温度和湿度,使用QSlider控件来模拟温度和湿度的变化,使用QPushButton控件来触发温度和湿度的更新。 mainwindow.h文件: ```cpp #ifndef MAINWINDOW_H #define MAINWINDOW_H #include <QMainWindow> #include <QLCDNumber> #include <QSlider> #include <QPushButton> class MainWindow : public QMainWindow { Q_OBJECT public: MainWindow(QWidget *parent = 0); ~MainWindow(); private slots: void updateTemperature(int value); void updateHumidity(int value); private: QLCDNumber *temperatureLCD; QLCDNumber *humidityLCD; QSlider *temperatureSlider; QSlider *humiditySlider; QPushButton *updateButton; }; #endif // MAINWINDOW_H ``` mainwindow.cpp文件: ```cpp #include "mainwindow.h" MainWindow::MainWindow(QWidget *parent) : QMainWindow(parent) { // 创建温度和湿度的QLCDNumber控件 temperatureLCD = new QLCDNumber(this); temperatureLCD->setDigitCount(3); temperatureLCD->display(25); humidityLCD = new QLCDNumber(this); humidityLCD->setDigitCount(3); humidityLCD->display(50); // 创建温度和湿度的QSlider控件 temperatureSlider = new QSlider(Qt::Horizontal, this); temperatureSlider->setRange(0, 50); temperatureSlider->setValue(25); humiditySlider = new QSlider(Qt::Horizontal, this); humiditySlider->setRange(0, 100); humiditySlider->setValue(50); // 创建更新按钮 updateButton = new QPushButton(tr("更新"), this); // 连接温度和湿度的QSlider控件的valueChanged信号和槽函数 connect(temperatureSlider, &QSlider::valueChanged, this, &MainWindow::updateTemperature); connect(humiditySlider, &QSlider::valueChanged, this, &MainWindow::updateHumidity); // 连接更新按钮的clicked信号和槽函数 connect(updateButton, &QPushButton::clicked, this, [=](){ temperatureLCD->display(temperatureSlider->value()); humidityLCD->display(humiditySlider->value()); }); // 创建布局 QVBoxLayout *temperatureLayout = new QVBoxLayout; temperatureLayout->addWidget(new QLabel(tr("温度"))); temperatureLayout->addWidget(temperatureLCD); temperatureLayout->addWidget(temperatureSlider); QVBoxLayout *humidityLayout = new QVBoxLayout; humidityLayout->addWidget(new QLabel(tr("湿度"))); humidityLayout->addWidget(humidityLCD); humidityLayout->addWidget(humiditySlider); QHBoxLayout *sliderLayout = new QHBoxLayout; sliderLayout->addLayout(temperatureLayout); sliderLayout->addLayout(humidityLayout); QVBoxLayout *mainLayout = new QVBoxLayout; mainLayout->addLayout(sliderLayout); mainLayout->addWidget(updateButton); // 设置窗口布局 QWidget *centralWidget = new QWidget(this); centralWidget->setLayout(mainLayout); setCentralWidget(centralWidget); } MainWindow::~MainWindow() { } void MainWindow::updateTemperature(int value) { temperatureLCD->display(value); } void MainWindow::updateHumidity(int value) { humidityLCD->display(value); } ``` 在这个示例中,我们创建了一个QMainWindow窗口,并在其中添加了两个QLCDNumber控件用于显示温度和湿度,两个QSlider控件用于模拟温度和湿度的变化,以及一个QPushButton控件用于更新温度和湿度的数值。在程序运行时,我们将温度和湿度的QLCDNumber控件、温度和湿度的QSlider控件以及更新按钮都添加到窗口布局中,并连接了QSlider控件的valueChanged信号和槽函数,以及QPushButton控件的clicked信号和槽函数。在槽函数中,我们使用QLCDNumber控件的display函数来更新温度和湿度的数值。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值