95 lines
3.0 KiB
C++
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);
|
|
}
|
|
|