day41 CD播放(案例学习)

2024-02-15 15:52
文章标签 学习 案例 播放 cd day41

本文主要是介绍day41 CD播放(案例学习),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

示例

该示例是一个简单的CD播放器,通过点击不同的按钮来控制CD的旋转和音乐的播放/暂停。

JavaScript部分的功能分析如下:

  1. rota数组用于描述每个CD的旋转角度,初始值为[0, 0]。
  2. result数组用于表示每个CD的状态,初始值为[false, false],代表两个CD都是静止不动的状态。
  3. setInter数组存储了定时器的引用,用于控制CD的旋转。
  4. playOrStop函数是点击按钮时的事件处理函数,根据点击的CD当前的状态执行相应的操作。
    • 如果CD当前是静止状态,将CD的定时器启动,每隔20毫秒调用move函数旋转CD,并将CD的状态设置为运行。
    • 同时播放对应CD的音乐,并暂停其他CD的音乐。
    • 如果CD当前是运行状态,清除CD的定时器,暂停CD的音乐,并将CD的状态设置为静止。
  5. move函数是CD旋转的方法,通过修改CD的transform属性实现旋转效果。

HTML部分主要是一个简单的表格布局,包含两个CD的图像和按钮,点击按钮时调用playOrStop函数。

CSS部分定义了一些样式,包括设置CD的大小、边框、旋转等样式。

总体来说,该示例通过JavaScript控制了CD的旋转和音乐的播放/暂停,通过HTML和CSS实现了简单的界面展示和样式设置。
在这里插入图片描述


var rota = [0, 0];//描述角度
var result = [false, false];//默认两个CD都是静止不动
var setInter = [null, null];
function playOrStop(index) {//判断点击的cd的状态if (result[index] == false) {//证明点击的这个CD目前的状态是静止setInter[index] = setInterval("move(" + index + ");", 20);//每隔20毫秒进行方法的调用result[index] = true;//改变这个cd的状态为运行//对音乐进行操作(音乐要开始播放了)//------------------------------------------------------var audio = document.getElementById("audio" + index);if (audio && audio.paused) {audio.play();}//其余的CD停止for (var i = 0; i < rota.length; i++) {if (i != index) {clearInterval(setInter[i]);var audio = document.getElementById("audio" + i);if (audio) {audio.pause();}result[i] = false;}}} else {//证明该我点击的这个CD目前是运行状态clearInterval(setInter[index]);document.getElementById("audio" + index).pause();result[index] = false;}
}//运行的方法
function move(index) {var box = document.getElementById("td" + index).style.transform = "rotate(" + rota[index] + "deg)";rota[index]++;
}
<!DOCTYPE html>
<html><head><meta charset="utf-8"><title></title><script type="text/javascript" src="cd.js"></script><link rel="stylesheet" href="cd.css"></head><body><div id="all"><table><tr><td id="td0"><img src="/images/qiji.jpg"></td><td id="td1"><img src="/images/yuai.jpg"></td></tr><tr><td><input type="button" value="play/stop" onclick="playOrStop(0);"></td><td><input type="button" value="play/stop" onclick="playOrStop(1);"></td></tr></table></div><div id="music" style="display: none;"><audio src="mp3/wind.mp3" id="audio0" autoplay></audio><audio src="mp3/wind.mp3" id="audio1" autoplay></audio></div></body></html>
#all {border: 1px solid red;width: 1238px;height: 1223px;margin: 0 auto;
}table td {border: 1px solid black;width: 610px;height: 600px;
}table tr {text-align: center;
}table tr input {width: 400px;height: 200px;font-size: 40px;
}table img {width: 610px;height: 600px;object-fit: cover;
}#td0 {transform: rotate(0deg);
}#td1 {transform: rotate(0deg);
}

这篇关于day41 CD播放(案例学习)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/711832

相关文章

Vue3视频播放组件 vue3-video-play使用方式

