文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

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

2023-08-31 16:38

关注

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

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

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

一、需求描述

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

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

 

 

 二、界面设计

用到的控件如下

相对视图

单选组

翻页视图

翻页适配器

此外 广告每隔两三秒就轮播下一个广告,这种自动轮播可采用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 getImageList() {        ArrayList imageList = new ArrayList();        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; // 返回默认的广告图片列表    }    @Override    protected 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 {    @Override    protected 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文件

            

2

        

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

来源地址:https://blog.csdn.net/jiebaoshayebuhui/article/details/127816603

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     807人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     351人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     314人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     433人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     221人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