仿网易云播放器:带声音可切换歌曲的播放器
ccwgpt 2024-10-21 04:05 38 浏览 0 评论
新的一年到来了,给大家分享一个仿网易云播放器制作案例(带声音且可切换歌曲)。希望大家能够享受音乐带来的快乐,同时消除工作紧张、减轻生活压力,带着美好心情进入2019年的生活。
演示地址
- 点击播放按钮,可播放、暂停歌曲;
- 点击前进按钮/后台按钮,可切换歌曲;
- 切换歌曲时,当前是播放状态,则切换歌曲的时候也是播放状态;
- 切换歌曲时,当前是暂停状态,则切换歌曲的时候是暂停状态;
- 歌曲切换的时候,顶部歌曲名称及演唱者会相应变化;
- 歌曲播放过程中,歌曲会显示实时的播放进度。
温馨提示:此演示案例带有声音,工作期间请带上耳机,以免造成不必要的影响。
原理分析
- 通过播放/暂停按钮控制循环动态面板是否循环;
- 通过上一首、下一首按钮控制切换歌曲;
- 通过循环动态面板控制歌曲播放进度,歌曲旋转播放动效;
- 通过文本元件预存歌曲播放时长(以秒为单位);
- 通过内联框架加载真实歌曲;
- 用热区控制用于表示播放进度圆球移动边界。
元件准备
1. 顶部元素
1.1 2个文本矩形框,分别放作者名称和歌曲名称
1.2 1张表示返回的图片
1.3 1张顶部背景(配置阴影效果,体现层级关系)
2. 1张拨片图片,用于体现歌曲播放或暂停的状态
3. 歌曲播放动效元素
3.1 1个白色矩形框,调整圆角半径,使之成为圆形
3.2 1个黑色矩形框,调整圆角半径,使之成为圆形
3.3 动态面板,设置三种状态,分别放置三首歌曲的图片
4. 播放进度元素
4.1 1个椭圆形元件,用于动态显示歌曲播放进度
4.2 1个矩形,用于表示播放进度背景
4.3 两个矩形,分别表示播放进度时间和歌曲时间
4.4 1个热区,用于控制圆形元件的移动边界
5. 5张图片,分别表示歌曲循环、上一首、播放/暂停控制、下一首、更多
6. 一个内联框架,用于实时加载歌曲
7. 1个文本元件,用于表示当前播放歌曲的时间(秒杀)
8. 动态面板,用于控制图片循环及播放进度动效
将内联框架、时间举行,循环面板位置放在不显眼处,重新布局元件后效果如下:
实现步骤
1. 播放按钮设置
播放按钮初始状态是暂停待播放图片,表示当前是暂停状态;选中时,我们预置一张播放待暂停图片,表示当前是播放状态
选中时,启动循环面板,每个0.5秒变换一次状态,同时将播放拨片旋转到唱片上;同时判断当前面板的状态,根据面板状态分别设置歌曲名称、作者、歌曲时间及要播放的歌曲。
取消选中时,停止循环面板。将播放拨片旋转到初始位置,同时在内联框架打开空链接(终止歌曲播放作用),将用于表示播放进度的圆球移到初始位置。
循环动态面板设置事件:
播放拨片设置事件,注意锚点偏移设置:
在内联框架打开mp3歌曲的设置,如果用本地mp3文件,注意相对路径和绝对路径的区别:
2. 上一首按钮设置
点击“上一首”按钮时,需要先判断歌曲状态:
如果是播放状态的话,需要在切换动态面板显示状态后,再触发播放按钮的点击事件(否则无法切换歌曲);
如果是暂停状态,则只需要切换动态面板状态即可。
切换循环动态面板及触发播放按钮重新播放的事件配置如下:
3. 下一首按钮设置
同理,点击“下一首”按钮时,需要先判断歌曲状态:
4. 循环动态面板事件
当播放按钮的状态是选中时,启用循环动态面板;
当循环面板的状态改变时,移动圆球,同时旋转唱片,从而动态显示歌曲播放。
用于表示播放进度的圆球移动事件如下图设置,注意每次移动的距离根据歌曲的时间长度而变化。
移动距离计算:播放背景长度 除以 歌曲时长(需要将歌曲时长换算成秒,用time元件临时保存)。
旋转唱片的设置事件:
5. 圆球移动事件设置(表示播放进度)
圆球在移动时,需要设置一个边界(放一个热区作为边界),当圆球接触边界时,触发播放的点击事件(也就是暂停歌曲播放)。
触发事件设置如下:
6. 唱片状态改变事件设置
当唱片状态改变时,需要根据唱片当前显示的状态,分别设置歌曲名称、作者、歌曲时间及要播放的歌曲。
这个步骤不能少,否则在未播放状态下点击“上一首”或“下一首”按钮时,歌曲名称等不会变化。
本文由 @十月大神 原创发布于人人都是产品经理,未经许可,禁止转载。
题图来自 Unsplash,基于CC0协议。
相关推荐
- 十分钟让你学会LNMP架构负载均衡(impala负载均衡)
-
业务架构、应用架构、数据架构和技术架构一、几个基本概念1、pv值pv值(pageviews):页面的浏览量概念:一个网站的所有页面,在一天内,被浏览的总次数。(大型网站通常是上千万的级别)2、u...
- AGV仓储机器人调度系统架构(agv物流机器人)
-
系统架构层次划分采用分层模块化设计,分为以下五层:1.1用户接口层功能:提供人机交互界面(Web/桌面端),支持任务下发、实时监控、数据可视化和报警管理。模块:任务管理面板:接收订单(如拣货、...
- 远程热部署在美团的落地实践(远程热点是什么意思)
-
Sonic是美团内部研发设计的一款用于热部署的IDEA插件,本文其实现原理及落地的一些技术细节。在阅读本文之前,建议大家先熟悉一下Spring源码、SpringMVC源码、SpringBoot...
- springboot搭建xxl-job(分布式任务调度系统)
-
一、部署xxl-job服务端下载xxl-job源码:https://gitee.com/xuxueli0323/xxl-job二、导入项目、创建xxl_job数据库、修改配置文件为自己的数据库三、启动...
- 大模型:使用vLLM和Ray分布式部署推理应用
-
一、vLLM:面向大模型的高效推理框架1.核心特点专为推理优化:专注于大模型(如GPT-3、LLaMA)的高吞吐量、低延迟推理。关键技术:PagedAttention:类似操作系统内存分页管理,将K...
- 国产开源之光【分布式工作流调度系统】:DolphinScheduler
-
DolphinScheduler是一个开源的分布式工作流调度系统,旨在帮助用户以可靠、高效和可扩展的方式管理和调度大规模的数据处理工作流。它支持以图形化方式定义和管理工作流,提供了丰富的调度功能和监控...
- 简单可靠高效的分布式任务队列系统
-
#记录我的2024#大家好,又见面了,我是GitHub精选君!背景介绍在系统访问量逐渐增大,高并发、分布式系统成为了企业技术架构升级的必由之路。在这样的背景下,异步任务队列扮演着至关重要的角色,...
- 虚拟服务器之间如何分布式运行?(虚拟服务器部署)
-
在云计算和虚拟化技术快速发展的今天,传统“单机单任务”的服务器架构早已难以满足现代业务对高并发、高可用、弹性伸缩和容错容灾的严苛要求。分布式系统应运而生,并成为支撑各类互联网平台、企业信息系统和A...
- 一文掌握 XXL-Job 的 6 大核心组件
-
XXL-Job是一个分布式任务调度平台,其核心组件主要包括以下部分,各组件相互协作实现高效的任务调度与管理:1.调度注册中心(RegistryCenter)作用:负责管理调度器(Schedule...
- 京东大佬问我,SpringBoot中如何做延迟队列?单机与分布式如何做?
-
京东大佬问我,SpringBoot中如何做延迟队列?单机如何做?分布式如何做呢?并给出案例与代码分析。嗯,用户问的是在SpringBoot中如何实现延迟队列,单机和分布式环境下分别怎么做。这个问题其实...
- 企业级项目组件选型(一)分布式任务调度平台
-
官网地址:https://www.xuxueli.com/xxl-job/能力介绍架构图安全性为提升系统安全性,调度中心和执行器进行安全性校验,双方AccessToken匹配才允许通讯;调度中心和执...
- python多进程的分布式任务调度应用场景及示例
-
多进程的分布式任务调度可以应用于以下场景:分布式爬虫:importmultiprocessingimportrequestsdefcrawl(url):response=re...
- SpringBoot整合ElasticJob实现分布式任务调度
-
介绍ElasticJob是面向互联网生态和海量任务的分布式调度解决方案,由两个相互独立的子项目ElasticJob-Lite和ElasticJob-Cloud组成。它通过弹性调度、资源管控、...
- 分布式可视化 DAG 任务调度系统 Taier 的整体流程分析
-
Taier作为袋鼠云的开源项目之一,是一个分布式可视化的DAG任务调度系统。旨在降低ETL开发成本,提高大数据平台稳定性,让大数据开发人员可以在Taier直接进行业务逻辑的开发,而不用关...
- SpringBoot任务调度:@Scheduled与TaskExecutor全面解析
-
一、任务调度基础概念1.1什么是任务调度任务调度是指按照预定的时间计划或特定条件自动执行任务的过程。在现代应用开发中,任务调度扮演着至关重要的角色,它使得开发者能够自动化处理周期性任务、定时任务和异...
你 发表评论:
欢迎- 一周热门
- 最近发表
- 标签列表
-
- MVC框架 (46)
- spring框架 (46)
- 框架图 (58)
- flask框架 (53)
- quartz框架 (51)
- abp框架 (47)
- jpa框架 (47)
- laravel框架 (46)
- springmvc框架 (49)
- 分布式事务框架 (65)
- scrapy框架 (56)
- shiro框架 (61)
- 定时任务框架 (56)
- java日志框架 (61)
- JAVA集合框架 (47)
- grpc框架 (55)
- ppt框架 (48)
- 内联框架 (52)
- winform框架 (46)
- gui框架 (44)
- cad怎么画框架 (58)
- ps怎么画框架 (47)
- ssm框架实现登录注册 (49)
- oracle字符串长度 (48)
- oracle提交事务 (47)