OpenMiner/source/client/gui/ItemWidget.cpp

95 lines
3.0 KiB
C++
Raw Normal View History

/*
* =====================================================================================
*
* OpenMiner
*
* Copyright (C) 2018-2020 Unarelith, Quentin Bazin <openminer@unarelith.net>
* Copyright (C) 2019-2020 the OpenMiner contributors (see CONTRIBUTORS.md)
*
* This file is part of OpenMiner.
*
* OpenMiner is free software; you can redistribute it and/or
* modify it under the terms of the GNU Lesser General Public
* License as published by the Free Software Foundation; either
* version 2.1 of the License, or (at your option) any later version.
*
* OpenMiner is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
* Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public License
* along with OpenMiner; if not, write to the Free Software Foundation, Inc.,
* 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
*
* =====================================================================================
*/
#include <gk/resource/ResourceHandler.hpp>
#include "ItemWidget.hpp"
#include "Registry.hpp"
#include "TextureAtlas.hpp"
ItemWidget::ItemWidget(Inventory &inventory, u16 x, u16 y, Widget *parent)
: Widget(18, 18, parent), m_inventory(inventory), m_x(x), m_y(y),
m_textureAtlas(gk::ResourceHandler::getInstance().get<TextureAtlas>("atlas-blocks"))
{
m_cube.setPosition(9, 9, 0);
2018-06-26 01:52:28 +02:00
// m_cube.setPosition(8.5, 14, 0);
// m_cube.setRotation(-172, glm::vec3{0.42, -0.2, 1});
}
void ItemWidget::update() {
2020-01-30 16:03:49 +09:00
if (stack().item().isBlock()) {
const Block &block = Registry::getInstance().getBlock(stack().item().id());
2020-03-29 19:19:39 +02:00
if (block.drawType() != BlockDrawType::XShape && block.inventoryImage().empty()) {
2020-01-30 16:03:49 +09:00
m_cube.updateVertexBuffer(block);
m_isImage = false;
}
else
2020-02-19 20:08:46 +09:00
updateImage(&block);
}
2020-01-30 16:03:49 +09:00
else
updateImage();
m_text.setString(std::to_string(stack().amount()));
m_text.setPosition(16 - 4 - 6 * floor(log10(stack().amount())), 16 - 6, 0);
}
2018-06-23 00:34:02 +02:00
2020-02-19 20:08:46 +09:00
void ItemWidget::updateImage(const Block *block) {
2020-01-30 16:03:49 +09:00
if (m_image.width() == 0) {
m_image.load(m_textureAtlas.texture());
m_image.setPosition(1, 1, 0);
m_image.setClipRect(0, 0, 0, 0);
}
gk::FloatRect clipRect = m_textureAtlas.getTexCoords(stack().item().tiles().getTextureForFace(0), false);
m_image.setClipRect(clipRect.x, clipRect.y, clipRect.sizeX, clipRect.sizeY);
m_image.setScale(16.0f / clipRect.sizeX, 16.0f / clipRect.sizeY);
2020-01-30 16:03:49 +09:00
2020-02-19 20:08:46 +09:00
if (block)
m_image.setColor(block->colorMultiplier());
2020-01-30 16:03:49 +09:00
m_isImage = true;
}
void ItemWidget::setStack(const std::string &name, unsigned int amount) {
m_inventory.setStack(m_x, m_y, name, amount);
update();
}
2018-12-29 02:23:23 +01:00
void ItemWidget::draw(gk::RenderTarget &target, gk::RenderStates states) const {
states.transform *= getTransform();
2020-01-30 16:03:49 +09:00
if (stack().item().id()) {
if (!m_isImage)
target.draw(m_cube, states);
else
target.draw(m_image, states);
}
2018-06-26 06:03:30 +02:00
if (stack().amount() != 1)
target.draw(m_text, states);
}