`
wptc
  • 浏览: 22672 次
  • 性别: Icon_minigender_1
  • 来自: 重庆
社区版块
存档分类
最新评论

Flex版Mp3播放器----大部分功能版一,前台

阅读更多

利用假期学习了下flex,个人感觉要做点啥东西才能算的上熟练,恰逢工作室让写一个听歌的程序,自己就尝试写了个,菜鸟作品,多多批评。

 

首先 给个预览看下

 

登录页面:(javaeye的加入图片太麻烦了 要看的同志们到这里看:http://user.qzone.qq.com/361276898 里面听听那个相册就可以看了)

 

总体将:采用 Hibernate + Spring + flex + Blades(忘了单词咋写的 ^_^) 

 

一,前台的代码 newting.mxml

 

<?xml version="1.0" encoding="utf-8"?> <mx:Application xmlns:mx="http://www.adobe.com/2006/mxml" layout="absolute" backgroundImage="images/green/bg.png" creationComplete="init()"> <!--远程访问对象--> <mx:RemoteObject id="userServiceControl" destination="userControl"> </mx:RemoteObject> <mx:RemoteObject id="songServiceControl" destination="songControl"> </mx:RemoteObject> <mx:Script> <![CDATA[ import mx.utils.URLUtil; import mx.events.ResourceEvent; import mx.events.ListEvent; //进入该网站是的初始化 public function init():void{ var url:String = Application.application.url; uploadUrl = URLUtil.getServerName(url)+":"+URLUtil.getPort(url); //提示先登录才能使用 newtingPlayer.selectedChild=login; //默认当前是第一页 internowPage = 0; } public var uploadUrl:String; public var UUName:String; public var downSongName:String; //上一页下一页标志 0表示上一页,1表示下一页 3表示刚进入页面 public var flagPage:Number=3; //默认当前是第一页 public var internowPage:Number=0; //播放和上传的脚本 import cn.jcracker.tingting.TTupload; import cn.jcracker.tingting.Player; import mx.controls.Alert; import mx.collections.*; import mx.utils.ArrayUtil; public var applyNo:Number;//表示目前的应用 0为听歌历史 1为最新上传 2为最热应用 3为随机听歌 //用户名 public var userName:String; //播放标志,0 表示暂停,1表示播放 public var playFlag:Number = 1; [Bindable] public var player:Player; //播放前的准备工作 private function playInit():void{ //默认歌词显示 lrcPanel.visible = true; uploadPanel.visible = false; //默认音量大小 tingVolume.value = 1.5; //默认不播放 playFlag = 0; } private function Play(player:Player):void{ switch(playFlag){ case 0: player.play(); playProgressControl.value = player.nowProgress; playControl.source = "images/green/ctrl_pause.png"; playFlag = 1; break; case 1: player.pause(); playControl.source = "images/green/ctrl_play.png"; playFlag = 0; break; default: player.pause(); playControl.source = "images/green/ctrl_play.png"; playFlag = 0; } } private function ChangeVolume(player:Player):void{ volumePanel.source = "images/green/ctrl_vol.png"; player.volume = tingVolume.value; player.changeVolume(); } private function stopVolume(player:Player):void{ player.volume = 0; player.changeVolume(); volumePanel.source = "images/green/ctrl_vol_mute.png"; } private function ChangeProgress(player:Player):void{ player.nowProgress = playProgressControl.value; player.changeProcess(); //恢复到值的音量 ChangeVolume(player); } private function ShowLrc(player:Player):void{ uploadPanel.visible = false; lrcPanel.visible = true; } private function ShowUpload(player:Player):void{ lrcPanel.visible = false; uploadPanel.visible = true; } //进度条在下载完成后消失 private function dispear(player:Player):void{ downloadBar.visible = false; } //文件上传处理代码 public var ttupload:TTupload = new TTupload(); public function UploadMp3():void{ ttupload.uploadMp3(); } public function UploadLrc():void{ ttupload.uploadLrc(); } public function DownloadMp3():void{ ttupload.downloadMp3(uploadUrl,UUName); } public function UploadNow():void{ ttupload.proceedWithUpload(uploadUrl,userNameLabel.text,saySomethingToOne.text.toString()); } /** * 页面登录脚本开始 * */ import mx.rpc.events.FaultEvent; import mx.rpc.events.ResultEvent; import mx.events.ResizeEvent; import mx.controls.Alert; //用户登录 public function loginflex(event:Event):void{ userName =loguserName.text; var password:String = password.text; userServiceControl.login(userName,password); userServiceControl.addEventListener(ResultEvent.RESULT,loginSuccess); userServiceControl.addEventListener(FaultEvent.FAULT,errorHandler); } //游客登录 public function loginflexAsGuest(event:Event):void{ userName ="guest"; var password:String ="guest"; userServiceControl.login(userName,password); userServiceControl.addEventListener(ResultEvent.RESULT,loginSuccess); userServiceControl.addEventListener(FaultEvent.FAULT,errorHandler); } //登录失败处理 public function errorHandler(e:FaultEvent):void{ userServiceControl.removeEventListener(FaultEvent.FAULT,errorHandler); Alert.show("用户名或密码错误!"); } //登录成功后的处理 public function loginSuccess(e:ResultEvent):void{ //调用初始化播放器函数 playInit(); //检查是否是会员 userName = e.result.toString(); if(userName =="guest"){ uploadPanel.enabled = false; } //显示该用户的名称在播放器上 userNameLabel.text = userName; //跳转到登录成功页面, 打开huiyuan 画布 newtingPlayer.selectedChild=huiyuan; //跳转至最新上传 歌曲应用 newSong(internowPage); userServiceControl.removeEventListener(ResultEvent.RESULT,loginSuccess); // internowPage = internowPage +1; } /** * 页面登录脚本结束 * */ //-----------------------------开始处理应用请求------------------------------------------------- public function myList(nowPage:Number):void{ if(userName == "guest"){ Alert.show("未注册用户,没有歌曲收藏!"); }else { //发送得到列表请求 songServiceControl.getMyList(userName,nowPage); if(nowPage == 0 ){internowPage = 0} songServiceControl.addEventListener(ResultEvent.RESULT,myListSuccess); songServiceControl.addEventListener(FaultEvent.FAULT,myListerrorHandler); applyNo = 0; } } //获取列表成功处理函数 public function myListSuccess(e:ResultEvent):void{ // Alert.show("listSuccess"); // Alert.show("internowPage:"+internowPage); if(e!=null){ var mylist:ArrayCollection =e.result as ArrayCollection; list.dataProvider=mylist; //Alert.show("myList:"+mylist.length); // //报异常这里 // if( mylist.length > 0){ // nextpagelable.visible = true; // uppagelable.visible = true; ////// Alert.show("listSoon"); // list.dataProvider=mylist; // }else{ //// Alert.show("无歌曲列表"); // } }else{ Alert.show("您没有收藏的歌曲!"); } // songServiceControl.removeEventListener(ResultEvent.RESULT,myListSuccess); } //获取列表失败处理函数 public function myListerrorHandler(e:FaultEvent):void{ songServiceControl.removeEventListener(FaultEvent.FAULT,myListerrorHandler); Alert.show("获取列表失败,请在论坛反映。"); } //单击歌曲列表中的歌曲名称响应函数 public function playTheSong(e:ListEvent):void{ //先停止正在播放的歌曲 if(player!=null){ player.stop(); } var songName:String = (e.target as DataGrid).selectedItem[(e.target as DataGrid).columns[e.columnIndex].dataField]; downSongName = songName; //在载制定songName的uuName songServiceControl.getUUName(songName); songServiceControl.addEventListener(ResultEvent.RESULT,getUUName); var userName:String = userNameLabel.text; //replace 替换数据库中名称的.mp3为.lrc //添加这首歌曲到我的听歌历史 songServiceControl.addMyList(songName,userName); songServiceControl.addPlayTimes(songName); } public function getUUName(e:ResultEvent):void{ UUName = e.result as String; UUName = UUName; player = new Player(uploadUrl,UUName,UUName.replace(".mp3",".lrc")); playInit(); Play(player); //重新加载列表 switch(applyNo){ case 0:myList(internowPage);break; case 1:newSong(internowPage);break; case 2:hotSong(internowPage);break; case 3:randSong(internowPage);break; default:newSong(internowPage); } songServiceControl.removeEventListener(ResultEvent.RESULT,getUUName); songServiceControl.addEventListener(ResultEvent.RESULT,getSomeWords); songServiceControl.addEventListener(FaultEvent.FAULT,myListerrorHandler); } public function getSomeWords(es:ResultEvent):void{ someWords.text = es.result.toString(); songServiceControl.removeEventListener(ResultEvent.RESULT,getSomeWords); } //播放上一首歌曲 public function prevSong():void{ Alert.show("此功能尚未实现,请直接点击歌曲播放!"); } //最新上传的二十首歌曲 public function newSong(nowPage:Number):void{ //页面计数同步 if(nowPage == 0 ){internowPage = 0} // Alert.show("最新上传的歌曲"); songServiceControl.getNewSong(nowPage); songServiceControl.addEventListener(ResultEvent.RESULT,myListSuccess); songServiceControl.addEventListener(FaultEvent.FAULT,myListerrorHandler); applyNo = 1; } //最热的二十首歌曲 public function hotSong(nowPage:Number):void{ // Alert.show("It's very hot"); songServiceControl.getHotSong(nowPage); if(nowPage == 0 ){internowPage = 0} songServiceControl.addEventListener(ResultEvent.RESULT,myListSuccess); songServiceControl.addEventListener(FaultEvent.FAULT,myListerrorHandler); applyNo = 2; } //随机听歌 public function randSong(nowPage:Number):void{ // Alert.show("Rand"); songServiceControl.getRandSong(nowPage); if(nowPage == 0 ){internowPage = 0} songServiceControl.addEventListener(ResultEvent.RESULT,myListSuccess); songServiceControl.addEventListener(FaultEvent.FAULT,myListerrorHandler); applyNo = 3; } //分页 public function nextPage():void{ flagPage = 1; // Alert.show("internowPage:"+internowPage); switch(applyNo){ case 0:myList(internowPage);break; case 1:newSong(internowPage);break; case 2:hotSong(internowPage);break; case 3:randSong(internowPage);break; } internowPage = internowPage+1; } public function upPage():void{ flagPage = 0; // Alert.show("internowPage:"+internowPage); switch(applyNo){ case 0:myList(internowPage);break; case 1:newSong(internowPage);break; case 2:hotSong(internowPage);break; case 3:randSong(internowPage);break; } internowPage = internowPage -1; } ]]> </mx:Script> <mx:ViewStack id="newtingPlayer"> <!--===============================注册用户听歌页面,有上传功能,开始================================================================--> <mx:Canvas x="0" y="0" width="1275" height="536" id="huiyuan"> <!--天佑听听log--> <mx:Image x="0" y="0" width="1275" source="images/green/tingtingbar.png" height="86"/> <!--听听整个页面--> <mx:Image width="686.4394" height="394.0909" source="images/green/player.png" x="267.8" y="116"/> <!--听听后退按钮--> <!--听听播放按钮--> <mx:Image x="292" y="140" source="images/green/ctrl_play.png" click="Play(player);" id="playControl" width="36"/> <!--听听前进按钮--> <!--听听音量按钮--> <mx:Image x="345" y="152" source="images/green/ctrl_vol.png" click="stopVolume(player)" id="volumePanel"/> <!--听听音量大小滑块--> <mx:HSlider x="367" y="149" height="18" width="224" id="tingVolume" change="ChangeVolume(player)" maximum="2" minimum="0" value="{player.volume}"/> <!--听听播放进度--> <mx:HSlider x="279" y="194" width="312" height="29" id="playProgressControl" value="{player.playProgress}" change="ChangeProgress(player)" allowTrackClick="true" maximum="100" minimum="0"/> <!--听听歌曲列表--> <mx:DataGrid width="229" height="251" rowCount="15" fontSize="12" x="362" y="249" id="list" itemClick="playTheSong(event)"> <mx:columns> <mx:Array> <mx:DataGridColumn headerText="歌曲列表" dataField="songName" width="180" /> </mx:Array> </mx:columns> </mx:DataGrid> <!--听听应用列表--> <mx:DataGrid x="279" y="249" width="85" height="251" fontSize="12"> <mx:columns> <mx:Array> <mx:DataGridColumn headerText="我的应用" dataField="col1" /> </mx:Array> </mx:columns> </mx:DataGrid> <!--听听右边控制面板,通过Js修改为上传歌曲还是歌词显示!--> <!--歌词--> <mx:Label x="654" y="140" text="显示歌词" width="70" height="29" fontSize="12" alpha="1.0" fontWeight="bold" click="ShowLrc(player)"/> <mx:Label x="823" y="140" text="上传歌曲" width="74" height="29" fontSize="12" fontWeight="bold" click="ShowUpload(player)"/> <mx:Canvas x="614" y="177" width="307" height="323" id="lrcPanel"> <mx:Label x="0" y="0" text="对大家说点什么吧!" width="307" height="21" id="someWords" fontSize="12" textAlign="center"/> <mx:TextArea x="0" y="20" width="307" height="303" id="lrc" text="{player.lrc}" fontSize="15" editable="false"/> <mx:Button x="10" y="285" label="下载这首歌" width="287" height="28" fontSize="18" click="DownloadMp3()"/> </mx:Canvas> <!--上传页面--> <!--未注册用户,将uploadpanel隐藏--> <mx:Canvas x="614" y="177" width="307" height="323" id="uploadPanel"> <!-- <mx:Label x="823" y="140" text="上传歌曲" width="74" height="29" fontSize="12" fontWeight="bold" click="ShowUpload()"/> --> <mx:Label x="28" y="59" text="送歌给:" width="90" height="32" fontSize="20" fontWeight="bold" textAlign="right"/> <mx:TextInput x="114" y="59" height="32" width="171" id="saySomethingToOne" fontSize="12"/> <mx:ProgressBar id="uploadProgressBar" source="{ttupload.file}" x="28" y="280" width="257" fontSize="12" indeterminate="false" labelPlacement="center" height="27"/> <mx:Button x="28" y="137" label="浏览歌曲" width="193" height="33" fontSize="18" fontWeight="bold" click="UploadMp3();"/> <mx:Button x="28" y="215" label="浏览歌词" width="193" height="33" fontSize="18" fontWeight="bold" click="UploadLrc();"/> <mx:Button x="229" y="137" label="上传" height="33" width="56" fontSize="12" click="UploadNow()"/> <mx:Button x="229" y="217" label="上传" height="33" width="56" fontSize="12" click="UploadNow()"/> <mx:Label x="28" y="198" text="请保证歌词名与歌曲名相同" width="161" fontSize="12"/> </mx:Canvas> <mx:ProgressBar x="279" y="224" width="312" id="downloadBar" source="{player.mySong}" labelPlacement="center" height="26"/> <mx:Label x="729" y="140" id="userNameLabel" height="29" width="88" fontSize="12" fontWeight="bold" color="#CF590A" fontFamily="Arial" textAlign="center"/> <mx:Button x="279" y="291" label="听过的歌" width="85" fontSize="12" click="myList(0);"/> <mx:Button x="279" y="332" label="最新列表" width="85" fontSize="12" click="newSong(0)"/> <mx:Button x="279" y="373" label="最热列表" width="85" fontSize="12" click="hotSong(0)"/> <mx:Button x="279" y="414" label="随便听听" width="85" fontSize="12" click="randSong(0)"/> <!-- <mx:Label x="372" y="476" text="上一页" id="uppagelable" width="74" height="22" fontSize="12" textAlign="center" fontWeight="bold" click="upPage()"/> <mx:Label x="493" y="476" text="下一页" id="nextpagelable" width="74" height="22" fontSize="12" textAlign="center" fontWeight="bold" click="nextPage()"/> --> </mx:Canvas> <!--===============================注册用户听歌页面,有上传功能,结束================================================================--> <!--=========================================================登录页面开始=====================================================--> <mx:Canvas x="0" y="0" width="1275" height="536" id="login"> <mx:Image x="0" y="0" width="1275" source="images/green/tingtingbar.png" height="86"/> <mx:Panel x="350" y="133" width="468" height="332" layout="absolute" fontSize="14" title="登录" borderColor="#82F5B0"> <mx:Label x="92" y="67" text="用户名:" width="84" fontWeight="bold" fontSize="18"/> <mx:Label x="92" y="114" text="密码:" width="84" fontSize="18" fontWeight="bold" textAlign="left" /> <mx:TextInput x="184" y="67" height="28" width="162" id="loguserName"/> <mx:TextInput x="184" y="114" height="28" width="162" id="password" displayAsPassword="true"/> <mx:Button x="92" y="191" label="注册"/> <mx:Button x="196" y="191" label="登录" click="loginflex(event);"/> <mx:Button x="290" y="191" label="游客" click="loginflexAsGuest(event);"/> </mx:Panel> </mx:Canvas> <!--=========================================================登录页面结束=====================================================--> </mx:ViewStack> </mx:Application>

 

关于以上的  有些函数没有用到在应用中,主要是自己还没那水平,希望以后能补上 .

 

二,配置和后台交互相关的

      remoting-config.xml

 

    

<?xml version="1.0" encoding="UTF-8"?> <service id="remoting-service" class="flex.messaging.services.RemotingService"> <adapters> <adapter-definition id="java-object" class="flex.messaging.services.remoting.adapters.JavaAdapter" default="true"/> </adapters> <default-channels> <channel ref="my-amf"/> </default-channels> <destination id="userControl"> <properties> <source>cn.jcracker.tingting.controller.UserControl</source> </properties> </destination> <destination id="songControl"> <properties> <source>cn.jcracker.tingting.controller.SongControl</source> </properties> </destination> </service>

 

web.xml

  

<?xml version="1.0" encoding="UTF-8"?> <web-app xmlns="http://java.sun.com/xml/ns/j2ee" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" id="WebApp_ID" version="2.4" xsi:schemaLocation="http://java.sun.com/xml/ns/j2ee http://java.sun.com/xml/ns/j2ee/web-app_2_4.xsd"> <display-name>newting</display-name> <context-param id="flex"> <param-name id="flexp">flex.class.path</param-name> <param-value id="flexvalue">/WEB-INF/flex/hotfixes,/WEB-INF/flex/jars</param-value> </context-param> <!-- Http Flex Session attribute and binding listener support --> <listener> <listener-class>flex.messaging.HttpFlexSession</listener-class> </listener> <!-- MessageBroker Servlet --> <servlet> <servlet-name>MessageBrokerServlet</servlet-name> <servlet-class>flex.messaging.MessageBrokerServlet</servlet-class> <init-param> <param-name>services.configuration.file</param-name> <param-value>/WEB-INF/flex/services-config.xml</param-value> </init-param> <init-param> <param-name>flex.write.path</param-name> <param-value>/WEB-INF/flex</param-value> </init-param> <load-on-startup>1</load-on-startup> </servlet> <servlet> <description>This is the description of my J2EE component</description> <display-name>This is the display name of my J2EE component</display-name> <servlet-name>Upload</servlet-name> <servlet-class>cn.jcracker.tingting.Upload</servlet-class> </servlet> <servlet-mapping> <servlet-name>MessageBrokerServlet</servlet-name> <url-pattern>/messagebroker/*</url-pattern> </servlet-mapping> <servlet-mapping> <servlet-name>Upload</servlet-name> <url-pattern>/songupload</url-pattern> </servlet-mapping> <welcome-file-list> <welcome-file>index.html</welcome-file> <welcome-file>index.htm</welcome-file> <welcome-file>index.jsp</welcome-file> <welcome-file>default.html</welcome-file> <welcome-file>default.htm</welcome-file> <welcome-file>default.jsp</welcome-file> </welcome-file-list> <!-- for WebSphere deployment, please uncomment --> <!-- <resource-ref> <description>Flex Messaging WorkManager</description> <res-ref-name>wm/MessagingWorkManager</res-ref-name> <res-type>com.ibm.websphere.asynchbeans.WorkManager</res-type> <res-auth>Container</res-auth> <res-sharing-scope>Shareable</res-sharing-scope> </resource-ref> --> <filter> <filter-name>Filter</filter-name> <filter-class>cn.jcracker.tingting.utils.EncodingUtils</filter-class> </filter> <filter-mapping> <filter-name>Filter</filter-name> <url-pattern>/*</url-pattern> </filter-mapping> <!-- 添加Spring初始化 --> <!-- Spring --> <context-param> <param-name>contextConfigLocation</param-name> <param-value>classpath:applicationContext.xml</param-value> </context-param> <listener> <listener-class>org.springframework.web.context.ContextLoaderListener</listener-class> </listener> <filter> <filter-name>OpenSessionInViewFilter</filter-name> <filter-class>org.springframework.orm.hibernate3.support.OpenSessionInViewFilter</filter-class> <init-param> <param-name>singleSession</param-name> <param-value>false</param-value> </init-param> </filter> <filter-mapping> <filter-name>OpenSessionInViewFilter</filter-name> <url-pattern>/*</url-pattern> </filter-mapping> </web-app>

 至此前台结束! 后面见Flex版Mp3播放器----大部分功能版二,后台。附件也在最后,这里就不上传了!

 

0
0
分享到:
评论

相关推荐

    javaWeb项目源码-ssm网络视频播放器-设计论文-汇报PPT

    本文以JSP为开发技术,实现了一个网络视频播放器。网络视频播放器的主要使用者分为管理员;个人中心、用户管理、视频信息管理、系统公告管理、交流论坛、我的收藏管理、系统管理,前台首页;首页、视频信息、系统...

    flex-ibatis-sping项目的创建

    这种组合不仅能够充分利用`flex`作为前端展示的优势,还能借助`Spring`框架的强大功能以及`MyBatis`的数据库访问能力,构建出高性能且易于维护的应用。 #### 二、创建项目框架 ##### 1. 创建WebProject项目 首先...

    支持歌词的Mp3播放器的设计与实现

    本文介绍的支持歌词功能的MP3播放器采用了模块化设计,主要包括以下几个部分: 1. **媒体主控**:作为前台核心模块,为用户提供播放、暂停、停止、上下曲目切换、音量调节、声道控制等功能,并可打开媒体文件、播放...

    毕业设计-基于JSP+SSM的网络视频播放器-设计与实现(源码+论文+视频).zip

    5.1前台首页功能模块 网络视频播放器,在系统首页可以查看首页、视频信息、系统公告、论坛信息、我的、跳转到后台、客服等内容,如图5-1所示。 图5-1前台首页功能界面图 用户登录,在登录页面可以填写账号、...

    368[计算机毕业设计]基于SSM音乐播放器-源码-视频讲解-LW-PPT.rar

    前台路径地址:localhost:8080/项目名称/front/index.html (无前台不需要输入) 管理员账号:abo 管理员密码:abo 如果您要学会调试运行,一定要去看运行教学 springboot程序运行教学地址: 链接:...

    纯flex网站前台(httpservice、webservice进行数据交互)

    Flex是一种基于Adobe Flash技术的开发框架,用于构建富互联网应用程序(RIA)。在“纯flex网站前台(httpservice、webservice进行数据交互)”这个项目中,我们主要关注的是如何使用Flex来实现与服务器端的数据通信...

    358[计算机毕业设计]基于SSM的网络视频播放器-源码-视频讲解-LW-PPT.rar

    前台路径地址:localhost:8080/项目名称/front/index.html (无前台不需要输入) 管理员账号:abo 管理员密码:abo 如果您要学会调试运行,一定要去看运行教学 springboot程序运行教学地址: 链接:...

    15.网络视频播放器-基于JSP技术+ Mysql+Java+ B/S(可运行源码+数据库+开发文档+lw)

    15.网络视频播放器|基于JSP技术+ Mysql+Java+ B/S结构的网络视频播放器设计与实现(可运行源码+数据库+开发文档+lw) 以JSP为开发技术,实现了一个网络视频播放器。网络视频播放器的主要使用者分为管理员;个人中心、...

    Android音乐播放前台服务

    在Android开发中,创建一个能够持续播放音乐的前端服务(前台服务)是非常常见的需求,尤其对于音乐播放应用来说更是必不可少。本项目“Android音乐播放前台服务”是基于Android Studio实现的,它允许用户在后台或者...

    SpringBoot项目博客系统-包含前台后台前端后端-适合作为Java学习的第一练手项目

    SpringBoot项目博客系统-包含前台后台前端后端-适合作为Java学习的第一练手项目SpringBoot项目博客系统-包含前台后台前端后端-适合作为Java学习的第一练手项目SpringBoot项目博客系统-包含前台后台前端后端-适合作为...

    最新梨花带雨网页音乐播放器二开优化修复美化版全开源版本源码下载.zip

    这款播放器采用thinkphp6框架开发,以XPlayerHTML5为基础,为您呈现一个功能强大的网页播放器前台控制面板。它不仅支持多音乐平台音乐解析,更在二开过程中针对播放器接口问题进行了深入修复。 在二开过程中,我们...

    抽奖程序--前台+后台

    WPF是.NET Framework的一部分,由微软开发,主要用于构建桌面应用程序的用户界面。它提供了丰富的图形渲染能力,支持矢量图形、动画、3D效果等,使得界面设计更加美观和生动。在这款抽奖程序中,WPF可能被用来创建...

    Flex前台分页

    "Flex前台分页"指的是使用Flex(一种基于ActionScript的开源框架)在客户端实现分页功能。Flex允许开发者创建丰富的互联网应用,而前台分页意味着分页逻辑和数据处理在用户浏览器端进行,而不是服务器端。 1. **...

    Java毕业设计-基于ssm框架开发的网络视频播放器系统-毕业论文+ppt(附源代码)

    Java毕业设计--基于ssm框架开发的网络视频播放器系统--毕业论文+ppt(附源代码) 开发语言:Java 框架:ssm 技术:JSP JDK版本:JDK1.8 服务器:tomcat7 数据库:mysql 5.7(一定要5.7版本) 数据库工具:Navicat11...

    企业总机-WEB前台-员工

    《企业总机-WEB前台-员工》手册详细介绍了员工如何通过WEB前台登录系统,并使用各种功能来提高工作效率。 **员工登录步骤**: 1. **打开登录页面**:首先,在浏览器中输入指定URL(例如:...

    FlexLayout布局_企业城微信小程序js代码前台前端H5页面源码.rar

    通过设置`display: flex`或`display: inline-flex`,可以将一个元素转变为Flex容器。 - **主轴(Main Axis)与侧轴(Cross Axis)**:主轴是容器内元素的主要排列方向,侧轴与主轴垂直。默认情况下,主轴是水平方向...

    安卓音乐播放器相关-Jamendo音乐播放器.zip

    【安卓音乐播放器相关-Jamendo音乐播放器.zip】是一个包含源码的压缩包,主要涉及的是一个名为Jamendo的开源音乐播放器的Android版本。Jamendo是一个知名的平台,它提供免费、合法的音乐流媒体服务,特别是侧重于...

    前台版-微信接龙-群昵称-快速8.0.47.mdr

    前台版-微信接龙-群昵称-快速8.0.47.mdr

    uni-app商城前台

    【uni-app商城前台】是一个基于uni-app框架开发的电商应用前端项目。uni-app是一个多端开发框架,允许开发者使用一套代码实现跨平台的应用发布,包括微信小程序、支付宝小程序、H5、App等。这个项目主要关注的是商城...

Global site tag (gtag.js) - Google Analytics