tooltip stuff

This commit is contained in:
Kae 2024-09-11 19:52:01 +10:00
parent a98ff51ef7
commit 3c4a2eb71e
4 changed files with 26 additions and 29 deletions

View File

@ -135,7 +135,7 @@ tuple<Image, Vec2I, bool> Font::render(String::Char c) {
} }
} }
} }
} else if (colored = slot->bitmap.pixel_mode == FT_PIXEL_MODE_BGRA) { } else if (colored = (slot->bitmap.pixel_mode == FT_PIXEL_MODE_BGRA)) {
unsigned bpp = image.bytesPerPixel(); unsigned bpp = image.bytesPerPixel();
uint8_t* data = image.data() + bpp + ((image.width() * (image.height() - 2)) * bpp); // offset by 1 pixel as it's padded uint8_t* data = image.data() + bpp + ((image.width() * (image.height() - 2)) * bpp); // offset by 1 pixel as it's padded
for (size_t y = 0; y != height; ++y) { for (size_t y = 0; y != height; ++y) {

View File

@ -214,7 +214,7 @@ ImageOperation imageOperationFromString(StringView string) {
else // we're in A of A=B. In vanilla only A=B pairs are evaluated, so only throw an error if B is also there. else // we're in A of A=B. In vanilla only A=B pairs are evaluated, so only throw an error if B is also there.
return operation; return operation;
if (which = !which) if ((which = !which))
operation.colorReplaceMap[*(Vec4B*)&a] = *(Vec4B*)&b; operation.colorReplaceMap[*(Vec4B*)&a] = *(Vec4B*)&b;
hexLen = 0; hexLen = 0;

View File

@ -17,11 +17,9 @@ EnumMap<PaneLayer> const PaneLayerNames{
PaneManager::PaneManager() PaneManager::PaneManager()
: m_context(GuiContext::singletonPtr()), m_prevInterfaceScale(1) { : m_context(GuiContext::singletonPtr()), m_prevInterfaceScale(1) {
auto assets = Root::singleton().assets(); auto assets = Root::singleton().assets();
m_tooltipMouseoverTime = assets->json("/panes.config:tooltipMouseoverTime").toFloat();
m_tooltipMouseoverRadius = assets->json("/panes.config:tooltipMouseoverRadius").toFloat(); m_tooltipMouseoverRadius = assets->json("/panes.config:tooltipMouseoverRadius").toFloat();
m_tooltipMouseOffset = jsonToVec2I(assets->json("/panes.config:tooltipMouseoverOffset")); m_tooltipMouseOffset = jsonToVec2I(assets->json("/panes.config:tooltipMouseoverOffset"));
m_tooltipShowTimer = GameTimer(assets->json("/panes.config:tooltipMouseoverTime").toFloat());
m_tooltipShowTimer = m_tooltipMouseoverTime;
} }
void PaneManager::displayPane(PaneLayer paneLayer, PanePtr const& pane, DismissCallback onDismiss) { void PaneManager::displayPane(PaneLayer paneLayer, PanePtr const& pane, DismissCallback onDismiss) {
@ -124,7 +122,9 @@ PanePtr PaneManager::getPaneAt(Set<PaneLayer> const& paneLayers, Vec2I const& po
PanePtr PaneManager::getPaneAt(Vec2I const& position) const { PanePtr PaneManager::getPaneAt(Vec2I const& position) const {
for (auto const& layerPair : m_displayedPanes) { for (auto const& layerPair : m_displayedPanes) {
for (auto const& panePair : layerPair.second) { for (auto const& panePair : layerPair.second) {
if (panePair.first->inWindow(position) && panePair.first->active()) if (panePair.first != m_activeTooltip
&& panePair.first->inWindow(position)
&& panePair.first->active())
return panePair.first; return panePair.first;
} }
} }
@ -185,12 +185,12 @@ bool PaneManager::sendInputEvent(InputEvent const& event) {
} }
if (event.is<MouseButtonDownEvent>()) { if (event.is<MouseButtonDownEvent>()) {
m_tooltipShowTimer = m_tooltipMouseoverTime; m_tooltipShowTimer.reset();
if (m_activeTooltip) { if (m_activeTooltip) {
dismiss(m_activeTooltip); dismiss(m_activeTooltip);
m_activeTooltip.reset(); m_activeTooltip.reset();
m_tooltipParentPane.reset(); m_tooltipParentPane.reset();
m_tooltipShowTimer = m_tooltipMouseoverTime; m_tooltipShowTimer.reset();
} }
} }
@ -270,29 +270,27 @@ void PaneManager::render() {
} }
void PaneManager::update(float dt) { void PaneManager::update(float dt) {
m_tooltipShowTimer -= GlobalTimestep; auto newTooltipParentPane = getPaneAt(m_tooltipLastMousePos);
if (m_tooltipParentPane.expired())
m_tooltipParentPane.reset();
bool removeTooltip = vmag(m_tooltipInitialPosition - m_tooltipLastMousePos) > m_tooltipMouseoverRadius bool updateTooltip = m_tooltipShowTimer.tick(dt) || (m_activeTooltip && (
|| m_tooltipParentPane.expired() || m_tooltipParentPane.lock()->inWindow(m_tooltipLastMousePos); vmag(m_tooltipInitialPosition - m_tooltipLastMousePos) > m_tooltipMouseoverRadius
|| m_tooltipParentPane != newTooltipParentPane
|| !m_tooltipParentPane->inWindow(m_tooltipLastMousePos)));
if (removeTooltip) { if (updateTooltip) {
if (m_activeTooltip) {
dismiss(m_activeTooltip); dismiss(m_activeTooltip);
m_activeTooltip.reset(); m_activeTooltip.reset();
m_tooltipParentPane.reset(); m_tooltipParentPane.reset();
} }
// Scan for a new tooltip if we just removed the old one, or the show timer has expired m_tooltipShowTimer.reset();
if (removeTooltip || (m_tooltipShowTimer < 0 && !m_activeTooltip)) { if (newTooltipParentPane) {
if (auto parentPane = getPaneAt(m_tooltipLastMousePos)) { if (auto tooltip = newTooltipParentPane->createTooltip(m_tooltipLastMousePos)) {
if (auto tooltip = parentPane->createTooltip(m_tooltipLastMousePos)) {
m_activeTooltip = std::move(tooltip); m_activeTooltip = std::move(tooltip);
m_tooltipParentPane = std::move(parentPane); m_tooltipParentPane = std::move(newTooltipParentPane);
m_tooltipInitialPosition = m_tooltipLastMousePos; m_tooltipInitialPosition = m_tooltipLastMousePos;
displayPane(PaneLayer::Tooltip, m_activeTooltip); displayPane(PaneLayer::Tooltip, m_activeTooltip);
} else {
m_tooltipShowTimer = m_tooltipMouseoverTime;
} }
} }
} }

View File

@ -3,6 +3,7 @@
#include "StarPane.hpp" #include "StarPane.hpp"
#include "StarOrderedMap.hpp" #include "StarOrderedMap.hpp"
#include "StarBiMap.hpp" #include "StarBiMap.hpp"
#include "StarGameTimers.hpp"
namespace Star { namespace Star {
@ -92,15 +93,13 @@ private:
WidgetPtr m_backgroundWidget; WidgetPtr m_backgroundWidget;
float m_tooltipMouseoverTime;
float m_tooltipMouseoverRadius; float m_tooltipMouseoverRadius;
Vec2I m_tooltipMouseOffset; Vec2I m_tooltipMouseOffset;
GameTimer m_tooltipShowTimer;
float m_tooltipShowTimer;
Vec2I m_tooltipLastMousePos; Vec2I m_tooltipLastMousePos;
Vec2I m_tooltipInitialPosition; Vec2I m_tooltipInitialPosition;
PanePtr m_activeTooltip; PanePtr m_activeTooltip;
PaneWeakPtr m_tooltipParentPane; PanePtr m_tooltipParentPane;
}; };
} }