Started fixing texture tool (incomplete)
This commit is contained in:
@ -9,5 +9,6 @@ target_sources(${DAWN_TARGET_NAME}
|
|||||||
MeshRenderer.cpp
|
MeshRenderer.cpp
|
||||||
CubeMeshHost.cpp
|
CubeMeshHost.cpp
|
||||||
CapsuleMeshHost.cpp
|
CapsuleMeshHost.cpp
|
||||||
|
QuadMeshHost.cpp
|
||||||
MeshHost.cpp
|
MeshHost.cpp
|
||||||
)
|
)
|
30
src/dawn/scene/components/display/mesh/QuadMeshHost.cpp
Normal file
30
src/dawn/scene/components/display/mesh/QuadMeshHost.cpp
Normal file
@ -0,0 +1,30 @@
|
|||||||
|
// Copyright (c) 2023 Dominic Masters
|
||||||
|
//
|
||||||
|
// This software is released under the MIT License.
|
||||||
|
// https://opensource.org/licenses/MIT
|
||||||
|
|
||||||
|
#include "QuadMeshHost.hpp"
|
||||||
|
|
||||||
|
using namespace Dawn;
|
||||||
|
|
||||||
|
QuadMeshHost::QuadMeshHost(SceneItem *item) :
|
||||||
|
xy0(glm::vec2(-0.5f, -0.5f)), xy1(glm::vec2(0.5f, 0.5f)),
|
||||||
|
uv0(glm::vec2(0, 0)), uv1(glm::vec2(1, 1)),
|
||||||
|
MeshHost(item)
|
||||||
|
{
|
||||||
|
}
|
||||||
|
|
||||||
|
void QuadMeshHost::onStart() {
|
||||||
|
this->mesh.createBuffers(QUAD_VERTICE_COUNT, QUAD_INDICE_COUNT);
|
||||||
|
|
||||||
|
useEffect([&]{
|
||||||
|
QuadMesh::bufferQuadMesh(
|
||||||
|
&this->mesh,
|
||||||
|
glm::vec2(this->xy0),
|
||||||
|
glm::vec2(this->uv0),
|
||||||
|
glm::vec2(this->xy1),
|
||||||
|
glm::vec2(this->uv1),
|
||||||
|
0, 0
|
||||||
|
);
|
||||||
|
}, { &this->xy0, &this->xy1, &this->uv0, &this->uv1 })();
|
||||||
|
}
|
25
src/dawn/scene/components/display/mesh/QuadMeshHost.hpp
Normal file
25
src/dawn/scene/components/display/mesh/QuadMeshHost.hpp
Normal file
@ -0,0 +1,25 @@
|
|||||||
|
// Copyright (c) 2023 Dominic Masters
|
||||||
|
//
|
||||||
|
// This software is released under the MIT License.
|
||||||
|
// https://opensource.org/licenses/MIT
|
||||||
|
|
||||||
|
#pragma once
|
||||||
|
#include "MeshHost.hpp"
|
||||||
|
#include "display/mesh/QuadMesh.hpp"
|
||||||
|
|
||||||
|
namespace Dawn {
|
||||||
|
class QuadMeshHost : public MeshHost {
|
||||||
|
public:
|
||||||
|
// @optional
|
||||||
|
StateProperty<glm::vec2> xy0;
|
||||||
|
// @optional
|
||||||
|
StateProperty<glm::vec2> xy1;
|
||||||
|
// @optional
|
||||||
|
StateProperty<glm::vec2> uv0;
|
||||||
|
// @optional
|
||||||
|
StateProperty<glm::vec2> uv1;
|
||||||
|
|
||||||
|
QuadMeshHost(SceneItem *item);
|
||||||
|
void onStart() override;
|
||||||
|
};
|
||||||
|
}
|
@ -14,6 +14,8 @@ CharacterController2D::CharacterController2D(SceneItem *i) :
|
|||||||
|
|
||||||
void CharacterController2D::onStart() {
|
void CharacterController2D::onStart() {
|
||||||
useEvent([&](float_t delta){
|
useEvent([&](float_t delta){
|
||||||
|
if(velocity == glm::vec2(0, 0)) return;
|
||||||
|
|
||||||
// Common variables
|
// Common variables
|
||||||
auto myCollider = item->getComponent<Collider2D>();
|
auto myCollider = item->getComponent<Collider2D>();
|
||||||
|
|
||||||
@ -62,11 +64,6 @@ void CharacterController2D::onStart() {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// if(
|
|
||||||
// mathAbs<float_t>(moveAmount.x) <= 0.001f &&
|
|
||||||
// mathAbs<float_t>(moveAmount.y) <= 0.001f
|
|
||||||
// ) return;
|
|
||||||
|
|
||||||
transform->setLocalPosition(
|
transform->setLocalPosition(
|
||||||
transform->getLocalPosition() + (glm::vec3(moveAmount.x, 0, moveAmount.y) * delta)
|
transform->getLocalPosition() + (glm::vec3(moveAmount.x, 0, moveAmount.y) * delta)
|
||||||
);
|
);
|
||||||
@ -83,5 +80,8 @@ void CharacterController2D::onStart() {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Stop velocity near zero.
|
||||||
|
if(mathAbs<float_t>(velocity.x) <= 0.001f) velocity.x = 0;
|
||||||
|
if(mathAbs<float_t>(velocity.y) <= 0.001f) velocity.y = 0;
|
||||||
}, getScene()->eventSceneUpdate);
|
}, getScene()->eventSceneUpdate);
|
||||||
}
|
}
|
@ -23,4 +23,6 @@ tool_prefab(${ROSE_ASSETS_DIR}/prefabs/Player.xml)
|
|||||||
tool_prefab(${ROSE_ASSETS_DIR}/prefabs/Urchin.xml)
|
tool_prefab(${ROSE_ASSETS_DIR}/prefabs/Urchin.xml)
|
||||||
tool_prefab(${ROSE_ASSETS_DIR}/prefabs/Crab.xml)
|
tool_prefab(${ROSE_ASSETS_DIR}/prefabs/Crab.xml)
|
||||||
tool_prefab(${ROSE_ASSETS_DIR}/prefabs/SwordHitbox.xml)
|
tool_prefab(${ROSE_ASSETS_DIR}/prefabs/SwordHitbox.xml)
|
||||||
tool_prefab(${ROSE_ASSETS_DIR}/prefabs/Wall.xml)
|
tool_prefab(${ROSE_ASSETS_DIR}/prefabs/Wall.xml)
|
||||||
|
|
||||||
|
tool_texture(texture_urchin ${ROSE_ASSETS_DIR}/textures/Urchin.png)
|
@ -43,13 +43,14 @@ namespace Dawn {
|
|||||||
camera = Camera::create(this);
|
camera = Camera::create(this);
|
||||||
camera->fov = 0.436332f;
|
camera->fov = 0.436332f;
|
||||||
camera->transform->lookAt(glm::vec3(10, 10, 10), glm::vec3(0, 0, 0));
|
camera->transform->lookAt(glm::vec3(10, 10, 10), glm::vec3(0, 0, 0));
|
||||||
auto gameCamera = camera->item->addComponent<GameCamera>();
|
// auto gameCamera = camera->item->addComponent<GameCamera>();
|
||||||
gameCamera->player = player->player;
|
// gameCamera->player = player->player;
|
||||||
}
|
}
|
||||||
|
|
||||||
std::vector<Asset*> getRequiredAssets() override {
|
std::vector<Asset*> getRequiredAssets() override {
|
||||||
auto assMan = &this->game->assetManager;
|
auto assMan = &this->game->assetManager;
|
||||||
std::vector<Asset*> assets;
|
std::vector<Asset*> assets;
|
||||||
|
vectorAppend(&assets, Urchin::getRequiredAssets(assMan));
|
||||||
return assets;
|
return assets;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -19,4 +19,5 @@ set(
|
|||||||
include(util/CMakeLists.txt)
|
include(util/CMakeLists.txt)
|
||||||
|
|
||||||
# Tools
|
# Tools
|
||||||
add_subdirectory(prefabtool)
|
add_subdirectory(prefabtool)
|
||||||
|
add_subdirectory(texturetool)
|
@ -32,6 +32,7 @@ target_include_directories(prefabtool
|
|||||||
# Definitions
|
# Definitions
|
||||||
target_compile_definitions(prefabtool
|
target_compile_definitions(prefabtool
|
||||||
PUBLIC
|
PUBLIC
|
||||||
|
${DAWN_SHARED_DEFINITIONS}
|
||||||
DAWN_TOOL_INSTANCE=PrefabTool
|
DAWN_TOOL_INSTANCE=PrefabTool
|
||||||
DAWN_TOOL_HEADER="PrefabTool.hpp"
|
DAWN_TOOL_HEADER="PrefabTool.hpp"
|
||||||
)
|
)
|
||||||
|
@ -34,17 +34,19 @@ void PrefabGen::generate(
|
|||||||
|
|
||||||
// Process assets
|
// Process assets
|
||||||
int32_t assetNumber = 0;
|
int32_t assetNumber = 0;
|
||||||
|
std::map<std::string, std::string> assetMap;
|
||||||
auto processAsset = [&](struct PrefabAsset a) {
|
auto processAsset = [&](struct PrefabAsset a) {
|
||||||
std::string assetType = "";
|
std::string assetType = "";
|
||||||
|
a.usageName = "asset" + std::to_string(assetNumber++);
|
||||||
switch(a.type) {
|
switch(a.type) {
|
||||||
case PREFAB_ASSET_TYPE_TEXTURE:
|
case PREFAB_ASSET_TYPE_TEXTURE:
|
||||||
assetType = "TextureAsset";
|
assetType = "TextureAsset";
|
||||||
|
assetMap[a.fileName] = "&" + a.usageName + "->texture";
|
||||||
break;
|
break;
|
||||||
|
|
||||||
default:
|
default:
|
||||||
assertUnreachable();
|
assertUnreachable();
|
||||||
}
|
}
|
||||||
a.usageName = "asset" + std::to_string(assetNumber++);
|
|
||||||
line(&methodInit.body, "auto " + a.usageName + " = man->get<" + assetType + ">(\"" + a.fileName + "\");", "");
|
line(&methodInit.body, "auto " + a.usageName + " = man->get<" + assetType + ">(\"" + a.fileName + "\");", "");
|
||||||
line(&methodAssets.body, "assets.push_back(man->get<" + assetType + ">(\"" + a.fileName + "\"));", "");
|
line(&methodAssets.body, "assets.push_back(man->get<" + assetType + ">(\"" + a.fileName + "\"));", "");
|
||||||
};
|
};
|
||||||
@ -77,7 +79,11 @@ void PrefabGen::generate(
|
|||||||
// Now set each property
|
// Now set each property
|
||||||
auto itValues = c.values.begin();
|
auto itValues = c.values.begin();
|
||||||
while(itValues != c.values.end()) {
|
while(itValues != c.values.end()) {
|
||||||
line(&methodInit.body, componentName + "->" + itValues->first + " = " + itValues->second + ";", "");
|
auto value = itValues->second;
|
||||||
|
if(assetMap.find(value) != assetMap.end()) {
|
||||||
|
value = assetMap[value];
|
||||||
|
}
|
||||||
|
line(&methodInit.body, componentName + "->" + itValues->first + " = " + value + ";", "");
|
||||||
++itValues;
|
++itValues;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
53
src/dawntools/texturetool/CMakeLists.txt
Normal file
53
src/dawntools/texturetool/CMakeLists.txt
Normal file
@ -0,0 +1,53 @@
|
|||||||
|
# Copyright (c) 2021 Dominic Msters
|
||||||
|
#
|
||||||
|
# This software is released under the MIT License.
|
||||||
|
# https://opensource.org/licenses/MIT
|
||||||
|
|
||||||
|
# Texture Build Tool
|
||||||
|
project(texturetool VERSION 1.0)
|
||||||
|
add_executable(texturetool)
|
||||||
|
|
||||||
|
target_sources(texturetool
|
||||||
|
PRIVATE
|
||||||
|
${DAWN_SHARED_SOURCES}
|
||||||
|
${DAWN_TOOL_SOURCES}
|
||||||
|
TextureTool.cpp
|
||||||
|
../util/Image.cpp
|
||||||
|
)
|
||||||
|
|
||||||
|
target_include_directories(texturetool
|
||||||
|
PUBLIC
|
||||||
|
${DAWN_SHARED_INCLUDES}
|
||||||
|
${DAWN_TOOL_INCLUDES}
|
||||||
|
${CMAKE_CURRENT_LIST_DIR}
|
||||||
|
)
|
||||||
|
|
||||||
|
# Definitions
|
||||||
|
target_compile_definitions(texturetool
|
||||||
|
PUBLIC
|
||||||
|
${DAWN_SHARED_DEFINITIONS}
|
||||||
|
DAWN_TOOL_INSTANCE=TextureTool
|
||||||
|
DAWN_TOOL_HEADER="TextureTool.hpp"
|
||||||
|
)
|
||||||
|
|
||||||
|
# Libraries
|
||||||
|
target_link_libraries(texturetool
|
||||||
|
PUBLIC
|
||||||
|
${DAWN_BUILD_HOST_LIBS}
|
||||||
|
stb
|
||||||
|
)
|
||||||
|
|
||||||
|
# Tool Function
|
||||||
|
function(tool_texture target in)
|
||||||
|
set(DEPS "")
|
||||||
|
if(DAWN_BUILD_TOOLS)
|
||||||
|
set(DEPS texturetool)
|
||||||
|
endif()
|
||||||
|
|
||||||
|
add_custom_target(${target}
|
||||||
|
COMMAND texturetool --input="${DAWN_ASSETS_SOURCE_DIR}/${in}" --output="${DAWN_ASSETS_BUILD_DIR}/${target}"
|
||||||
|
COMMENT "Generating texture ${target} from ${in}"
|
||||||
|
DEPENDS ${DEPS}
|
||||||
|
)
|
||||||
|
add_dependencies(${DAWN_TARGET_NAME} ${target})
|
||||||
|
endfunction()
|
61
src/dawntools/texturetool/TextureTool.cpp
Normal file
61
src/dawntools/texturetool/TextureTool.cpp
Normal file
@ -0,0 +1,61 @@
|
|||||||
|
// Copyright (c) 2023 Dominic Masters
|
||||||
|
//
|
||||||
|
// This software is released under the MIT License.
|
||||||
|
// https://opensource.org/licenses/MIT
|
||||||
|
|
||||||
|
#include "TextureTool.hpp"
|
||||||
|
|
||||||
|
using namespace Dawn;
|
||||||
|
|
||||||
|
std::vector<std::string> TextureTool::getRequiredFlags() {
|
||||||
|
return std::vector<std::string>{ "input", "output" };
|
||||||
|
}
|
||||||
|
|
||||||
|
int32_t TextureTool::start() {
|
||||||
|
// Finished with XML data, now we can write data out.
|
||||||
|
File fileOut(flags["output"] + ".texture");
|
||||||
|
if(fileOut.exists()) return 0;
|
||||||
|
|
||||||
|
// Load input file
|
||||||
|
File in(flags["input"]);
|
||||||
|
if(!in.open(FILE_MODE_READ)) return 1;
|
||||||
|
|
||||||
|
int w, h, channels;
|
||||||
|
auto dataImage = stbi_load_from_file(in.file, &w, &h, &channels, STBI_rgb_alpha);
|
||||||
|
if(dataImage == NULL) {
|
||||||
|
std::cout << "Failed to load input texture!" << std::endl;
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
in.close();
|
||||||
|
|
||||||
|
// Convert to floating points
|
||||||
|
size_t len = STBI_rgb_alpha * w * h;
|
||||||
|
|
||||||
|
// Open and create output
|
||||||
|
File out(flags["output"] + ".texture");
|
||||||
|
if(!out.mkdirp()) {
|
||||||
|
std::cout << "Failed to make output dir " << out.filename << std::endl;
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
if(!out.open(FILE_MODE_WRITE)) {
|
||||||
|
std::cout << "Failed to open texture file for writing " << out.filename << std::endl;
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Write info
|
||||||
|
char headerBuffer[64];
|
||||||
|
size_t headerBufferLength = sprintf((char *)headerBuffer, "%i|%i|", w, h);
|
||||||
|
if(!out.writeRaw(headerBuffer, headerBufferLength)) {
|
||||||
|
std::cout << "Failed to write texture header for " << out.filename << std::endl;
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Write texture
|
||||||
|
if(!out.writeRaw((char *)dataImage, sizeof(uint8_t) * len)) {
|
||||||
|
std::cout << "Failed to write texture data for " << out.filename << std::endl;
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
stbi_image_free(dataImage);
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
19
src/dawntools/texturetool/TextureTool.hpp
Normal file
19
src/dawntools/texturetool/TextureTool.hpp
Normal file
@ -0,0 +1,19 @@
|
|||||||
|
// Copyright (c) 2023 Dominic Masters
|
||||||
|
//
|
||||||
|
// This software is released under the MIT License.
|
||||||
|
// https://opensource.org/licenses/MIT
|
||||||
|
|
||||||
|
#pragma once
|
||||||
|
#include "util/DawnTool.hpp"
|
||||||
|
#include "util/File.hpp"
|
||||||
|
#include "util/Image.hpp"
|
||||||
|
|
||||||
|
namespace Dawn {
|
||||||
|
class TextureTool : public DawnTool {
|
||||||
|
protected:
|
||||||
|
std::vector<std::string> getRequiredFlags() override;
|
||||||
|
|
||||||
|
public:
|
||||||
|
int32_t start();
|
||||||
|
};
|
||||||
|
}
|
55
src/dawntools/util/Image.cpp
Normal file
55
src/dawntools/util/Image.cpp
Normal file
@ -0,0 +1,55 @@
|
|||||||
|
/**
|
||||||
|
* Copyright (c) 2021 Dominic Masters
|
||||||
|
*
|
||||||
|
* This software is released under the MIT License.
|
||||||
|
* https://opensource.org/licenses/MIT
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include "Image.hpp"
|
||||||
|
|
||||||
|
#ifndef STB_IMAGE_IMPLEMENTATION
|
||||||
|
#define STB_IMAGE_IMPLEMENTATION
|
||||||
|
#include <stb_image.h>
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifndef STB_IMAGE_RESIZE_IMPLEMENTATION
|
||||||
|
#define STB_IMAGE_RESIZE_IMPLEMENTATION
|
||||||
|
#include <stb_image_resize.h>
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifndef STB_IMAGE_WRITE_IMPLEMENTATION
|
||||||
|
#define STB_IMAGE_WRITE_IMPLEMENTATION
|
||||||
|
#include <stb_image_write.h>
|
||||||
|
#endif
|
||||||
|
|
||||||
|
void imageCopy(
|
||||||
|
uint8_t *source, int32_t sourceWidth, int32_t sourceHeight,
|
||||||
|
uint8_t *dest, int32_t destWidth, int32_t destHeight,
|
||||||
|
int32_t cropX, int32_t cropY, int32_t cropWidth, int32_t cropHeight,
|
||||||
|
int32_t pasteX, int32_t pasteY,
|
||||||
|
int32_t channels
|
||||||
|
) {
|
||||||
|
int32_t x, y, c;
|
||||||
|
int32_t absX, absY;
|
||||||
|
int32_t sourceIndex, targetIndex;
|
||||||
|
|
||||||
|
if(cropX == -1) cropX = 0;
|
||||||
|
if(cropY == -1) cropY = 0;
|
||||||
|
if(cropWidth == -1) cropWidth = sourceWidth;
|
||||||
|
if(cropHeight == -1) cropHeight = sourceHeight;
|
||||||
|
if(pasteX == -1) pasteX = 0;
|
||||||
|
if(pasteY == -1) pasteY = 0;
|
||||||
|
|
||||||
|
for(x = cropX; x < cropX + cropWidth; x++) {
|
||||||
|
for(y = cropY; y < cropY + cropHeight; y++) {
|
||||||
|
absX = x - cropX + pasteX;
|
||||||
|
absY = y - cropY + pasteY;
|
||||||
|
if(absX >= destWidth || absY >= destHeight || absX < 0 || absY < 0)continue;
|
||||||
|
targetIndex = absY * destWidth + absX;
|
||||||
|
sourceIndex = y * sourceWidth + x;
|
||||||
|
for(c = 0; c < channels; c++) {
|
||||||
|
dest[(targetIndex*channels) + c] = source[(sourceIndex*channels) + c];
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
38
src/dawntools/util/Image.hpp
Normal file
38
src/dawntools/util/Image.hpp
Normal file
@ -0,0 +1,38 @@
|
|||||||
|
/**
|
||||||
|
* Copyright (c) 2021 Dominic Masters
|
||||||
|
*
|
||||||
|
* This software is released under the MIT License.
|
||||||
|
* https://opensource.org/licenses/MIT
|
||||||
|
*/
|
||||||
|
|
||||||
|
#pragma once
|
||||||
|
#include "File.hpp"
|
||||||
|
|
||||||
|
#include <stb_image.h>
|
||||||
|
#include <stb_image_resize.h>
|
||||||
|
#include <stb_image_write.h>
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Unused currently.
|
||||||
|
*
|
||||||
|
* @param source
|
||||||
|
* @param sourceWidth
|
||||||
|
* @param sourceHeight
|
||||||
|
* @param dest
|
||||||
|
* @param destWidth
|
||||||
|
* @param destHeight
|
||||||
|
* @param cropX
|
||||||
|
* @param cropY
|
||||||
|
* @param cropWidth
|
||||||
|
* @param cropHeight
|
||||||
|
* @param pasteX
|
||||||
|
* @param pasteY
|
||||||
|
* @param channels
|
||||||
|
*/
|
||||||
|
void imageCopy(
|
||||||
|
uint8_t *source, int32_t sourceWidth, int32_t sourceHeight,
|
||||||
|
uint8_t *dest, int32_t destWidth, int32_t destHeight,
|
||||||
|
int32_t cropX, int32_t cropY, int32_t cropWidth, int32_t cropHeight,
|
||||||
|
int32_t pasteX, int32_t pasteY,
|
||||||
|
int32_t channels
|
||||||
|
);
|
Reference in New Issue
Block a user