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

相关文章

springboot循环依赖问题案例代码及解决办法

《springboot循环依赖问题案例代码及解决办法》在SpringBoot中,如果两个或多个Bean之间存在循环依赖(即BeanA依赖BeanB,而BeanB又依赖BeanA),会导致Spring的... 目录1. 什么是循环依赖?2. 循环依赖的场景案例3. 解决循环依赖的常见方法方法 1:使用 @La

用js控制视频播放进度基本示例代码

《用js控制视频播放进度基本示例代码》写前端的时候,很多的时候是需要支持要网页视频播放的功能,下面这篇文章主要给大家介绍了关于用js控制视频播放进度的相关资料,文中通过代码介绍的非常详细,需要的朋友可... 目录前言html部分:JavaScript部分:注意:总结前言在javascript中控制视频播放

Python+PyQt5实现多屏幕协同播放功能

《Python+PyQt5实现多屏幕协同播放功能》在现代会议展示、数字广告、展览展示等场景中,多屏幕协同播放已成为刚需,下面我们就来看看如何利用Python和PyQt5开发一套功能强大的跨屏播控系统吧... 目录一、项目概述:突破传统播放限制二、核心技术解析2.1 多屏管理机制2.2 播放引擎设计2.3 专

使用Python实现文本转语音(TTS)并播放音频

《使用Python实现文本转语音(TTS)并播放音频》在开发涉及语音交互或需要语音提示的应用时,文本转语音(TTS)技术是一个非常实用的工具,下面我们来看看如何使用gTTS和playsound库将文本... 目录什么是 gTTS 和 playsound安装依赖库实现步骤 1. 导入库2. 定义文本和语言 3

MySQL中实现多表查询的操作方法(配sql+实操图+案例巩固 通俗易懂版)

《MySQL中实现多表查询的操作方法(配sql+实操图+案例巩固通俗易懂版)》本文主要讲解了MySQL中的多表查询,包括子查询、笛卡尔积、自连接、多表查询的实现方法以及多列子查询等,通过实际例子和操... 目录复合查询1. 回顾查询基本操作group by 分组having1. 显示部门号为10的部门名,员

Java进阶学习之如何开启远程调式

《Java进阶学习之如何开启远程调式》Java开发中的远程调试是一项至关重要的技能,特别是在处理生产环境的问题或者协作开发时,:本文主要介绍Java进阶学习之如何开启远程调式的相关资料,需要的朋友... 目录概述Java远程调试的开启与底层原理开启Java远程调试底层原理JVM参数总结&nbsMbKKXJx

Python爬虫selenium验证之中文识别点选+图片验证码案例(最新推荐)

《Python爬虫selenium验证之中文识别点选+图片验证码案例(最新推荐)》本文介绍了如何使用Python和Selenium结合ddddocr库实现图片验证码的识别和点击功能,感兴趣的朋友一起看... 目录1.获取图片2.目标识别3.背景坐标识别3.1 ddddocr3.2 打码平台4.坐标点击5.图

Java深度学习库DJL实现Python的NumPy方式

《Java深度学习库DJL实现Python的NumPy方式》本文介绍了DJL库的背景和基本功能,包括NDArray的创建、数学运算、数据获取和设置等,同时,还展示了如何使用NDArray进行数据预处理... 目录1 NDArray 的背景介绍1.1 架构2 JavaDJL使用2.1 安装DJL2.2 基本操

使用Navicat工具比对两个数据库所有表结构的差异案例详解

《使用Navicat工具比对两个数据库所有表结构的差异案例详解》:本文主要介绍如何使用Navicat工具对比两个数据库test_old和test_new,并生成相应的DDLSQL语句,以便将te... 目录概要案例一、如图两个数据库test_old和test_new进行比较:二、开始比较总结概要公司存在多

Python实现多路视频多窗口播放功能

《Python实现多路视频多窗口播放功能》这篇文章主要为大家详细介绍了Python实现多路视频多窗口播放功能的相关知识,文中的示例代码讲解详细,有需要的小伙伴可以跟随小编一起学习一下... 目录一、python实现多路视频播放功能二、代码实现三、打包代码实现总结一、python实现多路视频播放功能服务端开