鱼C论坛

 找回密码
 立即注册
查看: 3717|回复: 8

[技术原创] 音乐播放器2.0版--QT动画制作(二十)

[复制链接]
发表于 2017-3-11 09:04:16 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
效果:
ssda.png

功能增加了播放进度和音量调节,再往后的3.0版更新我不想做了,其实还可以有很多功能,比如多曲播放和现实时间长度,这都没什么难度,希望有志人士能继续研究。
还有视频播放器也跟这个原理差不多,我以后就不讲了
main.qml文件:
  1. import QtQuick 2.5
  2. import QtQuick.Controls 1.3
  3. import QtQuick.Dialogs 1.0
  4. import QtMultimedia 5.0
  5. ApplicationWindow {
  6.     visible: true
  7.     width: 300
  8.     height: 250
  9.     title: qsTr("Hello World")
  10.     Action{
  11.         id:open
  12.         text:"open"
  13.         onTriggered:fg.open()
  14.     }
  15. menuBar:MenuBar{
  16.     Menu{
  17.         title: qsTr("File")
  18.         MenuItem{
  19.             action: open
  20.         }
  21.         MenuItem {
  22.                         text: qsTr("Exit")
  23.                         onTriggered: Qt.quit();//退出程序
  24.                     }
  25.     }

  26. }
  27. FileDialog{
  28.      id:fg
  29.      onAccepted: main.rect.music.source=fg.fileUrl
  30. }
  31.     MainForm {
  32.         id:main
  33.         anchors.fill: parent

  34.     }
  35. }
复制代码

MainForm.ui.qml文件:
  1. import QtQuick 2.5
  2. import QtQuick.Controls 1.3
  3. Rect{
  4.     property alias rect: rect
  5.     id:rect
  6.     anchors.centerIn: parent
  7. }
复制代码

Rect.qml文件:
  1. import QtQuick 2.0
  2. import QtMultimedia 5.0
  3. import QtQuick.Controls 1.0
  4. import QtQuick.Controls.Styles 1.0

  5. Item{
  6.    property alias music:music
  7.     MediaPlayer{
  8.         id:music
  9.         loops:MediaPlayer.Infinite//无限循环播放
  10.         autoPlay: false//自动播放设定为假
  11.     }
  12. Column{
  13.     anchors.centerIn: parent
  14.     spacing: 20
  15.     Row{
  16.         spacing: 20
  17.     Button{
  18.     id:btn
  19.     text:"play"
  20.     style:button
  21.     onClicked: music.play()//开始播放
  22.     }
  23.     Button{
  24.     id:btn1
  25.     text:"pause"
  26.     style: button
  27.     onClicked: music.pause()//暂停播放
  28.     }
  29.     }
  30.     /*播放进度*/
  31.     Slider{id:progress;maximumValue: music.duration}
  32.     Row{
  33.         Text{text:"volume:"}
  34.         Slider{id:s;style:slider;value: maximumValue/2}
  35.     }
  36. }
  37. Text{anchors.bottom: parent.bottom;text:"鱼C工作室制作"}
  38.     property Component button:ButtonStyle{
  39.     background: Rectangle{
  40.         implicitHeight: 70
  41.         implicitWidth: 100
  42.         radius: 5
  43.         border.width: 2
  44.         border.color: "gray"
  45.         /*当控件按下时颜色为灰,否则为白*/
  46.         color:control.pressed?"darkgray":"white"
  47.     }
  48. }
  49. function sound()
  50. {
  51.     music.volume=s.value;
  52. }
  53. function position()
  54. {
  55.     progress.value=music.position;
  56. }
  57. property Component slider: SliderStyle{//给声音大小的滑动条设定样式
  58.     handle:Rectangle{
  59.         width:10
  60.         height: 10
  61.         radius:2
  62.         color: control.pressed?"darkgray":"gray"
  63.     }
  64. }
  65. Connections{//改变声音
  66.     target:s
  67.     onValueChanged: sound()
  68. }
  69. Connections{//让滑动条进度跟随播放进度
  70.     target:music
  71.     onPositionChanged:position()
  72. }
  73. Connections{//滑条手动拖动时,播放进度跟着改变
  74.     target:progress
  75.     onValueChanged:music.seek(progress.value)
  76. }
  77. }
复制代码

Preview: 明天我们介绍Socket网络通信

评分

参与人数 1荣誉 +5 鱼币 +5 贡献 +3 收起 理由
不二如是 + 5 + 5 + 3 支持楼主!

查看全部评分

本帖被以下淘专辑推荐:

小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2017-3-11 09:18:59 | 显示全部楼层
终于有点播放器的样子了。。。
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2017-3-11 09:19:24 | 显示全部楼层
这么快就到socket!!!
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2017-3-11 10:09:40 | 显示全部楼层
不二如是 发表于 2017-3-11 09:18
终于有点播放器的样子了。。。

嫌我做的丑吧
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2017-3-11 10:19:32 | 显示全部楼层

至少有播放键了,,,
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2017-3-11 12:41:30 | 显示全部楼层
不二如是 发表于 2017-3-11 09:19
这么快就到socket!!!

我是讲QML模式下的,不是QWiget网络编程,QWiget其它没讲完的你还是继续讲吧
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2017-3-11 14:17:47 | 显示全部楼层
一直有个问题,怎么知道QML的版本是多少。
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2017-3-11 14:54:12 | 显示全部楼层
wei_Y 发表于 2017-3-11 14:17
一直有个问题,怎么知道QML的版本是多少。

应该就是QT的版本吧
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2017-3-11 16:03:52 | 显示全部楼层
alltolove 发表于 2017-3-11 14:54
应该就是QT的版本吧

额,我是说QtQuick这类在导入时怎么确定他的版本。。
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2025-4-28 02:41

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表