html圆形音乐播放器

时间: 2023-09-04 09:15:39 浏览: 86
HTML

html 音乐播放器

下面是一个基本的 HTML 圆形音乐播放器的示例代码: ```html <!DOCTYPE html> <html> <head> <title>圆形音乐播放器</title> <style type="text/css"> .circle { width: 200px; height: 200px; border-radius: 50%; background-color: #333; position: relative; overflow: hidden; } .circle img { width: 100%; height: 100%; object-fit: cover; } .circle:before { content: ""; display: block; padding-top: 100%; } .circle .play-button { width: 60px; height: 60px; border-radius: 50%; background-color: #fff; position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%); cursor: pointer; box-shadow: 0px 0px 10px rgba(0, 0, 0, 0.5); } .circle .play-button:before { content: ""; display: block; width: 0; height: 0; border-top: 15px solid transparent; border-bottom: 15px solid transparent; border-left: 25px solid #333; position: absolute; left: 22px; top: 15px; } .circle.playing .play-button:before { border-left: none; border-right: 25px solid #333; left: 28px; } .circle .progress-bar { width: 100%; height: 5px; background-color: #fff; position: absolute; bottom: 0; left: 0; z-index: 1; visibility: hidden; } .circle.playing .progress-bar { visibility: visible; } .circle .progress-bar .progress { width: 0; height: 100%; background-color: #FFD700; } .circle .progress-bar .progress.animate { animation-name: progress; animation-duration: 3s; animation-timing-function: linear; animation-iteration-count: infinite; } @keyframes progress { from { width: 0; } to { width: 100%; } } </style> </head> <body> <div class="circle"> <img src="music.jpg"> <div class="play-button"></div> <div class="progress-bar"> <div class="progress"></div> </div> </div> <audio id="myAudio" src="music.mp3"></audio> <script type="text/javascript"> var audio = document.getElementById("myAudio"); var playButton = document.getElementsByClassName("play-button")[0]; var progressBar = document.getElementsByClassName("progress")[0]; var circle = document.getElementsByClassName("circle")[0]; var isPlaying = false; playButton.addEventListener("click", function() { if (isPlaying) { audio.pause(); playButton.classList.remove("playing"); progressBar.classList.remove("animate"); isPlaying = false; } else { audio.play(); playButton.classList.add("playing"); progressBar.classList.add("animate"); isPlaying = true; } }); audio.addEventListener("timeupdate", function() { var progress = audio.currentTime / audio.duration; progressBar.style.width = progress * 100 + "%"; }); audio.addEventListener("ended", function() { playButton.classList.remove("playing"); progressBar.classList.remove("animate"); isPlaying = false; }); </script> </body> </html> ``` 这个播放器有一个圆形的外观,包括一个播放/暂停按钮和一个进度条。你可以将你的音乐文件的路径替换为 `src` 属性的值。
阅读全文

相关推荐

zip
音乐播放器 HTML5 audio video 移动播放器 通过 HTML5,音乐在网络上东山再起。添加音频文件就像插入图像那样简单,并且用户能在浏览器外播放音乐,从而实现惊人的音乐体验。 标签的推出使您不再需要外部音乐播放器,在网站上实现真正的声音融合。 随着 HTML5 的出现,发生了一些重大变化,特别是在音乐和音频方面。开发人员不再要求 web 冲浪者使用 Adobe Flash、Apple QuickTime 或 Microsoft Windows 媒体播放器等特殊的播放器。这意味着用户不必担心是否有最新的兼容插件(或任何播放器插件)。他们只需打开自己喜欢的浏览器并聆听能发出声音的任何内容,如音乐、有声读物、FX 声音效果或朋友和家人录制的消息。 最近在论坛中看到了很多实用html5开发视频播放,音乐播放的功能,大部分都在寻找答案。因此我就在这里做一个demo,供大家相互学习。html5开发越来越流行了,而对于视频这一块也是必不可少的一部分。如何让你的网站占据优势,就要看你的功能和用户体验了。html5对video还是做了很多优惠的东西,我们使用起来很得心应手。 在过去 flash 是网页上最好的解决视频的方法,截至到目前还算是主流,像那些优酷之类的视频网站、虾米那样的在线音乐网站,仍然使用 flash 来提供播放服务。但是这种状况将会随着 HTML5 的发展而改变。就视频而言,HTML5 新增了 video 来实现在线播放视频的功能。 使用 HTML5 的 video 可以很方便的使用 JavaScript 对视频内容进行控制等等,功能十分强大,同时代码比较少加快加载速度。此外跨平台性比较好,特别是一些平板、手机等。例如苹果公司的产品不支持 flash 仅支持 HTML5 中的 video 功能。 HTML5 的兼容性问题虽然目前是个硬伤,但这只是时间的问题。

