OpenMiner/source/client/gui/ItemWidget.cpp
2020-06-20 01:24:06 +02:00

95 lines
3.0 KiB
C++

/*
* =====================================================================================
*
* 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);
// m_cube.setPosition(8.5, 14, 0);
// m_cube.setRotation(-172, glm::vec3{0.42, -0.2, 1});
}
void ItemWidget::update() {
if (stack().item().isBlock()) {
const Block &block = Registry::getInstance().getBlock(stack().item().id());
if (block.drawType() != BlockDrawType::XShape && block.inventoryImage().empty()) {
m_cube.updateVertexBuffer(block);
m_isImage = false;
}
else
updateImage(&block);
}
else
updateImage();
m_text.setString(std::to_string(stack().amount()));
m_text.setPosition(16 - 4 - 6 * floor(log10(stack().amount())), 16 - 6, 0);
}
void ItemWidget::updateImage(const Block *block) {
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);
if (block)
m_image.setColor(block->colorMultiplier());
m_isImage = true;
}
void ItemWidget::setStack(const std::string &name, unsigned int amount) {
m_inventory.setStack(m_x, m_y, name, amount);
update();
}
void ItemWidget::draw(gk::RenderTarget &target, gk::RenderStates states) const {
states.transform *= getTransform();
if (stack().item().id()) {
if (!m_isImage)
target.draw(m_cube, states);
else
target.draw(m_image, states);
}
if (stack().amount() != 1)
target.draw(m_text, states);
}