关于Qt音乐播放器进度条拖拽无用的问题解决方案

在使用Qt编写音乐播放器的时候,进度条关联播放音乐基本是必须的。那么在设计的过程中你可能会碰到一个奇怪的问题就是拖拽进度条的时候,可能会报错如下:

然后音乐就卡着不动了。。。

cpp 复制代码
connect(ui->volume_toolButton,&VolumeToolBtn::volumeChange,this,
       [this](const int value) {
            // 将值转换为0.0到1.0之间
            const float volume = static_cast<float>(value) / 100;
            this->m_audioOutput->setVolume(volume); // 设置音量
});

connect(this->m_player.get(), &QMediaPlayer::positionChanged,this, &KuGouApp::updatePositionLab);

connect(this->m_player.get(), &QMediaPlayer::durationChanged, this, &KuGouApp::updateSliderRange);

connect(ui->progressSlider,&QSlider::sliderReleased,
this,&KuGouApp::updateSliderPosition);
******************************


void KuGouApp::updatePositionLab(int position) {
    if(ui->progressSlider->isSliderDown())return;
    ui->position_label->setText(QTime::fromMSecsSinceStartOfDay(position).toString("mm:ss"));
}

void KuGouApp::updateSliderRange(int duration) {
    ui->progressSlider->setMaximum(duration);//一旦加上这一行就无法拖动进度条
    ui->duration_label->setText(QTime::fromMSecsSinceStartOfDay(duration).toString("mm:ss"));
}

void KuGouApp::updateSliderPosition() {
    //播放列表为空时,设置无法拖动,留待之后解决
    this->m_player->setPosition(this->m_player->duration()*ui->progressSlider->value()/100);
    this->m_player->play();
}

是不是想不明白为什么自己明明已经设置了在sliderReleased的时候让播放器setPosition。但却没有反应。。。

那是因为你的总时长被你修改了,但是在setPosition的时候

你还是用了固定的100。。。改成ui-> progressSlider->duration();即可

相关推荐
笑鸿的学习笔记8 分钟前
qt-C++语法笔记之Stretch与Spacer的关系分析
c++·笔记·qt
留不住丨晚霞13 分钟前
说说SpringBoot常用的注解?
java·开发语言
hardStudy_h22 分钟前
C++——内联函数与Lambda表达式
开发语言·jvm·c++
艾莉丝努力练剑1 小时前
【C语言】学习过程教训与经验杂谈:思想准备、知识回顾(三)
c语言·开发语言·数据结构·学习·算法
witton2 小时前
Go语言网络游戏服务器模块化编程
服务器·开发语言·游戏·golang·origin·模块化·耦合
枯萎穿心攻击3 小时前
ECS由浅入深第三节:进阶?System 的行为与复杂交互模式
开发语言·unity·c#·游戏引擎
Jerry Lau3 小时前
go go go 出发咯 - go web开发入门系列(一) helloworld
开发语言·前端·golang
nananaij3 小时前
【Python基础入门 re模块实现正则表达式操作】
开发语言·python·正则表达式
Micro麦可乐3 小时前
Java常用加密算法详解与实战代码 - 附可直接运行的测试示例
java·开发语言·加密算法·aes加解密·rsa加解密·hash算法
天下一般3 小时前
go入门 - day1 - 环境搭建
开发语言·后端·golang