最新推荐

recommend-type

Android使用自定义ImageView实现圆形图片效果

Android 使用自定义 ImageView 实现圆形图片效果 在 Android 开发中,ImageView 组件只能显示矩形的图片,這样不能满足我们其他的需求,比如要显示圆形的图片。这时,我们就需要自定义 ImageView 了。下面我们将...
recommend-type

Java编程实现swing圆形按钮实例代码

Java编程实现swing圆形按钮实例代码 Java编程实现swing圆形按钮实例代码主要介绍了Java编程实现swing圆形按钮实例代码,涉及两个简单的Java实现按钮的代码,其中一个具有侦测点击事件的简单功能,具有一定借鉴价值...
recommend-type

WPF实现半圆形导航菜单

在本文中,我们将深入探讨如何使用WPF(Windows Presentation Foundation)来实现一个独特的半圆形导航菜单。这个菜单通过组合多个扇形自定义控件并利用clip属性实现菜单项的动态展开和折叠效果。...
recommend-type

ArcGIS教程:按圆形区域提取

圆形区域提取技术在 ArcGIS 中的应用 圆形区域提取是 ArcGIS 中的一种常用技术,用于从栅格数据中提取位于圆形区域内的像元。该技术广泛应用于遥感、地理信息系统、环境监测等领域。 圆形区域提取技术的原理是基于...
recommend-type

html+css实现数据图表的展示效果

例如,使用边框半径和渐变可以制作出漂亮的圆形或饼图;利用伪类和定位可以实现动态的进度条图表。 3. **线形图表**:通过设置元素的宽度和位置,可以构建线形图表。CSS 的 `linear-gradient` 可以用来创建线条,而...
recommend-type

Python中快速友好的MessagePack序列化库msgspec

资源摘要信息:"msgspec是一个针对Python语言的高效且用户友好的MessagePack序列化库。MessagePack是一种快速的二进制序列化格式,它旨在将结构化数据序列化成二进制格式,这样可以比JSON等文本格式更快且更小。msgspec库充分利用了Python的类型提示(type hints),它支持直接从Python类定义中生成序列化和反序列化的模式。对于开发者来说,这意味着使用msgspec时,可以减少手动编码序列化逻辑的工作量,同时保持代码的清晰和易于维护。 msgspec支持Python 3.8及以上版本,能够处理Python原生类型(如int、float、str和bool)以及更复杂的数据结构,如字典、列表、元组和用户定义的类。它还能处理可选字段和默认值,这在很多场景中都非常有用,尤其是当消息格式可能会随着时间发生变化时。 在msgspec中,开发者可以通过定义类来描述数据结构,并通过类继承自`msgspec.Struct`来实现。这样,类的属性就可以直接映射到消息的字段。在序列化时,对象会被转换为MessagePack格式的字节序列;在反序列化时,字节序列可以被转换回原始对象。除了基本的序列化和反序列化,msgspec还支持运行时消息验证,即可以在反序列化时检查消息是否符合预定义的模式。 msgspec的另一个重要特性是它能够处理空集合。例如,上面的例子中`User`类有一个名为`groups`的属性,它的默认值是一个空列表。这种能力意味着开发者不需要为集合中的每个字段编写额外的逻辑,以处理集合为空的情况。 msgspec的使用非常简单直观。例如,创建一个`User`对象并序列化它的代码片段显示了如何定义一个用户类,实例化该类,并将实例序列化为MessagePack格式。这种简洁性是msgspec库的一个主要优势,它减少了代码的复杂性,同时提供了高性能的序列化能力。 msgspec的设计哲学强调了性能和易用性的平衡。它利用了Python的类型提示来简化模式定义和验证的复杂性,同时提供了优化的内部实现来确保快速的序列化和反序列化过程。这种设计使得msgspec非常适合于那些需要高效、类型安全的消息处理的场景,比如网络通信、数据存储以及服务之间的轻量级消息传递。 总的来说,msgspec为Python开发者提供了一个强大的工具集,用于处理高性能的序列化和反序列化任务,特别是当涉及到复杂的对象和结构时。通过利用类型提示和用户定义的模式,msgspec能够简化代码并提高开发效率,同时通过运行时验证确保了数据的正确性。"
recommend-type

