Android Studio App开发实战项目之广告轮播(附源码 可用于大作业)

news/2024/10/17 13:38:11/

需要图片集和源码请点赞关注收藏后评论区留言即可~~~

电商App的首页上方,都在明显位置放了一栏广告条,并且广告条会轮播,非常吸引眼球,这种广告轮播的功能,为推广热门事物出力甚大。

轮播视频已上传至我的主页,有需要可自行前往观看~

一、需求描述

作为App首页的常客,广告轮播特效早就为人所熟知,它的界面也司空见惯 效果如下

广告条除了广告图片之外,底部还有一排圆点,这些圆点被称作指示器,每当轮播到第几个广告,指示器就高亮显示第几个圆点,其余圆点显示白色,如此依赖用户便知道当前播放到了第几个广告

 

 

 二、界面设计

用到的控件如下

1:相对视图

2:单选组

3:翻页视图

4:翻页适配器

此外 广告每隔两三秒就轮播下一个广告,这种自动轮播可采用Handler+Runnable,因此有必要将广告条封装为单独的控件,以便随时随地在各页面中添加。

三、关键部分 

1:定义广告条的XML布局文件

采用相对布局以及内部嵌套容纳广告图片的翻页视图

2:编写广告条的Java定义代码

3:为广告条添加图片清单

指定广告图片的来源以及数量

4:实现广告条的自动轮播功能

给广告条添加图片清单之后,还得设置具体的轮播规则

5:在活动页面中使用广告条控件

引用时声明路径

四、代码

Java类

