直接上代码,在Flash Builder 4中新建 FLEX项目,复制代码可以可以直接运行
需要将 file = "D:\\voice\\3791.MP3"; 改为自己的路径
以后还准备增加流式播放!

<?xml version="1.0" encoding="utf-8"?>
<s:Application xmlns:fx="http://ns.adobe.com/mxml/2009"
xmlns:s="library://ns.adobe.com/flex/spark"
xmlns:mx="library://ns.adobe.com/flex/mx"
minWidth="955" minHeight="600"
creationComplete="initMusic()"
height="304" width="808">
<s:layout>
<s:BasicLayout/>
</s:layout>
<fx:Declarations>
<!-- 将非可视元素(例如服务、值对象)放在此处 -->
</fx:Declarations>
<fx:Script>
<![CDATA[
import com.adobe.serialization.json.JSON;
import flash.utils.ByteArray;
import mx.collections.ArrayCollection;
import mx.controls.Alert;
import mx.core.UIComponent;
import mx.events.IndexChangedEvent;
import mx.managers.PopUpManager;
import mx.printing.FlexPrintJob;
import mx.rpc.events.FaultEvent;
import mx.rpc.events.ResultEvent;
import mx.rpc.http.HTTPService;
private var serverIP:String = "http://127.0.0.1";
private var ba:ByteArray = new ByteArray();
private var soundRequest:URLRequest;
private var sound:Sound = new Sound(); //使用Sound对象来获取音乐文件播放声音
private var chanel:SoundChannel; //引入SoundChannel对象来精确控制声音
private var vol:SoundTransform; //通过设置SoundTransform对象的volume属性控制音量
private var stopPosition:int=0; //使用stopPosition记录暂停音乐时的位置
private var soundState:int=1; //使用soundState记录是否静音
private var soundValue:int=2; //记录静音前的音量
private var playState:int=0; //使用playState记录声音是否被停止(包括暂停)
private var totalTime:String = "00:00";//语音文件总时间
private var params:Object; //URL参数列表
private var _sperite:Sprite; //用于绘制声音波形
//初始化
private function initMusic():void{
var args:Object = getParams(); //获取URL中的参数列表
var file:String = serverIP + args.audio+".mp3";//得到语音文件名
// file = "http://127.0.0.1/voice/3416.mp3";
//对播放控制按钮和滑动条添加鼠标动作监听
soundBtn.addEventListener(MouseEvent.CLICK,onSoundClick);//有声音
soundBtnJ.addEventListener(MouseEvent.CLICK,onSoundClick);//静音
playBtn.addEventListener(MouseEvent.CLICK,onPlayBtnClick);//播放
pauseBtn.addEventListener(MouseEvent.CLICK,onPlayBtnClick);//暂停
proccessBar.addEventListener(MouseEvent.MOUSE_DOWN,onProccessBarDown);//播放进度条
proccessBar.addEventListener(MouseEvent.MOUSE_UP,onProccessBarUp);//播放进度条
//组件初始状态设置
soundSlide.value=2;//默认音量等于2
if(file != null && file != ""){
var buffer:SoundLoaderContext = new SoundLoaderContext(5000);
soundRequest = new URLRequest(file);
sound.load(soundRequest,buffer);
sound.addEventListener(Event.COMPLETE, loaded);//监听加载事件
sound.addEventListener(ProgressEvent.PROGRESS, progressHandler);//缓冲事件
}
//控制音量
vol = new SoundTransform();
vol.volume = soundSlide.value;
}
//缓冲事件方法
private function progressHandler(event:ProgressEvent):void{
//计算缓冲方框的宽度(滑块本身也有一定的宽度,减去约10个像素宽度)
if (sound.bytesLoaded>0){
bufferRect.width = sound.bytesLoaded / sound.bytesTotal*(proccessBar.width);
}
}
private function onProccessBarDown(e:MouseEvent):void{
this.removeEventListener(Event.ENTER_FRAME,onEnterFrame);
}
private function onProccessBarUp(e:MouseEvent):void{
this.addEventListener(Event.ENTER_FRAME,onEnterFrame);
}
//读取语音数据,一边取一边画
private function loaded(event:Event):void {
var width:Number = box.width;
var height:Number =box.height;
//获取语音长度,毫秒
var lengthTime:Number = sound.length;
totalTime = formatTime(lengthTime);
playTime.text = totalTime;
_sperite = new Sprite();//建立影片精灵
var uicomponent:UIComponent = new UIComponent();
uicomponent.addChild(_sperite);
box.addElement(uicomponent);
doDraw(0.1,0xffffff,0,height/2,width-2,height/2); //绘制中心轴线
//绘制横轴
for(var i:int=20;i<height;i+=20){
doDraw(0.1,0xCCCCCC,0,i,width-2,i); //绘制中心轴线
}
//绘制纵轴
for(var j:int=40;j<width;j+=40){
doDraw(0.1,0xCCCCCC,j,0,j,height); //绘制中心轴线
}
var dataCount:Number = lengthTime*44.1;
sound.extract(ba, dataCount); //将所有的语音数据读取到字节数组里面
ba.position = 0;//文件指针的当前位置
var startX:Number = 0,startY:Number = 100;//开始点
var m:int = 1;//记录数据个数
while(ba.bytesAvailable > 0){
var value:Number = ba.readFloat();
var endX:Number = m*width/dataCount;
var endY:Number = height/2;
endY = (1-value)*(height/2);//正数
doDraw(0.1, 0x00FF00, startX, startY, endX, endY);//绘制波形
startX = endX; startY = endY;
if(ba.bytesAvailable > 0){
ba.position += 84;
m += 11;
}
}
//完成自动播放
playState=1;
chanel = sound.play(stopPosition);
chanel.soundTransform=vol;
this.addEventListener(Event.ENTER_FRAME,onEnterFrame);
playBtn.visible=false;
pauseBtn.visible=true;
pState.text = "状态: 播放";
load.visible = false;
}
//绘制曲线
private function doDraw(cx:Number,color:uint,startX:Number,startY:Number,endX:Number,endY:Number):void{
_sperite.graphics.lineStyle(cx,color,1);
_sperite.graphics.moveTo(startX,startY);
_sperite.graphics.lineTo(endX,endY);
}
//播放暂停
private function onPlayBtnClick(e:MouseEvent):void{
//正常状态控制播放与暂停
if(playState==1){
playState=0;
stopPosition = chanel.position;
chanel.stop();
this.removeEventListener(Event.ENTER_FRAME,onEnterFrame);
playBtn.visible=true;
pauseBtn.visible=false;
pState.text = "状态: 暂停";
}else if(playState==0){
playState=1;
chanel = sound.play(stopPosition);
chanel.soundTransform=vol;
this.addEventListener(Event.ENTER_FRAME,onEnterFrame);
playBtn.visible=false;
pauseBtn.visible=true;
pState.text = "状态: 播放";
}
}
//停止播放
public function musStop():void{
playState=0;
stopPosition = 0;
this.removeEventListener(Event.ENTER_FRAME,onEnterFrame);
proccessBar.value=0;
playTime.text="00:00/"+totalTime;
playBtn.visible=true;
pauseBtn.visible=false;
pState.text = "状态: 停止";
if(chanel!=null){
chanel.stop();
}
}
//静音处理按钮
private function onSoundClick(e:MouseEvent):void{
//点击正常状态的静音按钮处理函数
if(soundState==1){
soundState=0;
vol.volume=0;
soundValue = soundSlide.value;
soundSlide.value=0;
soundBtnJ.visible=true;
soundBtn.visible=false;
}else if(soundState==0){
soundState=1;
soundSlide.value = soundValue;
vol.volume=soundSlide.value;
soundBtnJ.visible=false;
soundBtn.visible=true;
}
chanel.soundTransform=vol;
}
//控制音量大小
private function soundSlideChange():void{
vol.volume=soundSlide.value;
chanel.soundTransform=vol;
}
//控制播放进度
private function onEnterFrame(e:Event):void{
if(chanel!=null){
proccessBar.value=chanel.position*(100/sound.length);
playTime.text=formatTime(chanel.position) + "/" + totalTime;
if(proccessBar.value>99){
musStop();
}
}
}
//鼠标拖动进度条更改播放进度的处理
private function changePos():void{
if(chanel!=null){
chanel.stop();
//完成自动播放
playState=1;
chanel = sound.play(proccessBar.value*sound.length/100);
chanel.soundTransform=vol;
this.addEventListener(Event.ENTER_FRAME,onEnterFrame);
playBtn.visible=false;
pauseBtn.visible=true;
pState.text = "状态: 播放";
}
}
//时间格式处理
private function formatTime(time:Number):String{
var s:String;
var m:Number = Math.floor(time / 60000);//分钟
if(m >= 60){
//小时
var h:Number = Math.floor(m / 60);
if (h < 10)
s = "0" + h;
else
s = String(h);
//分钟
m = m - h*60;
if (m < 10)
s += ":0" + m;
else
s += ":" + String(m);
}else{
if (m < 10)
s = "0" + m;
else
s = String(m);
}
m = Math.floor((time / 1000 ) % 60)
if (m < 10)
s += ":0" + m;
else
s += ":" + m;
return s;
}
//从Url中得到参数,得到 ? 以后的所有
private function getParams():Object {
params = {};
//获取整个URI
var query:String = ExternalInterface.call("window.location.search.substring", 1);
var url:String = ExternalInterface.call("window.location.href.toString", 1);
var index:int = url.indexOf("dsas")
serverIP = url.substring(0,index-1);
if(query) {
var pairs:Array = query.split("&");
for(var i:uint=0; i < pairs.length; i++) {
var pos:int = pairs[i].indexOf("=");
if(pos != -1) {
var argname:String = pairs[i].substring(0, pos);
var value:String = pairs[i].substring(pos+1);
params[argname] = value;
}
}
}
return params;
}
//下载语音文件
private function downLoadsVoice():void{
var args:Object = getParams(); //获取URL中的参数列表
var fileName:String = args.audio;
var file:String = serverIP + fileName + ".mp3";//得到语音文件名
var urlReq:URLRequest = new URLRequest(file);
var fileRef:FileReference = new FileReference();
var index:int = fileName.indexOf("voice/");
var tempFile:String = fileName.substring(index+6,fileName.length)+".mp3";
fileRef.download(urlReq,tempFile);
}
]]>
</fx:Script>
<s:Panel id="panel" x="1.3" y="1.35" width="806" height="302" title="乘务员标准化作业语音监控系统"
backgroundColor="#448FF5" backgroundAlpha="0.72" >
<s:Label x="738" y="-24" text="状态:暂停" id="pState" color="#FF0404" fontWeight="bold"/>
<s:BorderContainer x="2" y="2" width="800" height="200" id="box" backgroundColor="#0211D6">
<s:Label x="260" y="84" text="语音加载完成后自动播放,请稍后..." id="load" fontSize="20" color="#FC0000" fontWeight="bold" fontStyle="italic" fontFamily="Courier New"/>
</s:BorderContainer>
<s:BorderContainer id="bufferRect" x="1" y="210" width="7" height="7" buttonMode="true" borderColor="red" backgroundColor="red">
</s:BorderContainer>
<s:HSlider x="1" y="207" width="801" id="proccessBar" change="changePos()"
minimum="0" maximum="100" snapInterval="0.1" liveDragging="true"
showDataTip="false" height="13" alpha="0.5" buttonMode="true"/>
<mx:Image x="6" y="227" source="assets/play.png" id="playBtn"/>
<mx:Image x="6" y="227" source="assets/pause.png" id="pauseBtn" visible="false"/>
<mx:Image x="56" y="227" source="assets/stop.png" id="stopBtn" click="musStop()"/>
<mx:Image x="106" y="227" source="assets/volume.png" id="soundBtn"/>
<mx:Image x="106" y="227" source="assets/volumeJ.png" id="soundBtnJ" visible="false"/>
<s:HSlider x="149" y="238" width="107" id="soundSlide" change="soundSlideChange()" minimum="0" maximum="5"/>
<s:Label y="224" right="1" text="00:00" id="playTime"/>
<s:Button x="758" y="247" label="下载" width="46" click="downLoadsVoice()" id="dl"/>
</s:Panel>
</s:Application>