管理建模和仿真的文件

管理Boualem Benatallah引用此版本:布阿利姆·贝纳塔拉。管理建模和仿真。约瑟夫-傅立叶大学-格勒诺布尔第一大学,1996年。法语。NNT:电话:00345357HAL ID:电话:00345357https://theses.hal.science/tel-003453572008年12月9日提交HAL是一个多学科的开放存取档案馆,用于存放和传播科学研究论文,无论它们是否被公开。论文可以来自法国或国外的教学和研究机构,也可以来自公共或私人研究中心。L’archive ouverte pluridisciplinaire
recommend-type

STM32 HAL库函数手册精读:最佳实践与案例分析

![STM32 HAL库函数手册精读:最佳实践与案例分析](https://khuenguyencreator.com/wp-content/uploads/2020/07/bai11.jpg) 参考资源链接:[STM32CubeMX与STM32HAL库开发者指南](https://wenku.csdn.net/doc/6401ab9dcce7214c316e8df8?spm=1055.2635.3001.10343) # 1. STM32与HAL库概述 ## 1.1 STM32与HAL库的初识 STM32是一系列广泛使用的ARM Cortex-M微控制器,以其高性能、低功耗、丰富的外设接
recommend-type

如何利用FineReport提供的预览模式来优化报表设计,并确保最终用户获得最佳的交互体验?

针对FineReport预览模式的应用,这本《2020 FCRA报表工程师考试题库与答案详解》详细解读了不同预览模式的使用方法和场景,对于优化报表设计尤为关键。首先,设计报表时,建议利用FineReport的分页预览模式来检查报表的布局和排版是否准确,因为分页预览可以模拟报表在打印时的页面效果。其次,通过填报预览模式,可以帮助开发者验证用户交互和数据收集的准确性,这对于填报类型报表尤为重要。数据分析预览模式则适合于数据可视化报表,可以在这个模式下调整数据展示效果和交互设计,确保数据的易读性和分析的准确性。表单预览模式则更多关注于表单的逻辑和用户体验,可以用于检查表单的流程是否合理,以及数据录入
recommend-type

大学生社团管理系统设计与实现

资源摘要信息:"基于ssm+vue的大学生社团管理系统.zip" 该系统是基于Java语言开发的,使用了ssm框架和vue前端框架,主要面向大学生社团进行管理和运营,具备了丰富的功能和良好的用户体验。 首先,ssm框架是Spring、SpringMVC和MyBatis三个框架的整合,其中Spring是一个全面的企业级框架,可以处理企业的业务逻辑,实现对象的依赖注入和事务管理。SpringMVC是基于Servlet API的MVC框架,可以分离视图和模型,简化Web开发。MyBatis是一个支持定制化SQL、存储过程以及高级映射的持久层框架。 SpringBoot是一种全新的构建和部署应用程序的方式,通过使用SpringBoot,可以简化Spring应用的初始搭建以及开发过程。它使用了特定的方式来进行配置,从而使开发人员不再需要定义样板化的配置。 Vue.js是一个用于创建用户界面的渐进式JavaScript框架,它的核心库只关注视图层,易于上手,同时它的生态系统也十分丰富,提供了大量的工具和库。 系统主要功能包括社团信息管理、社团活动管理、社团成员管理、社团财务管理等。社团信息管理可以查看和编辑社团的基本信息,如社团名称、社团简介等;社团活动管理可以查看和编辑社团的活动信息,如活动时间、活动地点等;社团成员管理可以查看和编辑社团成员的信息,如成员姓名、成员角色等;社团财务管理可以查看和编辑社团的财务信息,如收入、支出等。 此外,该系统还可以通过微信小程序进行访问,微信小程序是一种不需要下载安装即可使用的应用,它实现了应用“触手可及”的梦想,用户扫一扫或者搜一下即可打开应用。同时,它也实现了应用“用完即走”的理念,用户不用关心是否安装太多应用的问题。应用将无处不在,随时可用,但又无需安装卸载。 总的来说,基于ssm+vue的大学生社团管理系统是一款功能丰富、操作简便、使用方便的社团管理工具,非常适合大学生社团的日常管理和运营。