package com.example.chapter10;import android.annotation.SuppressLint;
import android.os.Bundle;
import android.widget.LinearLayout.LayoutParams;
import android.widget.TextView;import androidx.appcompat.app.AppCompatActivity;import com.example.chapter10.util.Utils;
import com.example.chapter10.widget.BannerPager;
import com.example.chapter10.widget.BannerPager.BannerClickListener;import java.util.ArrayList;
import java.util.List;@SuppressLint("DefaultLocale")
public class BannerPagerActivity extends AppCompatActivity implements BannerClickListener {private static final String TAG = "BannerPagerActivity";private TextView tv_pager;private List<Integer> getImageList() {ArrayList<Integer> imageList = new ArrayList<Integer>();imageList.add(R.drawable.banner_1);imageList.add(R.drawable.banner_2);imageList.add(R.drawable.banner_3);imageList.add(R.drawable.banner_4);imageList.add(R.drawable.banner_5);return imageList; // 返回默认的广告图片列表}@Overrideprotected void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);setContentView(R.layout.activity_banner_pager);tv_pager = findViewById(R.id.tv_pager);// 从布局文件中获取名叫banner_pager的广告轮播条BannerPager banner = findViewById(R.id.banner_pager);// 获取广告轮播条的布局参数LayoutParams params = (LayoutParams) banner.getLayoutParams();params.height = (int) (Utils.getScreenWidth(this) * 250f / 640f);banner.setLayoutParams(params); // 设置广告轮播条的布局参数banner.setImage(getImageList()); // 设置广告轮播条的广告图片列表banner.setOnBannerListener(this); // 设置广告轮播条的广告点击监听器banner.start(); // 开始广告图片的轮播滚动}// 一旦点击了广告图,就回调监听器的onBannerClick方法public void onBannerClick(int position) {String desc = String.format("您点击了第%d张图片", position + 1);tv_pager.setText(desc);}}

滚动视图类

package com.example.chapter10;import android.os.Bundle;
import android.widget.ListView;import androidx.appcompat.app.AppCompatActivity;import com.example.chapter10.adapter.PlanetListAdapter;
import com.example.chapter10.bean.Planet;
import com.example.chapter10.widget.NoScrollListView;public class NoscrollListActivity extends AppCompatActivity {@Overrideprotected void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);setContentView(R.layout.activity_noscroll_list);PlanetListAdapter adapter1 = new PlanetListAdapter(this, Planet.getDefaultList());// 从布局文件中获取名叫lv_planet的列表视图// lv_planet是系统自带的ListView,被ScrollView嵌套只能显示一行ListView lv_planet = findViewById(R.id.lv_planet);lv_planet.setAdapter(adapter1); // 设置列表视图的行星适配器lv_planet.setOnItemClickListener(adapter1);lv_planet.setOnItemLongClickListener(adapter1);PlanetListAdapter adapter2 = new PlanetListAdapter(this, Planet.getDefaultList());// 从布局文件中获取名叫nslv_planet的不滚动列表视图// nslv_planet是自定义控件NoScrollListView,会显示所有行NoScrollListView nslv_planet = findViewById(R.id.nslv_planet);nslv_planet.setAdapter(adapter2); // 设置不滚动列表视图的行星适配器nslv_planet.setOnItemClickListener(adapter2);nslv_planet.setOnItemLongClickListener(adapter2);}
}

XML文件

<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"android:layout_width="match_parent"android:layout_height="match_parent"android:orientation="vertical"><!-- 自定义的广告轮播条,需要使用全路径 --><com.example.chapter10.widget.BannerPagerandroid:id="@+id/banner_pager"android:layout_width="match_parent"android:layout_height="wrap_content" /><TextViewandroid:id="@+id/tv_pager"android:layout_width="match_parent"android:layout_height="wrap_content"android:gravity="center"android:paddingTop="10dp"android:text="上面的广告图片会自动轮播"android:textColor="@color/black"android:textSize="17sp" /></LinearLayout>

2

<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"android:layout_width="match_parent"android:layout_height="match_parent"><androidx.viewpager.widget.ViewPagerandroid:id="@+id/vp_banner"android:layout_width="match_parent"android:layout_height="match_parent" /><RadioGroupandroid:id="@+id/rg_indicator"android:layout_width="wrap_content"android:layout_height="wrap_content"android:paddingBottom="2dp"android:orientation="horizontal"android:layout_alignParentBottom="true"android:layout_centerHorizontal="true" /></RelativeLayout>

创作不易 觉得有帮助请点赞关注收藏~~~


http://www.ppmy.cn/news/743046.html

相关文章

桌面只计算机图标发白,win7系统桌面图标变白怎么回事_电脑桌面图标有小白块...

说起电脑桌面图标&#xff0c;网友们会罗列出各种问题&#xff0c;其中就是电脑桌面图标有小白块的情况&#xff0c;虽然桌面图标变白可以正常影响&#xff0c;但难免影响美观。win7系统桌面图标变白是怎么回事呢&#xff1f;通常&#xff0c;是因为桌面图标有缓存&#xff0c;…

计算机桌面 文字大小,敬业签电脑桌面便签软件怎么设置字体字号大小?

敬业签是一款支持多端同步功能的云服务便签软件&#xff0c;支持Windows和Mac电脑桌面PC版使用。Mac版目前暂不支持更改便签字体大小&#xff0c;Windows该云便签支持设置便签字体的字号大小&#xff0c;那么敬业签Windows电脑版桌面便签软件怎么设置字体字号大小呢&#xff1f…

电脑桌面云便签怎么设置字体字号大小?

支持多端同步功能的云便签支持Windows和Mac电脑桌面PC版使用。Windows该云便签支持设置便签字体的字号大小&#xff0c;那么Windows电脑版桌面云便签怎么设置字体字号大小呢&#xff1f; 一、打开已登录的电脑版桌面云便签&#xff0c;点击上方用户头像&#xff0c;或者按下默…

计算机电脑桌面文字虚,电脑屏幕字体变模糊是怎么回事

电脑屏幕字体变模糊是怎么回事 一般来说&#xff0c;集成显卡的电脑使用的时间长了&#xff0c;会出现显示器屏幕字体模糊的现象&#xff0c;在液晶显示器上发生的尤为明显。那么&#xff0c;到底是什么原因造成字体模糊的?有没有什么办法可以预防这种问题?下面是小编总结的一…

联想如何在桌面显示计算机和网络图标,联想电脑桌面图标字体变小怎么办

1. 电脑桌面字体图标变小怎么办 一、这种情况的出现大多是由于不懂电脑的人乱设才造成的。 首先在桌面上右击属性——>设置——>高级——>常规——>DPI设置(D:)——>选择正常尺寸(96DPI)——>然后点确定这样应该问题就能够解决了。二、这种情况是你在没有注…

wpf中DialogResult.Yes方法报错

原因&#xff1a;在WPF里DialogResult没有Yes或No的枚举取值了 所以应该这样写 private void Button_Click(object sender, RoutedEventArgs e) {   if (MessageBox.Show ("要退出程序吗?", "退出程序",MessageBoxButton.YesNo ) MessageBoxResult.Y…

github中Mermaid的用法

这个东西是最近推出&#xff0c;首先是自己的repository中新建一个readme.md文件 需要一点前端的知识&#xff0c;就是先导入一个依赖文件&#xff0c;然后再写甘特图&#xff0c;如下&#xff1a; ### 甘特图 [<a href"https://mermaid-js.github.io/mermaid/#/gant…

怎么控制物联网卡的流量使用?

随着时代的发展&#xff0c;物联网卡俨然成为了一种新的发展趋势&#xff0c;他也在被越来越多的人所熟知认识。不过&#xff0c;虽然物联网卡的发展十分迅速&#xff0c;但是相信还是有相当大的一部分人对于物联网卡是不是很熟悉吧&#xff0c;那接下来我就来简单的介绍一下什…