| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212 |
- #include "MainPanel.h"
- #include <QSplitter>
- #include <QVBoxLayout>
- #include <QListWidget>
- #include <util/jsonmapper.h>
- #include <QDebug>
- #include <qtpromise/qpromise.h>
- #include <qtpromise/qpromisefuture.h>
- #include <qtpromise/qpromisehelpers.h>
- #include <QtConcurrent>
- #include "widgets/bubbletip.h"
- #include "widgets/chatView/chatwindow.h"
- #include "widgets/maskoverlay.h"
- #include "widgets/userprofilewidget.h"
- #include "AvPlayer2/PlayWidget.h"
- #include "api/roomapi.h"
- #include "appevent.h"
- #include "ui/av_recorder.h"
- MainPanel::MainPanel(QWidget *parent)
- : QWidget(parent)
- , userProfile(nullptr)
- , chatView(nullptr)
- {
- // setupUI
- userProfile = new UserProfileWidget(this);
- webSocketClient = new WebSocketClient(this);
- chatView = new ChatWindow(webSocketClient);
- chatView->setMinimumWidth(400);
- QWidget *rightWidget = new QWidget;
- QVBoxLayout *vbox = new QVBoxLayout(rightWidget);
- vbox->setContentsMargins(0, 0, 0, 0);
- vbox->addWidget(userProfile, 0);
- vbox->addWidget(chatView, 1);
- m_roomListWidget = new QListWidget;
- splitter = new QSplitter(Qt::Horizontal, this);
- playerContainer = new QWidget(this);
- splitter->addWidget(m_roomListWidget);
- splitter->addWidget(playerContainer);
- splitter->addWidget(rightWidget);
- splitter->setStretchFactor(0, 10);
- splitter->setStretchFactor(1, 60);
- splitter->setStretchFactor(2, 30);
- QVBoxLayout *mainLayout = new QVBoxLayout(this);
- mainLayout->addWidget(splitter, 1);
- mainLayout->setContentsMargins(0, 0, 0, 0);
- mainLayout->setSpacing(0);
- setLayout(mainLayout);
- // initConnect
- connect(AppEvent::instance(), &AppEvent::connectionStateChanged, this, [this](bool connected) {
- if (userProfile) {
- userProfile->setStatus(connected ? "在线" : "离线");
- }
- });
- connect(m_roomListWidget, &QListWidget::itemDoubleClicked, this, &MainPanel::roomItemChanged);
- connect(userProfile, &UserProfileWidget::logoutClicked, this, &MainPanel::logoutClicked);
- connect(webSocketClient, &WebSocketClient::liveStatus, this, [this](const QString &msg) {
- // 这里可以处理 liveStatus 相关逻辑
- QJsonParseError err;
- QJsonDocument doc = QJsonDocument::fromJson(msg.toUtf8(), &err);
- if (err.error != QJsonParseError::NoError || !doc.isObject()) {
- qDebug() << "[MainPanel] liveStatus: 解析失败" << err.errorString();
- return;
- }
- QJsonObject obj = doc.object();
- int liveStatus = obj.value("liveStatus").toInt(0); // 默认-1
- if (liveStatus == 1) {
- qDebug() << "[MainPanel] liveStatus: 直播中";
- if (chatView) {
- const QString id = webSocketClient->roomId();
- if (PlayWidget *playWidget = qobject_cast<PlayWidget *>(playerWidget)) {
- if (!playWidget->isPlaying() && !m_isStartingPlay) {
- m_isStartingPlay = true;
- playWidget->startToPlay("rtmp://106.55.186.74:1935/stream/V1/" + id);
- m_isStartingPlay = false; // 如果 startToPlay 是同步的
- // 如果 startToPlay 是异步的,建议在播放真正开始/结束的回调里重置 m_isStartingPlay
- }
- }
- }
- // 你的处理逻辑
- } else if (liveStatus == 2) {
- qDebug() << "[MainPanel] liveStatus: 未开播";
- // 你的处理逻辑
- } else {
- qDebug() << "[MainPanel] liveStatus: 未知状态" << liveStatus;
- }
- });
- }
- MainPanel::~MainPanel()
- {
- if (userProfile) {
- delete userProfile;
- userProfile = nullptr;
- }
- }
- void MainPanel::setRole(const QStringList &roleList)
- {
- QWidget *newPlayer = nullptr;
- if (roleList.contains("role.admin")) {
- newPlayer = new AvRecorder(this);
- } else {
- newPlayer = new PlayWidget(this);
- }
- setPlayerWidget(newPlayer);
- // 如果是管理也就是教师 直接过滤当前教师的选项
- if (AppEvent::instance()->hasRole("role.admin")) {
- // roomInfo.ownerId = AppEvent::instance()->userId();
- m_roomListWidget->hide();
- } else {
- m_roomListWidget->show();
- }
- // 设置初始化信息
- const QString &name = AppEvent::instance()->userName();
- userProfile->setUsername(name);
- }
- void MainPanel::setPushRoomId(const QString &id)
- {
- // 推流配置
- if (AvRecorder *avRecorder = qobject_cast<AvRecorder *>(playerWidget)) {
- SettingsPage::Param param;
- param.liveUrl = "rtmp://106.55.186.74:1935/stream/V1";
- param.liveName = id.toStdString();
- avRecorder->setSettings(param);
- }
- // 重新进入房间
- chatView->initWebsocket(id);
- }
- void MainPanel::setPlayerWidget(QWidget *newPlayer)
- {
- if (playerWidget) {
- playerWidget->setParent(nullptr);
- playerWidget->deleteLater();
- }
- playerWidget = newPlayer;
- playerWidget->setParent(playerContainer);
- QLayout *oldLayout = playerContainer->layout();
- if (oldLayout) {
- QLayoutItem *item;
- while ((item = oldLayout->takeAt(0)) != nullptr) {
- if (item->widget())
- item->widget()->setParent(nullptr);
- delete item;
- }
- delete oldLayout;
- }
- QVBoxLayout *vbox = new QVBoxLayout(playerContainer);
- vbox->setContentsMargins(0, 0, 0, 0);
- vbox->addWidget(playerWidget);
- }
- void MainPanel::roomItemChanged(QListWidgetItem *item)
- {
- if (item) {
- const QString id = item->data(Qt::UserRole + 100).value<QString>();
- if (!playerWidget) {
- return;
- }
- // // 推流配置
- // if (AvRecorder *avRecorder = qobject_cast<AvRecorder *>(playerWidget)) {
- // SettingsPage::Param param;
- // param.liveUrl = "rtmp://106.55.186.74:1935/stream/V1";
- // param.liveName = id.toStdString();
- // avRecorder->setSettings(param);
- // }
- // 拉取视频流程
- if (PlayWidget *playWidget = qobject_cast<PlayWidget *>(playerWidget)) {
- MaskOverlay::instance()->show(nullptr, 0, MaskOverlay::ActiveWindow);
- QFuture<HttpResponse> getRoomFuture = getRoomApi(id);
- QtPromise::QPromise<HttpResponse> roomListPromise = QtPromise::resolve(getRoomFuture);
- roomListPromise
- .then([this, playWidget, id](const HttpResponse &response) {
- qDebug() << response.code << response.data << response.message;
- if (response.code != 0) {
- BubbleTip::showTip(this, response.message, BubbleTip::Top, 3000);
- return;
- }
- RoomInfo roomInfo = JsonMapper::formJsonEx<RoomInfo>(response.data.toObject());
- qDebug() << "roomInfo.liveStatus.has_value()"
- << roomInfo.liveStatus.has_value();
- int status = roomInfo.liveStatus.value_or(0);
- if (status == 1) {
- qDebug() << "open" << ("rtmp://106.55.186.74:1935/stream/V1/" + id);
- playWidget->startToPlay("rtmp://106.55.186.74:1935/stream/V1/" + id);
- }
- })
- .finally([]() { MaskOverlay::instance()->hide(); });
- }
- }
- }
|