diff options
Diffstat (limited to 'src/frontend/qt_sdl/main.cpp')
-rw-r--r-- | src/frontend/qt_sdl/main.cpp | 38 |
1 files changed, 23 insertions, 15 deletions
diff --git a/src/frontend/qt_sdl/main.cpp b/src/frontend/qt_sdl/main.cpp index 332e3e1..bf7c261 100644 --- a/src/frontend/qt_sdl/main.cpp +++ b/src/frontend/qt_sdl/main.cpp @@ -714,6 +714,11 @@ bool EmuThread::emuIsRunning() return (EmuRunning == 1); } +bool EmuThread::emuIsActive() +{ + return (RunningSomething == 1); +} + void ScreenHandler::screenSetupLayout(int w, int h) { @@ -942,26 +947,29 @@ void ScreenPanelNative::paintEvent(QPaintEvent* event) // fill background painter.fillRect(event->rect(), QColor::fromRgb(0, 0, 0)); - emuThread->FrontBufferLock.lock(); - int frontbuf = emuThread->FrontBuffer; - if (!GPU::Framebuffer[frontbuf][0] || !GPU::Framebuffer[frontbuf][1]) + if (emuThread->emuIsActive()) { - emuThread->FrontBufferLock.unlock(); - return; - } + emuThread->FrontBufferLock.lock(); + int frontbuf = emuThread->FrontBuffer; + if (!GPU::Framebuffer[frontbuf][0] || !GPU::Framebuffer[frontbuf][1]) + { + emuThread->FrontBufferLock.unlock(); + return; + } - memcpy(screen[0].scanLine(0), GPU::Framebuffer[frontbuf][0], 256*192*4); - memcpy(screen[1].scanLine(0), GPU::Framebuffer[frontbuf][1], 256*192*4); - emuThread->FrontBufferLock.unlock(); + memcpy(screen[0].scanLine(0), GPU::Framebuffer[frontbuf][0], 256 * 192 * 4); + memcpy(screen[1].scanLine(0), GPU::Framebuffer[frontbuf][1], 256 * 192 * 4); + emuThread->FrontBufferLock.unlock(); - painter.setRenderHint(QPainter::SmoothPixmapTransform, Config::ScreenFilter!=0); + painter.setRenderHint(QPainter::SmoothPixmapTransform, Config::ScreenFilter != 0); - QRect screenrc(0, 0, 256, 192); + QRect screenrc(0, 0, 256, 192); - for (int i = 0; i < numScreens; i++) - { - painter.setTransform(screenTrans[i]); - painter.drawImage(screenrc, screen[screenKind[i]]); + for (int i = 0; i < numScreens; i++) + { + painter.setTransform(screenTrans[i]); + painter.drawImage(screenrc, screen[screenKind[i]]); + } } OSD::Update(nullptr); |