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

相关文章

Python中re模块结合正则表达式的实际应用案例

《Python中re模块结合正则表达式的实际应用案例》Python中的re模块是用于处理正则表达式的强大工具,正则表达式是一种用来匹配字符串的模式,它可以在文本中搜索和匹配特定的字符串模式,这篇文章主... 目录前言re模块常用函数一、查看文本中是否包含 A 或 B 字符串二、替换多个关键词为统一格式三、提

Python get()函数用法案例详解

《Pythonget()函数用法案例详解》在Python中,get()是字典(dict)类型的内置方法,用于安全地获取字典中指定键对应的值,它的核心作用是避免因访问不存在的键而引发KeyError错... 目录简介基本语法一、用法二、案例:安全访问未知键三、案例:配置参数默认值简介python是一种高级编

MySQL中的索引结构和分类实战案例详解

《MySQL中的索引结构和分类实战案例详解》本文详解MySQL索引结构与分类,涵盖B树、B+树、哈希及全文索引,分析其原理与优劣势,并结合实战案例探讨创建、管理及优化技巧,助力提升查询性能,感兴趣的朋... 目录一、索引概述1.1 索引的定义与作用1.2 索引的基本原理二、索引结构详解2.1 B树索引2.2

从入门到精通MySQL 数据库索引(实战案例)

《从入门到精通MySQL数据库索引(实战案例)》索引是数据库的目录,提升查询速度,主要类型包括BTree、Hash、全文、空间索引,需根据场景选择,建议用于高频查询、关联字段、排序等,避免重复率高或... 目录一、索引是什么?能干嘛?核心作用:二、索引的 4 种主要类型(附通俗例子)1. BTree 索引(

HTML中meta标签的常见使用案例(示例详解)

《HTML中meta标签的常见使用案例(示例详解)》HTMLmeta标签用于提供文档元数据,涵盖字符编码、SEO优化、社交媒体集成、移动设备适配、浏览器控制及安全隐私设置,优化页面显示与搜索引擎索引... 目录html中meta标签的常见使用案例一、基础功能二、搜索引擎优化(seo)三、社交媒体集成四、移动

Python如何将OpenCV摄像头视频流通过浏览器播放

《Python如何将OpenCV摄像头视频流通过浏览器播放》:本文主要介绍Python如何将OpenCV摄像头视频流通过浏览器播放的问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完... 目录方法1:使用Flask + MJPEG流实现代码使用方法优点缺点方法2:使用WebSocket传输视

六个案例搞懂mysql间隙锁

《六个案例搞懂mysql间隙锁》MySQL中的间隙是指索引中两个索引键之间的空间,间隙锁用于防止范围查询期间的幻读,本文主要介绍了六个案例搞懂mysql间隙锁,具有一定的参考价值,感兴趣的可以了解一下... 目录概念解释间隙锁详解间隙锁触发条件间隙锁加锁规则案例演示案例一:唯一索引等值锁定存在的数据案例二:

Go学习记录之runtime包深入解析

《Go学习记录之runtime包深入解析》Go语言runtime包管理运行时环境,涵盖goroutine调度、内存分配、垃圾回收、类型信息等核心功能,:本文主要介绍Go学习记录之runtime包的... 目录前言:一、runtime包内容学习1、作用:① Goroutine和并发控制:② 垃圾回收:③ 栈和

Android学习总结之Java和kotlin区别超详细分析

《Android学习总结之Java和kotlin区别超详细分析》Java和Kotlin都是用于Android开发的编程语言,它们各自具有独特的特点和优势,:本文主要介绍Android学习总结之Ja... 目录一、空安全机制真题 1:Kotlin 如何解决 Java 的 NullPointerExceptio

MySQL 表的内外连接案例详解

《MySQL表的内外连接案例详解》本文给大家介绍MySQL表的内外连接,结合实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录表的内外连接(重点)内连接外连接表的内外连接(重点)内连接内连接实际上就是利用where子句对两种表形成的笛卡儿积进行筛选,我