- 大小: 84 KB
分享到:
相关推荐
在本文中,我们将深入探讨如何使用Flex4技术来创建一个功能丰富的音频播放器,特别是将重点放在如何在播放器界面上显示语音波形这一高级特性上。Flex4是Adobe Flash Platform的一部分,它提供了强大的组件库和框架,...
AS3是Adobe Flash Professional和Flex Builder等开发工具中广泛使用的编程语言,它允许我们创建丰富的交互式内容,包括音频处理。 ### AS3录音功能 在AS3中,我们可以使用`Microphone`类来访问用户的麦克风设备,...
资源内项目源码是来自个人的毕业设计,代码都测试ok,包含源码、数据集、可视化页面和部署说明,可产生核心指标曲线图、混淆矩阵、F1分数曲线、精确率-召回率曲线、验证集预测结果、标签分布图。都是运行成功后才上传资源,毕设答辩评审绝对信服的保底85分以上,放心下载使用,拿来就能用。包含源码、数据集、可视化页面和部署说明一站式服务,拿来就能用的绝对好资源!!! 项目备注 1、该资源内项目代码都经过测试运行成功,功能ok的情况下才上传的,请放心下载使用! 2、本项目适合计算机相关专业(如计科、人工智能、通信工程、自动化、电子信息等)的在校学生、老师或者企业员工下载学习,也适合小白学习进阶,当然也可作为毕设项目、课程设计、大作业、项目初期立项演示等。 3、如果基础还行,也可在此代码基础上进行修改,以实现其他功能,也可用于毕设、课设、作业等。 下载后请首先打开README.txt文件,仅供学习参考, 切勿用于商业用途。
【项目资源】: 适用于从基础到高级的各种项目,特别是在性能要求较高的场景中,比如操作系统开发、嵌入式编程和底层系统编程。如果您是初学者,可以从简单的控制台程序开始练习;如果是进阶开发者,可以尝试涉及硬件或网络的项目。 【项目质量】: 所有源码都经过严格测试,可以直接运行。 功能在确认正常工作后才上传。 【适用人群】: 适用于希望学习不同技术领域的小白或进阶学习者。 可作为毕设项目、课程设计、大作业、工程实训或初期项目立项。 【附加价值】: 项目具有较高的学习借鉴价值,也可直接拿来修改复刻。 对于有一定基础或热衷于研究的人来说,可以在这些基础代码上进行修改和扩展,实现其他功能。 【沟通交流】: 有任何使用上的问题,欢迎随时与博主沟通,博主会及时解答。 鼓励下载和使用,并欢迎大家互相学习,共同进步。 # 注意 1. 本资源仅用于开源学习和技术交流。不可商用等,一切后果由使用者承担。 2. 部分字体以及插图等来自网络,若是侵权请联系删除。
模型权重文件介绍 1. 基于开源数据集训练,训练集包含15000+图片,训练100 epochs 2. 基于YOLO11x模型进行的训练 3. 模型识别类别有2类:helmet、no-helmet
ARM仿真器快速使用资料+绿色版软件 附视频-20210701.zip
内容概要:本文详细介绍了QY20B型汽车起重机液压系统的设计过程,涵盖其背景、发展史、主要运动机构及其液压回路设计。文章首先概述了汽车起重机的分类和发展历程,强调了液压技术在现代起重机中的重要性。接着,文章深入分析了QY20B型汽车起重机的五大主要运动机构(支腿、回转、伸缩、变幅、起升)的工作原理及相应的液压回路设计。每个回路的设计均考虑了性能要求、功能实现及工作原理,确保系统稳定可靠。此外,文章还详细计算了支腿油缸的受力、液压元件的选择及液压系统的性能验算,确保设计的可行性和安全性。 适合人群:从事工程机械设计、液压系统设计及相关领域的工程师和技术人员,以及对起重机技术感兴趣的高等院校学生和研究人员。 使用场景及目标:①为从事汽车起重机液压系统设计的工程师提供详细的参考案例;②帮助技术人员理解和掌握液压系统设计的关键技术和计算方法;③为高等院校学生提供学习和研究起重机液压系统设计的实用资料。 其他说明:本文不仅提供了详细的液压系统设计过程,还结合了实际工程应用,确保设计的实用性和可靠性。文中引用了大量参考文献,确保设计依据的科学性和权威性。阅读本文有助于读者深入了解汽车起重机液压系统的设计原理和实现方法,为实际工程应用提供有力支持。
Unity Beautify 3 - Advanced Post Processing 23.0版本
基于数据包络分析的中国旅游业发展效率特征
【项目资源】: 物联网项目适用于从基础到高级的各种项目,特别是在性能要求较高的场景中,比如操作系统开发、嵌入式编程和底层系统编程。如果您是初学者,可以从简单的控制台程序开始练习;如果是进阶开发者,可以尝试涉及硬件或网络的项目。 【项目质量】: 所有源码都经过严格测试,可以直接运行。 功能在确认正常工作后才上传。 【适用人群】: 适用于希望学习不同技术领域的小白或进阶学习者。 可作为毕设项目、课程设计、大作业、工程实训或初期项目立项。 【附加价值】: 项目具有较高的学习借鉴价值,也可直接拿来修改复刻。 对于有一定基础或热衷于研究的人来说,可以在这些基础代码上进行修改和扩展,实现其他功能。 【沟通交流】: 有任何使用上的问题,欢迎随时与博主沟通,博主会及时解答。 鼓励下载和使用,并欢迎大家互相学习,共同进步。 # 注意 1. 本资源仅用于开源学习和技术交流。不可商用等,一切后果由使用者承担。 2. 部分字体以及插图等来自网络,若是侵权请联系删除。
# 基于蓝牙技术的多通道键盘 ## 项目简介 在多设备工作环境中,用户常常需要在家庭电脑、工作笔记本或平板电脑之间频繁切换键盘输入,这不仅占用了大量桌面空间,而且操作不便。本项目旨在通过蓝牙技术,设计一款能够同时连接多个设备并实现一键切换的多通道键盘,从而简化用户的操作流程,提高工作效率。 ## 项目的主要特性和功能 1. 多设备连接键盘可以同时连接多达三个不同的设备。 2. 一键切换通过按键即可快速切换输入目标设备。 3. 高性能微控制器采用ATMega32u4微控制器,提供足够的GPIO引脚,支持Arduino编程环境,便于固件开发和升级。 4. 蓝牙模块使用RN42蓝牙模块,确保稳定的设备连接和数据传输。 5. 电压调节器使用MIC4680电压调节器,确保系统稳定供电。 ## 安装使用步骤 1. 硬件准备 获取ATMega32u4微控制器、RN42蓝牙模块、MIC4680电压调节器等硬件组件。 2. 电路设计
【项目资源】: 单片机项目适用于从基础到高级的各种项目,特别是在性能要求较高的场景中,比如操作系统开发、嵌入式编程和底层系统编程。如果您是初学者,可以从简单的控制台程序开始练习;如果是进阶开发者,可以尝试涉及硬件或网络的项目。 【项目质量】: 所有源码都经过严格测试,可以直接运行。 功能在确认正常工作后才上传。 【适用人群】: 适用于希望学习不同技术领域的小白或进阶学习者。 可作为毕设项目、课程设计、大作业、工程实训或初期项目立项。 【附加价值】: 项目具有较高的学习借鉴价值,也可直接拿来修改复刻。 对于有一定基础或热衷于研究的人来说,可以在这些基础代码上进行修改和扩展,实现其他功能。 【沟通交流】: 有任何使用上的问题,欢迎随时与博主沟通,博主会及时解答。 鼓励下载和使用,并欢迎大家互相学习,共同进步。 # 注意 1. 本资源仅用于开源学习和技术交流。不可商用等,一切后果由使用者承担。 2. 部分字体以及插图等来自网络,若是侵权请联系删除。
基于Vue.js和SpringBoot的研究生调研管理系统.zip
地理信息文件,许昌市各县区政区图,shp格式,可编辑
资源内项目源码是来自个人的毕业设计,代码都测试ok,包含源码、数据集、可视化页面和部署说明,可产生核心指标曲线图、混淆矩阵、F1分数曲线、精确率-召回率曲线、验证集预测结果、标签分布图。都是运行成功后才上传资源,毕设答辩评审绝对信服的保底85分以上,放心下载使用,拿来就能用。包含源码、数据集、可视化页面和部署说明一站式服务,拿来就能用的绝对好资源!!! 项目备注 1、该资源内项目代码都经过测试运行成功,功能ok的情况下才上传的,请放心下载使用! 2、本项目适合计算机相关专业(如计科、人工智能、通信工程、自动化、电子信息等)的在校学生、老师或者企业员工下载学习,也适合小白学习进阶,当然也可作为毕设项目、课程设计、大作业、项目初期立项演示等。 3、如果基础还行,也可在此代码基础上进行修改,以实现其他功能,也可用于毕设、课设、作业等。 下载后请首先打开README.txt文件,仅供学习参考, 切勿用于商业用途。
Scratch放飞气球 2024年9月电子学会scratch三级考试真题源代码 综合考查角色添加、背景添加、初始位置、移动步数、方向旋转、造型切换、左右翻转、碰到边缘反弹、无限循环、条件判断、鼠标控制、碰撞检测等积木的使用;难点在于: 如何实现蝙蝠不断移动 如何实现蝙蝠边移动边挥翅膀 如何实现Ripley跟随鼠标移动 如何实现蝙蝠碰到Ripley移到随机位置 充分掌握重复执行和碰撞检测积木的使用 详细解题思路和步骤可以查看博客: https://scratch.blog.csdn.net/article/details/142934767 小兔子编程给小朋友们分享各种少儿编程(Scratch编程、python编程、C++编程等)学习、考级和比赛相关资料;更多少儿编程相关的学习资料,可以访问博主博客 https://blog.csdn.net/frank2102 期待小朋友们相互交流学习,有什么问题,建议或者意见可以直接给博主留言,或者私下,博主看到后会第一时间给到您相应的回复
【项目资源】: 物联网项目适用于从基础到高级的各种项目,特别是在性能要求较高的场景中,比如操作系统开发、嵌入式编程和底层系统编程。如果您是初学者,可以从简单的控制台程序开始练习;如果是进阶开发者,可以尝试涉及硬件或网络的项目。 【项目质量】: 所有源码都经过严格测试,可以直接运行。 功能在确认正常工作后才上传。 【适用人群】: 适用于希望学习不同技术领域的小白或进阶学习者。 可作为毕设项目、课程设计、大作业、工程实训或初期项目立项。 【附加价值】: 项目具有较高的学习借鉴价值,也可直接拿来修改复刻。 对于有一定基础或热衷于研究的人来说,可以在这些基础代码上进行修改和扩展,实现其他功能。 【沟通交流】: 有任何使用上的问题,欢迎随时与博主沟通,博主会及时解答。 鼓励下载和使用,并欢迎大家互相学习,共同进步。 # 注意 1. 本资源仅用于开源学习和技术交流。不可商用等,一切后果由使用者承担。 2. 部分字体以及插图等来自网络,若是侵权请联系删除。
前端分析-2023071100789s102102
【项目资源】: 物联网项目适用于从基础到高级的各种项目,特别是在性能要求较高的场景中,比如操作系统开发、嵌入式编程和底层系统编程。如果您是初学者,可以从简单的控制台程序开始练习;如果是进阶开发者,可以尝试涉及硬件或网络的项目。 【项目质量】: 所有源码都经过严格测试,可以直接运行。 功能在确认正常工作后才上传。 【适用人群】: 适用于希望学习不同技术领域的小白或进阶学习者。 可作为毕设项目、课程设计、大作业、工程实训或初期项目立项。 【附加价值】: 项目具有较高的学习借鉴价值,也可直接拿来修改复刻。 对于有一定基础或热衷于研究的人来说,可以在这些基础代码上进行修改和扩展,实现其他功能。 【沟通交流】: 有任何使用上的问题,欢迎随时与博主沟通,博主会及时解答。 鼓励下载和使用,并欢迎大家互相学习,共同进步。 # 注意 1. 本资源仅用于开源学习和技术交流。不可商用等,一切后果由使用者承担。 2. 部分字体以及插图等来自网络,若是侵权请联系删除。
风玫瑰图的数据包,直接导入即可