mirror of
https://github.com/bsnes-emu/bsnes.git
synced 2025-02-23 22:52:34 +01:00
byuu says: Changelog: - updated to newest hiro API - SFC performance profile builds once again - hiro: Qt port completed Errata 1: the hiro/Qt target won't run tomoko just yet. Starts by crashing inside InputSettings because hiro/Qt isn't forcefully selecting the first item added to a ComboButton just yet. Even with a monkey patch to get around that, the UI is incredibly unstable. Lots of geometry calculation bugs, and a crash when you try and access certain folders in the browser dialog. Lots of work left to be done there, sadly. Errata 2: the hiro/Windows port has black backgrounds on all ListView items. It's because I need to test for unassigned colors and grab the default Windows brush colors in those cases. Note: alternating row colors on multi-column ListView widgets is gone now. Not a bug. May add it back later, but I'm not sure. It doesn't interact nicely with per-cell background colors. Things left to do: First, I have to fix the Windows and Qt target bugs. Next, I need to go through and revise the hiro API even more (nothing too major.) Next, I need to update icarus to use the new hiro API, and add support for the SFC games database. Next, I have to rewrite my TSV->BML cheat code tool. Next, I need to post a final WIP of higan+icarus publicly and wait a few days. Next, I need to fix any bugs reported from the final WIP that I can. Finally, I should be able to release v095.
69 lines
1.8 KiB
C++
69 lines
1.8 KiB
C++
#if defined(Hiro_Viewport)
|
|
|
|
namespace hiro {
|
|
|
|
auto pViewport::construct() -> void {
|
|
qtWidget = qtViewport = new QtViewport(*this);
|
|
qtViewport->setMouseTracking(true);
|
|
qtViewport->setAttribute(Qt::WA_PaintOnScreen, true);
|
|
qtViewport->setStyleSheet("background: #000000");
|
|
|
|
pWidget::construct();
|
|
_setState();
|
|
}
|
|
|
|
auto pViewport::destruct() -> void {
|
|
delete qtViewport;
|
|
qtWidget = qtViewport = nullptr;
|
|
}
|
|
|
|
auto pViewport::handle() const -> uintptr_t {
|
|
return (uintptr_t)qtViewport->winId();
|
|
}
|
|
|
|
auto pViewport::setDroppable(bool droppable) -> void {
|
|
_setState();
|
|
}
|
|
|
|
auto pViewport::_setState() -> void {
|
|
qtViewport->setAcceptDrops(state().droppable);
|
|
}
|
|
|
|
auto QtViewport::dragEnterEvent(QDragEnterEvent* event) -> void {
|
|
if(event->mimeData()->hasUrls()) {
|
|
event->acceptProposedAction();
|
|
}
|
|
}
|
|
|
|
auto QtViewport::dropEvent(QDropEvent* event) -> void {
|
|
if(auto paths = DropPaths(event)) p.self().doDrop(paths);
|
|
}
|
|
|
|
auto QtViewport::leaveEvent(QEvent* event) -> void {
|
|
p.self().doMouseLeave();
|
|
}
|
|
|
|
auto QtViewport::mouseMoveEvent(QMouseEvent* event) -> void {
|
|
p.self().doMouseMove({event->pos().x(), event->pos().y()});
|
|
}
|
|
|
|
auto QtViewport::mousePressEvent(QMouseEvent* event) -> void {
|
|
switch(event->button()) {
|
|
case Qt::LeftButton: p.self().doMousePress(Mouse::Button::Left); break;
|
|
case Qt::MidButton: p.self().doMousePress(Mouse::Button::Middle); break;
|
|
case Qt::RightButton: p.self().doMousePress(Mouse::Button::Right); break;
|
|
}
|
|
}
|
|
|
|
auto QtViewport::mouseReleaseEvent(QMouseEvent* event) -> void {
|
|
switch(event->button()) {
|
|
case Qt::LeftButton: p.self().doMouseRelease(Mouse::Button::Left); break;
|
|
case Qt::MidButton: p.self().doMouseRelease(Mouse::Button::Middle); break;
|
|
case Qt::RightButton: p.self().doMouseRelease(Mouse::Button::Right); break;
|
|
}
|
|
}
|
|
|
|
}
|
|
|
|
#endif
|