mirror of
https://github.com/minetest/minetest.git
synced 2025-01-11 15:57:29 +01:00
FormSpec: Add StaticTextSpec and superimpose over item image buttons
This commit is contained in:
parent
eb3840a3f8
commit
baa7c8f8ad
@ -1497,7 +1497,7 @@ void GUIFormSpecMenu::parseItemImageButton(parserData* data,std::string element)
|
|||||||
258 + m_fields.size()
|
258 + m_fields.size()
|
||||||
);
|
);
|
||||||
|
|
||||||
gui::IGUIButton *e = Environment->addButton(rect, this, spec.fid, spec.flabel.c_str());
|
gui::IGUIButton *e = Environment->addButton(rect, this, spec.fid, L"");
|
||||||
|
|
||||||
if (spec.fname == data->focused_fieldname) {
|
if (spec.fname == data->focused_fieldname) {
|
||||||
Environment->setFocus(e);
|
Environment->setFocus(e);
|
||||||
@ -1515,6 +1515,12 @@ void GUIFormSpecMenu::parseItemImageButton(parserData* data,std::string element)
|
|||||||
pos.X += stof(v_pos[0]) * (float) spacing.X;
|
pos.X += stof(v_pos[0]) * (float) spacing.X;
|
||||||
pos.Y += stof(v_pos[1]) * (float) spacing.Y;
|
pos.Y += stof(v_pos[1]) * (float) spacing.Y;
|
||||||
m_itemimages.push_back(ImageDrawSpec("", item_name, pos, geom));
|
m_itemimages.push_back(ImageDrawSpec("", item_name, pos, geom));
|
||||||
|
|
||||||
|
StaticTextSpec label_spec(
|
||||||
|
utf8_to_wide(label),
|
||||||
|
rect
|
||||||
|
);
|
||||||
|
m_static_texts.push_back(label_spec);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
errorstream<< "Invalid ItemImagebutton element(" << parts.size() << "): '" << element << "'" << std::endl;
|
errorstream<< "Invalid ItemImagebutton element(" << parts.size() << "): '" << element << "'" << std::endl;
|
||||||
@ -1883,6 +1889,7 @@ void GUIFormSpecMenu::regenerateGui(v2u32 screensize)
|
|||||||
m_boxes.clear();
|
m_boxes.clear();
|
||||||
m_tooltips.clear();
|
m_tooltips.clear();
|
||||||
m_inventory_rings.clear();
|
m_inventory_rings.clear();
|
||||||
|
m_static_texts.clear();
|
||||||
|
|
||||||
// Set default values (fits old formspec values)
|
// Set default values (fits old formspec values)
|
||||||
m_bgcolor = video::SColor(140,0,0,0);
|
m_bgcolor = video::SColor(140,0,0,0);
|
||||||
@ -2462,6 +2469,15 @@ void GUIFormSpecMenu::drawMenu()
|
|||||||
m_pointer = m_device->getCursorControl()->getPosition();
|
m_pointer = m_device->getCursorControl()->getPosition();
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
/*
|
||||||
|
Draw static text elements
|
||||||
|
*/
|
||||||
|
for (u32 i = 0; i < m_static_texts.size(); i++) {
|
||||||
|
const StaticTextSpec &spec = m_static_texts[i];
|
||||||
|
video::SColor color(255, 255, 255, 255);
|
||||||
|
m_font->draw(spec.text.c_str(), spec.rect, color, true, true, &spec.rect);
|
||||||
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
Draw fields/buttons tooltips
|
Draw fields/buttons tooltips
|
||||||
*/
|
*/
|
||||||
|
@ -228,6 +228,20 @@ class GUIFormSpecMenu : public GUIModalMenu
|
|||||||
irr::video::SColor color;
|
irr::video::SColor color;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
struct StaticTextSpec {
|
||||||
|
StaticTextSpec()
|
||||||
|
{
|
||||||
|
}
|
||||||
|
StaticTextSpec(const std::wstring &a_text,
|
||||||
|
const core::rect<s32> &a_rect):
|
||||||
|
text(a_text),
|
||||||
|
rect(a_rect)
|
||||||
|
{
|
||||||
|
}
|
||||||
|
std::wstring text;
|
||||||
|
core::rect<s32> rect;
|
||||||
|
};
|
||||||
|
|
||||||
public:
|
public:
|
||||||
GUIFormSpecMenu(irr::IrrlichtDevice* dev,
|
GUIFormSpecMenu(irr::IrrlichtDevice* dev,
|
||||||
gui::IGUIElement* parent, s32 id,
|
gui::IGUIElement* parent, s32 id,
|
||||||
@ -339,6 +353,7 @@ protected:
|
|||||||
std::vector<ImageDrawSpec> m_itemimages;
|
std::vector<ImageDrawSpec> m_itemimages;
|
||||||
std::vector<BoxDrawSpec> m_boxes;
|
std::vector<BoxDrawSpec> m_boxes;
|
||||||
std::vector<FieldSpec> m_fields;
|
std::vector<FieldSpec> m_fields;
|
||||||
|
std::vector<StaticTextSpec> m_static_texts;
|
||||||
std::vector<std::pair<FieldSpec,GUITable*> > m_tables;
|
std::vector<std::pair<FieldSpec,GUITable*> > m_tables;
|
||||||
std::vector<std::pair<FieldSpec,gui::IGUICheckBox*> > m_checkboxes;
|
std::vector<std::pair<FieldSpec,gui::IGUICheckBox*> > m_checkboxes;
|
||||||
std::map<std::string, TooltipSpec> m_tooltips;
|
std::map<std::string, TooltipSpec> m_tooltips;
|
||||||
|
Loading…
Reference in New Issue
Block a user