- 浏览: 70797 次
- 性别:
- 来自: 深圳
最新评论
-
dudong0726:
不错
flex MP3播放器开发二(单歌曲播放) -
三尺寒冰:
楼主能共享一下源代码吗???
flex MP3播放器开发三(进度条显示) -
狂放不羁:
引用 另外 Hibernate 生成的 sql 也实在是太难看 ...
我为什么选择 iBatis 而不是 Hibernate(对于正在选型的人的建议) -
jimzhao:
有一个gif,按你的方法处理了一下,可以动画的时候,中间出现很 ...
imagick 处理 gif 切割 或者是 缩放 -
bigplum:
好东西
imagick 处理 gif 切割 或者是 缩放
mx:ProgressBar实现加载歌曲缓冲进度条
ProgressBar有三大mode模式,分别为event、manual、polled,event为基于事件驱动模式,可设置source对象自动显示加载进程;manual为手动模式,需要调用ProgressBar.setProgress()方法设置滚动条进度;polled为轮询模式,本例使用的manual模式,Sound加载load请求歌曲添加一个ProgressEvent.PROGRESS处理中监听事件,然后根据Sound已加载的bytes和bytesTotal数,设置setProgress进度。这里需要注意在切换歌曲的时候先要移除ProgressEvent.PROGRESS事件,否则之前播放歌曲还未加载完又切换load新歌曲时回出现ProgressBar触发多个PROGRESS事件被设置进度出现来回滚动的问题。
mx:HSlide调节滑秆
这个控件在本例中2处使用,实现对播放进度和声音大小的控制。最一开始调整播放进度的问题难倒了我很久,因为在歌曲播放过程中HSlide要自动滑动当前播放位置,同时又需要能手动拖动播放位置,HSlide本来有一个很好的change事件用来侦听改变,但是我使用定时器设置HSlide的value的时竟然也给我触发change事件,参考了Adobe哥官网的帮助文档,说是Slider 组件的值因鼠标或键盘交互操作而改变时调度,如果 liveDragging 属性是 true,则在用户移动滑块时持续调度该事件。 如果 liveDragging 是 false,则在用户释放滑块时调度该事件。但是无论我怎么设置,在代码里改变了HSlide的value值怎会触发change事件,不是说在用户交互操作而改变时调度吗?无赖啊,后来只能折中采取监听thumbDrag滑秆拖动时事件,这个事件Adobe哥的解释是当按下滑块并随后随鼠标移动时调度,这样会有一个小问题,就是需要拖动滑秆按下时才会触发,点击无效。
SoundMixer.computeSpectrum()分析音频曲线
本例你看到显示的音频曲线其实是右64个绘制成条状的Canvas控件排列而成,然后使用定时器每间隔100毫秒重新设置他们的scaleY位置以呈现出变幻曲线的效果,代码只有三行很简单,具体可参见我下面源码给出的timerTick事件。这里为什么要用定时器呢?在网上看别人是监听Event.ENTER_FRAME事件重绘音频曲线的,不想搞那么麻烦就直接用定时器了,随便根据bytesTotal和bytesLoaded计算下歌曲播放时间,使用100毫秒的定时器也并好耗站资源,CPU没有涨很高。
mxml代码如下:
ProgressBar有三大mode模式,分别为event、manual、polled,event为基于事件驱动模式,可设置source对象自动显示加载进程;manual为手动模式,需要调用ProgressBar.setProgress()方法设置滚动条进度;polled为轮询模式,本例使用的manual模式,Sound加载load请求歌曲添加一个ProgressEvent.PROGRESS处理中监听事件,然后根据Sound已加载的bytes和bytesTotal数,设置setProgress进度。这里需要注意在切换歌曲的时候先要移除ProgressEvent.PROGRESS事件,否则之前播放歌曲还未加载完又切换load新歌曲时回出现ProgressBar触发多个PROGRESS事件被设置进度出现来回滚动的问题。
mx:HSlide调节滑秆
这个控件在本例中2处使用,实现对播放进度和声音大小的控制。最一开始调整播放进度的问题难倒了我很久,因为在歌曲播放过程中HSlide要自动滑动当前播放位置,同时又需要能手动拖动播放位置,HSlide本来有一个很好的change事件用来侦听改变,但是我使用定时器设置HSlide的value的时竟然也给我触发change事件,参考了Adobe哥官网的帮助文档,说是Slider 组件的值因鼠标或键盘交互操作而改变时调度,如果 liveDragging 属性是 true,则在用户移动滑块时持续调度该事件。 如果 liveDragging 是 false,则在用户释放滑块时调度该事件。但是无论我怎么设置,在代码里改变了HSlide的value值怎会触发change事件,不是说在用户交互操作而改变时调度吗?无赖啊,后来只能折中采取监听thumbDrag滑秆拖动时事件,这个事件Adobe哥的解释是当按下滑块并随后随鼠标移动时调度,这样会有一个小问题,就是需要拖动滑秆按下时才会触发,点击无效。
SoundMixer.computeSpectrum()分析音频曲线
本例你看到显示的音频曲线其实是右64个绘制成条状的Canvas控件排列而成,然后使用定时器每间隔100毫秒重新设置他们的scaleY位置以呈现出变幻曲线的效果,代码只有三行很简单,具体可参见我下面源码给出的timerTick事件。这里为什么要用定时器呢?在网上看别人是监听Event.ENTER_FRAME事件重绘音频曲线的,不想搞那么麻烦就直接用定时器了,随便根据bytesTotal和bytesLoaded计算下歌曲播放时间,使用100毫秒的定时器也并好耗站资源,CPU没有涨很高。
mxml代码如下:
<?xml version="1.0" encoding="utf-8"?><mx:Application xmlns:mx="http://www.adobe.com/2006/mxml" verticalGap="0" scroll="false" backgroundAlpha="0" horizontalScrollPolicy="off" verticalScrollPolicy="off" verticalAlign="middle" horizontalAlign="center" initialize="init(event)" layout="vertical" fontSize="14" paddingLeft="0" paddingTop="0" paddingRight="0" paddingBottom="0" > <mx:Script> <![CDATA[ import mx.formatters.DateFormatter; import mx.effects.SoundEffect; import mx.events.SliderEvent; import mx.core.SoundAsset; import mx.controls.Alert; import mx.managers.CursorManager; import flash.media.*; import flash.utils.Timer; [Embed(source="images/cursor.gif")] private var cursorHand : Class;//图标 private var xml:XML; private var xmlPath:String = "/flex/bin-debug/song.xml"; private var currIndex : Number = 0; private var song :Sound; private var channel :SoundChannel; private var position : Number = 0; // 保存 512 个声音波形的快照 private var bytes:ByteArray = new ByteArray(); // SoundBar 的个数 private var barNum:uint = 64; // 保存所有 SoundBar 的引用 private var soundBars:Array = new Array(); //定时器 private var timer : Timer; //Application的initialize初试化事件 private function init(event:Event):void { var loader:URLLoader = new URLLoader(); loader.load(new URLRequest(xmlPath)); loader.addEventListener(Event.COMPLETE,Xml_Complete); timer = new Timer(100); timer.addEventListener(TimerEvent.TIMER,timerTick); var barWidth:Number = boxSoundBar.width*1.00/barNum; // 初始化Canvas为音频条,放入舞台并加入数组 for (var i:uint = 0; i < barNum; i++) { var soundBar:Canvas = new Canvas(); soundBar.width = barWidth; soundBar.height = boxSoundBar.height; soundBar.x = i * barWidth; soundBar.y = 0; var g:Graphics = soundBar.graphics; g.lineStyle(1,0x6688AA,1); g.beginGradientFill(GradientType.RADIAL,[0x33cc00,0x456628],[1,1],[0,255],null,SpreadMethod.REFLECT,InterpolationMethod.RGB,0); g.drawRect(0,0,soundBar.width,soundBar.height); g.endFill(); boxSoundBar.addChild(soundBar); soundBars.push(soundBar); } // 隐藏一些内建的鼠标右键菜单项 this.contextMenu.hideBuiltInItems(); var contextMenuItem : ContextMenuItem = new ContextMenuItem("Powered By: Jonllen"); contextMenuItem.enabled = false; contextMenu.customItems.push(contextMenuItem); this.contextMenu.customItems.push(contextMenuItem); //更改鼠标图标 CursorManager.setCursor(cursorHand); } //读取XML文件完成事件 private function Xml_Complete(event:Event):void { xml = new XML(event.target.data); if(xml.item.length()>=1) { listSong.dataProvider= xml.item.name; listSong.selectedIndex = 0; //手动触发List的Change事件 listSong.dispatchEvent(new mx.events.ListEvent(Event.CHANGE, true, false)); } } //List选择歌曲改变事件 private function Xml_Change(event:Event):void { currIndex = event.target.selectedIndex; timer.stop(); //停止声音文件的加载 if( song!=null ) { //移除之前加载PROGRESS事件对songProgress进度条的控制 song.removeEventListener(ProgressEvent.PROGRESS,songProgress_Change); if( song.isBuffering ) song.close(); } song = new Sound(); var url : String = xml.item[currIndex].url; var source:URLRequest = new URLRequest(url); song.load(source); song.addEventListener(ProgressEvent.PROGRESS, songProgress_Change); song.addEventListener(IOErrorEvent.IO_ERROR, songProgress_Error); position = 0; songStart(); } //歌曲播放完成 private function songProgress_Complete(e:Event):void { if(currIndex == xml.item.length()-1) { currIndex = 0; }else { currIndex++; } listSong.selectedIndex = currIndex; listSong.dispatchEvent(new mx.events.ListEvent(Event.CHANGE, true, false)); } //加载歌曲失败 private function songProgress_Error(e:IOErrorEvent):void { Alert.show("文件不存在!","系统提示"); } //开始播放歌曲 private function songStart():void { if ( channel != null ){ channel.stop(); } lblName.text = xml.item[currIndex].name; channel = song.play(position,int.MAX_VALUE); var length :Number = song.length*song.bytesTotal/song.bytesLoaded; var date : Date = new Date(); date.time = length; var dt : DateFormatter = new DateFormatter(); dt.formatString="NN:SS"; var totalTime : String = dt.format(date); date.time = channel.position; lblTime.text = dt.format(date) + " | " + totalTime; lblStatus.text = "播放"; var soundcontrol : SoundTransform = channel.soundTransform; soundcontrol.volume = volumeSlider.value; channel.soundTransform= soundcontrol; timer.start(); boxSoundBar.visible = true; } //停止歌曲播放 private function songStop():void { timer.stop(); position = 0; boxSoundBar.visible = false; lblTime.text = "00:00 |"+lblTime.text.split("|")[1]; lblStatus.text = "停止"; songSlider.value = songSlider.minimum; songProgress.setProgress(songProgress.minimum,songProgress.maximum); if ( channel != null ) { channel.stop(); } } //暂停歌曲播放 private function songPause():void { if ( channel != null ){ timer.stop(); position = channel.position; channel.stop(); lblStatus.text = "暂停"; } } //加载歌曲进度条显示 private function songProgress_Change(e:ProgressEvent):void { var percent:int = Math.round(e.bytesLoaded * 100 / e.bytesTotal); songProgress.setProgress(e.bytesLoaded,e.bytesTotal); } //定时器方法 private function timerTick( e:TimerEvent):void { if( channel!=null) { var length :Number = song.length*song.bytesTotal/song.bytesLoaded; var date : Date = new Date(); date.time = length; var dt : DateFormatter = new DateFormatter(); dt.formatString="NN:SS"; var totalTime : String = dt.format(date); date.time = channel.position; lblTime.text = dt.format(date) + " | " + totalTime; songSlider.value=100*channel.position/length; if( songSlider.value>=songSlider.maximum){ timer.stop(); songProgress_Complete(null); return; } SoundMixer.computeSpectrum(bytes, false, 0); for (var i:uint = 0; i < barNum; i++) { soundBars[i].scaleY = bytes.readFloat(); } } } //歌曲进度调整事件 internal function songSlider_Change(e:SliderEvent):void{ timer.stop(); if ( channel != null ){ var length :Number = song.length*song.bytesTotal/song.bytesLoaded; position = e.value*length/100; songStart(); } } //声音大小调整事件 internal function changeVolume(evt:SliderEvent):void{ if ( channel != null ){ var soundcontrol : SoundTransform = channel.soundTransform; soundcontrol.volume = evt.value; channel.soundTransform= soundcontrol; } } //设置歌曲播放时间和总时间 private function setTimeStatus():void { var length :Number = song.length*song.bytesTotal/song.bytesLoaded; var date : Date = new Date(); date.time = length; var dt : DateFormatter = new DateFormatter(); dt.formatString="NN:SS"; var totalTime : String = dt.format(date); date.time = channel.position; lblTime.text = dt.format(date) + " | " + totalTime; } ]]> </mx:Script> <mx:HBox width="100%" verticalGap="0" verticalAlign="middle" horizontalAlign="center"> <mx:Canvas width="440" borderColor="#CCCCCC" borderStyle="solid" height="171"> <mx:Label id="lblName" x="5" fontSize="18" y="10" text=""/> <mx:HBox id="boxSoundBar" horizontalGap="0" verticalAlign="middle" width="192" height="50" x="5" y="39" visible="false"></mx:HBox> <mx:ProgressBar id="songProgress" label="" width="290" height="3" mode="manual" textAlign="left" labelPlacement="center" fontSize="3" x="10" y="97" minimum="0" maximum="100" barColor="yellow" trackColors="[white, haloSilver]"/> <mx:HSlider id="songSlider" styleName="song" value="0" showTrackHighlight="true" x="5" y="85" thumbDrag="songSlider_Change(event)" width="300" height="22" minimum="0" maximum="100" liveDragging="false" snapInterval="1" toolTip="拖动调整播放进度"> </mx:HSlider> <mx:Label id="lblStatus" x="243" y="41" text=""/> <mx:Label id="lblTime" x="205" y="66" text="00:00 | 5:23"/> <mx:Button x="10" y="124" label="Play" click="songStart()"/> <mx:Button x="74" y="124" label="Pause" click="songPause()"/> <mx:Button x="152" y="124" label="Stop" click="songStop()"/> <mx:HSlider id="volumeSlider" styleName="volume" change="changeVolume(event)" showTrackHighlight="true" value="0.5" x="222" y="133" width="81" minimum="0" maximum="10" liveDragging="true" snapInterval="0.1" toolTip="音量调节" /> <mx:Label x="308" fontSize="18" y="10" text="歌曲列表"/> <mx:List id="listSong" alpha="0.25" x="308" y="43" height="116" change="Xml_Change(event)" width="130" toolTip="点击选择歌曲"></mx:List> </mx:Canvas> </mx:HBox></mx:Application>
发表评论
-
flex MP3播放器开发四(我的播放列表)
2010-10-08 22:57 1329flex MP3播放器开发四(我的播放列表) 研究过soso的 ... -
flex MP3播放器开发三(进度条显示)
2010-09-26 22:35 1553播放进度条和加载进度条是花了不少时间。。 开 ... -
flex MP3播放器开发二(单歌曲播放)
2010-09-25 23:39 1892由于flex音乐组件Sound比较强大,基本上能满足播放 ... -
flex MP3播放器开发一(思路篇)
2010-09-25 23:24 1330很早之前就计划开发一个flex mp3播放器,但苦于工作 ... -
游戏战歌网 仿soso音乐 flex播放器
2010-08-13 09:11 1351137战歌网 仿soso音乐 flex播放器 经过2个月的努 ... -
Flex播放器同步显示歌词
2010-07-14 16:00 1794播放歌曲时要同步显示歌词,首先必须要能解析出lrc格式的歌词文 ...
相关推荐
在创建音频播放器时,我们需要用到几个关键的Flex组件,包括Slider(用于控制音量和播放进度)、Button(用于播放、暂停、停止等操作)以及TimelineControl(用于显示时间线)。此外,我们还需要一个自定义组件来...
Flex播放器是一种基于Adobe Flex技术构建的多媒体播放软件,它允许开发者创建丰富的、交互式的网络应用程序,特别是用于视频和音频的播放。Flex是基于ActionScript 3.0和Flash Player运行时,提供了一套强大的开发...
总的来说,开发一个Flex和AIR的MP3播放器涉及到多个方面:理解Flex的MXML和ActionScript、掌握音频处理、设计用户界面、利用AIR特性以及可能的动画效果。通过这个教程,你应该能够逐步学会如何创建一个功能完备且...
Flex播放器是一款基于Adobe Flex技术开发的多媒体播放解决方案,它允许开发者创建丰富的、交互式的视频和音频播放体验。Adobe Flex是一套用于构建富互联网应用程序(RIA)的框架,基于ActionScript编程语言和Flex ...
Flex播放器是一种基于Adobe Flex技术开发的多媒体播放解决方案。Adobe Flex是用于构建富互联网应用程序(RIA)的开源框架,它允许开发者使用ActionScript编程语言和MXML标记语言创建交互式的、基于Flash的用户界面。...
### Flex进度条实现原理与应用 #### 一、引言 在现代Web开发中,进度条作为一种常见的UI组件,主要用于指示加载或处理过程中的完成情况。对于基于Flex框架的应用而言,进度条同样扮演着重要的角色,尤其是在应用...
这是Flex SDK中的一个核心组件,它可以处理音频和视频内容。通过创建一个MediaElement实例,我们可以加载FlV文件并控制其播放、暂停、停止等操作。以下是一个简单的FlV播放器的代码示例: ```actionscript ('...
Flex进度条是一种用于显示操作进度的图形用户界面组件,尤其适用于那些需要花费一定时间的异步操作,比如文件下载、音乐或视频的加载以及登录过程等。通过进度条,用户可以直观地看到当前操作的完成情况,从而减少...
在Flex编程中,指定文件下载并带有进度条功能是一项常见的需求,这主要涉及到网络I/O操作、事件处理以及用户界面的更新。以下是对这个主题的详细讲解。 首先,Flex是Adobe开发的一种开源富互联网应用程序(RIA)...
例如,`VideoDisplay`组件会触发`play`、`pause`和`stop`事件,这些事件需要绑定到相应的处理函数来实现播放、暂停和停止的功能。`Slider`和`VolumeBar`的`change`事件则用于更新播放位置和音量。 4. **播放模式...
通过查看和学习这个示例代码,你可以深入理解如何在Flex中创建自定义的UI组件,特别是如何实现具有吸引力的视觉效果和交互功能的圆形进度条。这对于提升Flex编程技巧和用户体验设计能力非常有帮助。
Flex音频播放器是一种基于Adobe Flex技术构建的交互式媒体播放器,它允许用户不仅能够播放音频文件,还提供了丰富的用户体验,如拖放播放位置和调节音量大小的功能。Flex是Adobe开发的一个开源框架,主要用于创建富...
Flex播放器源码是基于Adobe Flex框架开发的一款...总的来说,通过深入研究这个Flex播放器源码,开发者不仅能提升ActionScript和Flex的编程技能,还能了解富互联网应用的开发流程,以及多媒体播放器的设计和实现原理。
通过逐步解析和实现这些示例,开发者不仅可以掌握Flex的基本用法,还能了解到如何利用Flex构建复杂的多媒体应用。对于想要进入Flash和Flex开发领域的人来说,这是一个宝贵的资源,有助于他们快速提升技能,实现自己...
Flex播放器是基于Adobe Flex框架开发的多媒体播放应用程序,它允许用户播放音频和视频内容。在本项目中,我们关注的是实现暂停、上一首和下一首功能的代码实现。Flex作为一个强大的RIA(富互联网应用)开发平台,...
Flex播放器是一款基于Adobe Flex技术构建的多媒体播放解决方案,它允许开发者创建丰富的、交互式的视频和音频播放体验。本资源包含Flex播放器的源代码,以及使用JSP(JavaServer Pages)实现的具体部署过程文档,这...
标题中的“Flex进度条小例子”表明我们将讨论的是使用Adobe Flex技术实现的进度条组件的应用。Flex是一个开源的、基于MXML和ActionScript的框架,用于构建富互联网应用程序(RIA)。在Flex中,我们可以创建自定义的...
本文将深入探讨如何在Flex 4中创建和定制进度条的皮肤。 首先,我们需要了解Flex 4中的皮肤架构。Flex 4引入了Spark组件模型,其中皮肤是组件外观的独立层,可以通过CSS样式或MXML代码进行定义。每个组件都有一个...
直接上代码,在Flash Builder 4中新建 FLEX项目,复制代码可以可以直接运行 需要将 file = "D:\\voice\\3791.MP3"; 改为自己的路径 以后还准备增加流式播放!