《Vue3视频播放组件vue3-video-play使用方式》vue3-video-play是Vue3的视频播放组件,基于原生video标签开发,支持MP4和HLS流,提供全局/局部引入方式,可监听... 目录一、安装二、全局引入三、局部引入四、基本使用五、事件监听六、播放 HLS 流七、更多功能总结在 v

Java中的分布式系统开发基于 Zookeeper 与 Dubbo 的应用案例解析

《Java中的分布式系统开发基于Zookeeper与Dubbo的应用案例解析》本文将通过实际案例,带你走进基于Zookeeper与Dubbo的分布式系统开发,本文通过实例代码给大家介绍的非常详... 目录Java 中的分布式系统开发基于 Zookeeper 与 Dubbo 的应用案例一、分布式系统中的挑战二

Java 中的 equals 和 hashCode 方法关系与正确重写实践案例

《Java中的equals和hashCode方法关系与正确重写实践案例》在Java中,equals和hashCode方法是Object类的核心方法,广泛用于对象比较和哈希集合(如HashMa... 目录一、背景与需求分析1.1 equals 和 hashCode 的背景1.2 需求分析1.3 技术挑战1.4

Java中实现对象的拷贝案例讲解

《Java中实现对象的拷贝案例讲解》Java对象拷贝分为浅拷贝(复制值及引用地址)和深拷贝(递归复制所有引用对象),常用方法包括Object.clone()、序列化及JSON转换,需处理循环引用问题,... 目录对象的拷贝简介浅拷贝和深拷贝浅拷贝深拷贝深拷贝和循环引用总结对象的拷贝简介对象的拷贝,把一个

Java中最全最基础的IO流概述和简介案例分析

《Java中最全最基础的IO流概述和简介案例分析》JavaIO流用于程序与外部设备的数据交互,分为字节流(InputStream/OutputStream)和字符流(Reader/Writer),处理... 目录IO流简介IO是什么应用场景IO流的分类流的超类类型字节文件流应用简介核心API文件输出流应用文

MyBatis分页查询实战案例完整流程

《MyBatis分页查询实战案例完整流程》MyBatis是一个强大的Java持久层框架,支持自定义SQL和高级映射,本案例以员工工资信息管理为例,详细讲解如何在IDEA中使用MyBatis结合Page... 目录1. MyBATis框架简介2. 分页查询原理与应用场景2.1 分页查询的基本原理2.1.1 分

深度解析Java @Serial 注解及常见错误案例

《深度解析Java@Serial注解及常见错误案例》Java14引入@Serial注解,用于编译时校验序列化成员,替代传统方式解决运行时错误,适用于Serializable类的方法/字段,需注意签... 目录Java @Serial 注解深度解析1. 注解本质2. 核心作用(1) 主要用途(2) 适用位置3

Java 正则表达式的使用实战案例

《Java正则表达式的使用实战案例》本文详细介绍了Java正则表达式的使用方法,涵盖语法细节、核心类方法、高级特性及实战案例,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要... 目录一、正则表达式语法详解1. 基础字符匹配2. 字符类([]定义)3. 量词(控制匹配次数)4. 边

Python Counter 函数使用案例

《PythonCounter函数使用案例》Counter是collections模块中的一个类,专门用于对可迭代对象中的元素进行计数,接下来通过本文给大家介绍PythonCounter函数使用案例... 目录一、Counter函数概述二、基本使用案例(一)列表元素计数(二)字符串字符计数(三)元组计数三、C

Unity新手入门学习殿堂级知识详细讲解(图文)

《Unity新手入门学习殿堂级知识详细讲解(图文)》Unity是一款跨平台游戏引擎,支持2D/3D及VR/AR开发,核心功能模块包括图形、音频、物理等,通过可视化编辑器与脚本扩展实现开发,项目结构含A... 目录入门概述什么是 UnityUnity引擎基础认知编辑器核心操作Unity 编辑器项目模式分类工程