鱼C论坛

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

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

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

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

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

x
效果:
ssda.png

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

 }
 FileDialog{
     id:fg
     onAccepted: main.rect.music.source=fg.fileUrl
 }
    MainForm {
        id:main
        anchors.fill: parent

    }
}
MainForm.ui.qml文件:
import QtQuick 2.5
import QtQuick.Controls 1.3
Rect{
    property alias rect: rect
    id:rect
    anchors.centerIn: parent
}
Rect.qml文件:
import QtQuick 2.0
import QtMultimedia 5.0
import QtQuick.Controls 1.0
import QtQuick.Controls.Styles 1.0

Item{
   property alias music:music
    MediaPlayer{
        id:music
        loops:MediaPlayer.Infinite//无限循环播放
        autoPlay: false//自动播放设定为假
    }
Column{
    anchors.centerIn: parent
    spacing: 20
    Row{
        spacing: 20
    Button{
    id:btn
    text:"play"
    style:button
    onClicked: music.play()//开始播放
    }
    Button{
    id:btn1
    text:"pause"
    style: button
    onClicked: music.pause()//暂停播放
    }
    }
    /*播放进度*/
    Slider{id:progress;maximumValue: music.duration}
    Row{
        Text{text:"volume:"}
        Slider{id:s;style:slider;value: maximumValue/2}
    }
}
Text{anchors.bottom: parent.bottom;text:"鱼C工作室制作"}
    property Component button:ButtonStyle{
    background: Rectangle{
        implicitHeight: 70
        implicitWidth: 100
        radius: 5
        border.width: 2
        border.color: "gray"
        /*当控件按下时颜色为灰,否则为白*/
        color:control.pressed?"darkgray":"white"
    }
}
function sound()
{
    music.volume=s.value;
}
function position()
{
    progress.value=music.position;
}
property Component slider: SliderStyle{//给声音大小的滑动条设定样式
    handle:Rectangle{
        width:10
        height: 10
        radius:2
        color: control.pressed?"darkgray":"gray"
    }
}
Connections{//改变声音
    target:s
    onValueChanged: sound()
}
Connections{//让滑动条进度跟随播放进度
    target:music
    onPositionChanged:position()
}
Connections{//滑条手动拖动时,播放进度跟着改变
    target:progress
    onValueChanged:music.seek(progress.value)
}
}
Preview: 明天我们介绍Socket网络通信

评分

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

查看全部评分

本帖被以下淘专辑推荐:

想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2017-3-11 09:18:59 | 显示全部楼层
终于有点播放器的样子了。。。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2017-3-11 09:19:24 | 显示全部楼层
这么快就到socket!!!
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

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

嫌我做的丑吧
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

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

至少有播放键了,,,
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

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

我是讲QML模式下的,不是QWiget网络编程,QWiget其它没讲完的你还是继续讲吧
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2017-3-11 14:17:47 | 显示全部楼层
一直有个问题,怎么知道QML的版本是多少。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

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

应该就是QT的版本吧
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

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

额,我是说QtQuick这类在导入时怎么确定他的版本。。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2024-11-15 16:52

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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