|
|
@ -163,15 +163,19 @@ namespace MWGui
|
|
|
|
|
|
|
|
|
|
|
|
// special handling for markers on the local map: the tooltip should only be visible
|
|
|
|
// special handling for markers on the local map: the tooltip should only be visible
|
|
|
|
// if the marker is not hidden due to the fog of war.
|
|
|
|
// if the marker is not hidden due to the fog of war.
|
|
|
|
if (focus->getUserString ("IsMarker") == "true")
|
|
|
|
if (type == "MapMarker")
|
|
|
|
{
|
|
|
|
{
|
|
|
|
LocalMapBase::MarkerPosition pos = *focus->getUserData<LocalMapBase::MarkerPosition>();
|
|
|
|
LocalMapBase::MarkerUserData data = *focus->getUserData<LocalMapBase::MarkerUserData>();
|
|
|
|
|
|
|
|
|
|
|
|
if (!MWBase::Environment::get().getWorld ()->isPositionExplored (pos.nX, pos.nY, pos.cellX, pos.cellY, pos.interior))
|
|
|
|
if (!MWBase::Environment::get().getWorld ()->isPositionExplored (data.nX, data.nY, data.cellX, data.cellY, data.interior))
|
|
|
|
return;
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if (type == "ItemPtr")
|
|
|
|
ToolTipInfo info;
|
|
|
|
|
|
|
|
info.text = data.caption;
|
|
|
|
|
|
|
|
info.notes = data.notes;
|
|
|
|
|
|
|
|
tooltipSize = createToolTip(info);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
else if (type == "ItemPtr")
|
|
|
|
{
|
|
|
|
{
|
|
|
|
mFocusObject = *focus->getUserData<MWWorld::Ptr>();
|
|
|
|
mFocusObject = *focus->getUserData<MWWorld::Ptr>();
|
|
|
|
tooltipSize = getToolTipViaPtr(false);
|
|
|
|
tooltipSize = getToolTipViaPtr(false);
|
|
|
@ -403,16 +407,33 @@ namespace MWGui
|
|
|
|
MyGUI::IntSize totalSize = MyGUI::IntSize( std::min(std::max(textSize.width,captionSize.width + ((image != "") ? imageCaptionHPadding : 0)),maximumWidth),
|
|
|
|
MyGUI::IntSize totalSize = MyGUI::IntSize( std::min(std::max(textSize.width,captionSize.width + ((image != "") ? imageCaptionHPadding : 0)),maximumWidth),
|
|
|
|
((text != "") ? textSize.height + imageCaptionVPadding : 0) + captionHeight );
|
|
|
|
((text != "") ? textSize.height + imageCaptionVPadding : 0) + captionHeight );
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
for (std::vector<std::string>::const_iterator it = info.notes.begin(); it != info.notes.end(); ++it)
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
MyGUI::ImageBox* icon = mDynamicToolTipBox->createWidget<MyGUI::ImageBox>("MarkerButton",
|
|
|
|
|
|
|
|
MyGUI::IntCoord(padding.left, totalSize.height+padding.top, 8, 8), MyGUI::Align::Default);
|
|
|
|
|
|
|
|
icon->setColour(MyGUI::Colour(1.0,0.3,0.3));
|
|
|
|
|
|
|
|
MyGUI::EditBox* edit = mDynamicToolTipBox->createWidget<MyGUI::EditBox>("SandText",
|
|
|
|
|
|
|
|
MyGUI::IntCoord(padding.left+8+4, totalSize.height+padding.top, 300-padding.left-8-4, 300-totalSize.height),
|
|
|
|
|
|
|
|
MyGUI::Align::Default);
|
|
|
|
|
|
|
|
edit->setEditMultiLine(true);
|
|
|
|
|
|
|
|
edit->setEditWordWrap(true);
|
|
|
|
|
|
|
|
edit->setCaption(*it);
|
|
|
|
|
|
|
|
edit->setSize(edit->getWidth(), edit->getTextSize().height);
|
|
|
|
|
|
|
|
icon->setPosition(icon->getLeft(),(edit->getTop()+edit->getBottom())/2-icon->getHeight()/2);
|
|
|
|
|
|
|
|
totalSize.height += std::max(edit->getHeight(), icon->getHeight());
|
|
|
|
|
|
|
|
totalSize.width = std::max(totalSize.width, edit->getWidth()+8+4);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
if (!info.effects.empty())
|
|
|
|
if (!info.effects.empty())
|
|
|
|
{
|
|
|
|
{
|
|
|
|
MyGUI::Widget* effectArea = mDynamicToolTipBox->createWidget<MyGUI::Widget>("",
|
|
|
|
MyGUI::Widget* effectArea = mDynamicToolTipBox->createWidget<MyGUI::Widget>("",
|
|
|
|
MyGUI::IntCoord(padding.left, totalSize.height, 300-padding.left, 300-totalSize.height),
|
|
|
|
MyGUI::IntCoord(padding.left, totalSize.height, 300-padding.left, 300-totalSize.height),
|
|
|
|
MyGUI::Align::Stretch, "ToolTipEffectArea");
|
|
|
|
MyGUI::Align::Stretch);
|
|
|
|
|
|
|
|
|
|
|
|
MyGUI::IntCoord coord(0, 6, totalSize.width, 24);
|
|
|
|
MyGUI::IntCoord coord(0, 6, totalSize.width, 24);
|
|
|
|
|
|
|
|
|
|
|
|
Widgets::MWEffectListPtr effectsWidget = effectArea->createWidget<Widgets::MWEffectList>
|
|
|
|
Widgets::MWEffectListPtr effectsWidget = effectArea->createWidget<Widgets::MWEffectList>
|
|
|
|
("MW_StatName", coord, MyGUI::Align::Default, "ToolTipEffectsWidget");
|
|
|
|
("MW_StatName", coord, MyGUI::Align::Default);
|
|
|
|
effectsWidget->setEffectList(info.effects);
|
|
|
|
effectsWidget->setEffectList(info.effects);
|
|
|
|
|
|
|
|
|
|
|
|
std::vector<MyGUI::Widget*> effectItems;
|
|
|
|
std::vector<MyGUI::Widget*> effectItems;
|
|
|
@ -426,12 +447,12 @@ namespace MWGui
|
|
|
|
assert(enchant);
|
|
|
|
assert(enchant);
|
|
|
|
MyGUI::Widget* enchantArea = mDynamicToolTipBox->createWidget<MyGUI::Widget>("",
|
|
|
|
MyGUI::Widget* enchantArea = mDynamicToolTipBox->createWidget<MyGUI::Widget>("",
|
|
|
|
MyGUI::IntCoord(padding.left, totalSize.height, 300-padding.left, 300-totalSize.height),
|
|
|
|
MyGUI::IntCoord(padding.left, totalSize.height, 300-padding.left, 300-totalSize.height),
|
|
|
|
MyGUI::Align::Stretch, "ToolTipEnchantArea");
|
|
|
|
MyGUI::Align::Stretch);
|
|
|
|
|
|
|
|
|
|
|
|
MyGUI::IntCoord coord(0, 6, totalSize.width, 24);
|
|
|
|
MyGUI::IntCoord coord(0, 6, totalSize.width, 24);
|
|
|
|
|
|
|
|
|
|
|
|
Widgets::MWEffectListPtr enchantWidget = enchantArea->createWidget<Widgets::MWEffectList>
|
|
|
|
Widgets::MWEffectListPtr enchantWidget = enchantArea->createWidget<Widgets::MWEffectList>
|
|
|
|
("MW_StatName", coord, MyGUI::Align::Default, "ToolTipEnchantWidget");
|
|
|
|
("MW_StatName", coord, MyGUI::Align::Default);
|
|
|
|
enchantWidget->setEffectList(Widgets::MWEffectList::effectListFromESM(&enchant->mEffects));
|
|
|
|
enchantWidget->setEffectList(Widgets::MWEffectList::effectListFromESM(&enchant->mEffects));
|
|
|
|
|
|
|
|
|
|
|
|
std::vector<MyGUI::Widget*> enchantEffectItems;
|
|
|
|
std::vector<MyGUI::Widget*> enchantEffectItems;
|
|
|
@ -470,7 +491,7 @@ namespace MWGui
|
|
|
|
chargeCoord = MyGUI::IntCoord((totalSize.width - chargeAndTextWidth)/2 + chargeTextWidth, coord.top+6, chargeWidth, 18);
|
|
|
|
chargeCoord = MyGUI::IntCoord((totalSize.width - chargeAndTextWidth)/2 + chargeTextWidth, coord.top+6, chargeWidth, 18);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
Widgets::MWDynamicStatPtr chargeWidget = enchantArea->createWidget<Widgets::MWDynamicStat>
|
|
|
|
Widgets::MWDynamicStatPtr chargeWidget = enchantArea->createWidget<Widgets::MWDynamicStat>
|
|
|
|
("MW_ChargeBar", chargeCoord, MyGUI::Align::Default, "ToolTipEnchantCharge");
|
|
|
|
("MW_ChargeBar", chargeCoord, MyGUI::Align::Default);
|
|
|
|
chargeWidget->setValue(charge, maxCharge);
|
|
|
|
chargeWidget->setValue(charge, maxCharge);
|
|
|
|
totalSize.height += 24;
|
|
|
|
totalSize.height += 24;
|
|
|
|
}
|
|
|
|
}
|
|
|
@ -505,7 +526,7 @@ namespace MWGui
|
|
|
|
{
|
|
|
|
{
|
|
|
|
MyGUI::ImageBox* imageWidget = mDynamicToolTipBox->createWidget<MyGUI::ImageBox>("ImageBox",
|
|
|
|
MyGUI::ImageBox* imageWidget = mDynamicToolTipBox->createWidget<MyGUI::ImageBox>("ImageBox",
|
|
|
|
MyGUI::IntCoord((totalSize.width - captionSize.width - imageCaptionHPadding)/2, 0, imageSize, imageSize),
|
|
|
|
MyGUI::IntCoord((totalSize.width - captionSize.width - imageCaptionHPadding)/2, 0, imageSize, imageSize),
|
|
|
|
MyGUI::Align::Left | MyGUI::Align::Top, "ToolTipImage");
|
|
|
|
MyGUI::Align::Left | MyGUI::Align::Top);
|
|
|
|
imageWidget->setImageTexture(realImage);
|
|
|
|
imageWidget->setImageTexture(realImage);
|
|
|
|
imageWidget->setPosition (imageWidget->getPosition() + padding);
|
|
|
|
imageWidget->setPosition (imageWidget->getPosition() + padding);
|
|
|
|
}
|
|
|
|
}
|
|
|
|