From 845049a166b2c3ea02186b85bdba54398a15006c Mon Sep 17 00:00:00 2001 From: Kyle Shrader Date: Sat, 3 Oct 2020 10:55:44 +0000 Subject: [PATCH] Prevent empty right page of journal having invisible topics (Fixes #5588) --- CHANGELOG.md | 1 + apps/openmw/mwgui/bookpage.cpp | 12 ++++++++++++ 2 files changed, 13 insertions(+) diff --git a/CHANGELOG.md b/CHANGELOG.md index a00716f968..a89680a90a 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -47,6 +47,7 @@ Bug #5539: Window resize breaks when going from a lower resolution to full screen resolution Bug #5548: Certain exhausted topics can be highlighted again even though there's no new dialogue Bug #5557: Diagonal movement is noticeably slower with analogue stick + Bug #5588: Randomly clicking on the journal's right-side page when it's empty shows random topics Bug #5603: Setting constant effect cast style doesn't correct effects view Bug #5611: Usable items with "0 Uses" should be used only once Feature #390: 3rd person look "over the shoulder" diff --git a/apps/openmw/mwgui/bookpage.cpp b/apps/openmw/mwgui/bookpage.cpp index 5724defcd4..47027c2b7c 100644 --- a/apps/openmw/mwgui/bookpage.cpp +++ b/apps/openmw/mwgui/bookpage.cpp @@ -941,6 +941,9 @@ public: if (!mBook) return; + if (mPage >= mBook->mPages.size()) + return; + dirtyFocusItem (); mFocusItem = 0; @@ -952,6 +955,9 @@ public: if (!mBook) return; + if (mPage >= mBook->mPages.size()) + return; + left -= mCroppedParent->getAbsoluteLeft (); top -= mCroppedParent->getAbsoluteTop (); @@ -988,6 +994,9 @@ public: if (!mBook) return; + if (mPage >= mBook->mPages.size()) + return; + // work around inconsistency in MyGUI where the mouse press coordinates aren't // transformed by the current Layer (even though mouse *move* events are). MyGUI::IntPoint pos (left, top); @@ -1013,6 +1022,9 @@ public: if (!mBook) return; + if (mPage >= mBook->mPages.size()) + return; + // work around inconsistency in MyGUI where the mouse release coordinates aren't // transformed by the current Layer (even though mouse *move* events are). MyGUI::IntPoint pos (left, top);