Keep on improving fonts.
This commit is contained in:
2
lib/SDL
2
lib/SDL
Submodule lib/SDL updated: 7b8f0ba8b7...9670f233cc
@ -37,17 +37,17 @@ float_t TrueTypeFont::getScale(float_t scale) {
|
|||||||
|
|
||||||
float_t TrueTypeFont::getSpaceSize(float_t fontSize) {
|
float_t TrueTypeFont::getSpaceSize(float_t fontSize) {
|
||||||
assertTrue(fontSize > 0);
|
assertTrue(fontSize > 0);
|
||||||
return mathRound<float_t>(this->getScale(fontSize) * 18);
|
return this->getScale(fontSize) * 18;
|
||||||
}
|
}
|
||||||
|
|
||||||
float_t TrueTypeFont::getInitialLineHeight(float_t fontSize) {
|
float_t TrueTypeFont::getInitialLineHeight(float_t fontSize) {
|
||||||
assertTrue(fontSize > 0);
|
assertTrue(fontSize > 0);
|
||||||
return mathRound<float_t>(42.0f * this->getScale(fontSize));
|
return 42.0f * this->getScale(fontSize);
|
||||||
}
|
}
|
||||||
|
|
||||||
float_t TrueTypeFont::getLineHeight(float_t fontSize) {
|
float_t TrueTypeFont::getLineHeight(float_t fontSize) {
|
||||||
assertTrue(fontSize > 0);
|
assertTrue(fontSize > 0);
|
||||||
return mathRound<float_t>(58.0f * this->getScale(fontSize));
|
return 96.0f * this->getScale(fontSize);
|
||||||
}
|
}
|
||||||
|
|
||||||
void TrueTypeFont::buffer(
|
void TrueTypeFont::buffer(
|
||||||
@ -105,7 +105,14 @@ void TrueTypeFont::buffer(
|
|||||||
// Setup the initial loop state, and X/Y coords for the quad.
|
// Setup the initial loop state, and X/Y coords for the quad.
|
||||||
int32_t i = 0;
|
int32_t i = 0;
|
||||||
float_t x = 0;
|
float_t x = 0;
|
||||||
float_t y = this->getInitialLineHeight(fontSize) / scale;
|
float_t y = 0;
|
||||||
|
|
||||||
|
// Bake the first quad.
|
||||||
|
this->bakeQuad(quads, &x, &y, 'D');
|
||||||
|
y = -(quads->y0);
|
||||||
|
x = 0;
|
||||||
|
|
||||||
|
// y = this->getInitialLineHeight(fontSize) / scale;
|
||||||
float_t wordX = 0;
|
float_t wordX = 0;
|
||||||
char c;
|
char c;
|
||||||
while(c = text[i++]) {
|
while(c = text[i++]) {
|
||||||
|
38
src/dawn/prefabs/SimpleSpinningCubePrefab.hpp
Normal file
38
src/dawn/prefabs/SimpleSpinningCubePrefab.hpp
Normal file
@ -0,0 +1,38 @@
|
|||||||
|
// Copyright (c) 2023 Dominic Masters
|
||||||
|
//
|
||||||
|
// This software is released under the MIT License.
|
||||||
|
// https://opensource.org/licenses/MIT
|
||||||
|
|
||||||
|
#pragma once
|
||||||
|
#include "prefab/SceneItemPrefab.hpp"
|
||||||
|
#include "display/mesh/CubeMesh.hpp"
|
||||||
|
#include "scene/components/display/MeshRenderer.hpp"
|
||||||
|
#include "scene/components/display/MeshHost.hpp"
|
||||||
|
#include "scene/components/display/material/SimpleTexturedMaterial.hpp"
|
||||||
|
#include "scene/components/example/ExampleSpin.hpp"
|
||||||
|
|
||||||
|
namespace Dawn {
|
||||||
|
class SimpleSpinningCubePrefab :
|
||||||
|
public SceneItemPrefab<SimpleSpinningCubePrefab>
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
std::vector<Asset*> prefabAssets(AssetManager *man) {
|
||||||
|
return std::vector<Asset*>();
|
||||||
|
}
|
||||||
|
|
||||||
|
SimpleSpinningCubePrefab(Scene *s, sceneitemid_t i) :
|
||||||
|
SceneItemPrefab(s, i)
|
||||||
|
{
|
||||||
|
}
|
||||||
|
|
||||||
|
void prefabInit(AssetManager *man) override {
|
||||||
|
auto meshRenderer = this->addComponent<MeshRenderer>();
|
||||||
|
auto meshHost = this->addComponent<MeshHost>();
|
||||||
|
auto spinning = this->addComponent<ExampleSpin>();
|
||||||
|
auto material = this->addComponent<SimpleTexturedMaterial>();
|
||||||
|
|
||||||
|
meshHost->mesh.createBuffers(CUBE_VERTICE_COUNT, CUBE_INDICE_COUNT);
|
||||||
|
CubeMesh::buffer(&meshHost->mesh, glm::vec3(-0.5f, -0.5f, -0.5f), glm::vec3(1, 1, 1), 0, 0);
|
||||||
|
}
|
||||||
|
};
|
||||||
|
}
|
@ -91,7 +91,7 @@ std::vector<struct ShaderPassItem> UILabel::getSelfPassItems(
|
|||||||
this->z
|
this->z
|
||||||
);
|
);
|
||||||
item.start = this->startQuad * QUAD_INDICE_COUNT;
|
item.start = this->startQuad * QUAD_INDICE_COUNT;
|
||||||
item.count = this->quadCount * QUAD_INDICE_COUNT;
|
item.count = this->quadCount == -1 ? -1 : this->quadCount * QUAD_INDICE_COUNT;
|
||||||
items.push_back(item);
|
items.push_back(item);
|
||||||
return items;
|
return items;
|
||||||
}
|
}
|
||||||
|
@ -135,7 +135,6 @@ void VisualNovelTextbox::textboxOnSceneUpdate() {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
if(this->talkSound != nullptr) {
|
if(this->talkSound != nullptr) {
|
||||||
auto vnManager = this->getVisualNovelManager();
|
auto vnManager = this->getVisualNovelManager();
|
||||||
assertNotNull(vnManager);
|
assertNotNull(vnManager);
|
||||||
|
@ -6,6 +6,7 @@
|
|||||||
#include "DawnGame.hpp"
|
#include "DawnGame.hpp"
|
||||||
#include "scenes/SubSceneRendererScene.hpp"
|
#include "scenes/SubSceneRendererScene.hpp"
|
||||||
#include "scenes/Scene_1.hpp"
|
#include "scenes/Scene_1.hpp"
|
||||||
|
#include "scenes/TestUIScene.hpp"
|
||||||
|
|
||||||
using namespace Dawn;
|
using namespace Dawn;
|
||||||
|
|
||||||
@ -25,7 +26,7 @@ int32_t DawnGame::init() {
|
|||||||
this->renderManager.init();
|
this->renderManager.init();
|
||||||
this->audioManager.init();
|
this->audioManager.init();
|
||||||
|
|
||||||
this->scene = new Scene_1(this);
|
this->scene = new TestUIScene(this);
|
||||||
|
|
||||||
return DAWN_GAME_INIT_RESULT_SUCCESS;
|
return DAWN_GAME_INIT_RESULT_SUCCESS;
|
||||||
}
|
}
|
||||||
|
@ -8,4 +8,5 @@ target_sources(${DAWN_TARGET_NAME}
|
|||||||
PRIVATE
|
PRIVATE
|
||||||
PixelVNScene.cpp
|
PixelVNScene.cpp
|
||||||
PokerVNScene.cpp
|
PokerVNScene.cpp
|
||||||
|
TestUIScene.cpp
|
||||||
)
|
)
|
54
src/dawnpokergame/scenes/TestUIScene.cpp
Normal file
54
src/dawnpokergame/scenes/TestUIScene.cpp
Normal file
@ -0,0 +1,54 @@
|
|||||||
|
// Copyright (c) 2023 Dominic Masters
|
||||||
|
//
|
||||||
|
// This software is released under the MIT License.
|
||||||
|
// https://opensource.org/licenses/MIT
|
||||||
|
|
||||||
|
#include "TestUIScene.hpp"
|
||||||
|
|
||||||
|
using namespace Dawn;
|
||||||
|
|
||||||
|
TestUIScene::TestUIScene(DawnGame *game) : Scene(game) {
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
std::vector<Asset*> TestUIScene::getRequiredAssets() {
|
||||||
|
std::vector<Asset*> assets;
|
||||||
|
AssetManager *man = &this->game->assetManager;
|
||||||
|
assets.push_back(man->get<TrueTypeAsset>("truetype_alice"));
|
||||||
|
assets.push_back(man->get<TextureAsset>("texture_test"));
|
||||||
|
return assets;
|
||||||
|
}
|
||||||
|
|
||||||
|
void TestUIScene::stage() {
|
||||||
|
AssetManager *man = &this->game->assetManager;
|
||||||
|
|
||||||
|
// Camera
|
||||||
|
this->camera = Camera::create(this);
|
||||||
|
this->camera->transform->lookAt(glm::vec3(3, 3, 3), glm::vec3(0, 0, 0));
|
||||||
|
|
||||||
|
auto testCube = SimpleSpinningCubePrefab::create(this);
|
||||||
|
|
||||||
|
// UI
|
||||||
|
this->canvas = UICanvas::create(this);
|
||||||
|
|
||||||
|
// auto text = man->get<TextureAsset>("texture_test");
|
||||||
|
// auto border = this->canvas->addElement<UIBorder>();
|
||||||
|
// border->texture = &text->texture;
|
||||||
|
// border->setBorderSize(glm::vec2(4, 4));
|
||||||
|
// border->setTransform(
|
||||||
|
// UI_COMPONENT_ALIGN_STRETCH, UI_COMPONENT_ALIGN_STRETCH,
|
||||||
|
// glm::vec4(0, 0, 0, 0),
|
||||||
|
// 0.0f
|
||||||
|
// );
|
||||||
|
|
||||||
|
auto assetFont = man->get<TrueTypeAsset>("truetype_alice");
|
||||||
|
auto label = this->canvas->addElement<UILabel>();
|
||||||
|
label->setFont(&assetFont->font);
|
||||||
|
label->setText("test.1");
|
||||||
|
label->setFontSize(24);
|
||||||
|
label->setTransform(
|
||||||
|
UI_COMPONENT_ALIGN_STRETCH, UI_COMPONENT_ALIGN_STRETCH,
|
||||||
|
glm::vec4(0, 0, 0, 0),
|
||||||
|
0.0f
|
||||||
|
);
|
||||||
|
}
|
25
src/dawnpokergame/scenes/TestUIScene.hpp
Normal file
25
src/dawnpokergame/scenes/TestUIScene.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 "scene/Scene.hpp"
|
||||||
|
#include "game/DawnGame.hpp"
|
||||||
|
#include "scene/components/ui/UICanvas.hpp"
|
||||||
|
#include "ui/UILabel.hpp"
|
||||||
|
#include "ui/UIBorder.hpp"
|
||||||
|
#include "prefabs/SimpleSpinningCubePrefab.hpp"
|
||||||
|
|
||||||
|
namespace Dawn {
|
||||||
|
class TestUIScene : public Scene {
|
||||||
|
private:
|
||||||
|
Camera *camera = nullptr;
|
||||||
|
UICanvas *canvas = nullptr;
|
||||||
|
|
||||||
|
public:
|
||||||
|
TestUIScene(DawnGame *game);
|
||||||
|
std::vector<Asset*> getRequiredAssets() override;
|
||||||
|
void stage() override;
|
||||||
|
};
|
||||||
|
}
|
Reference in New Issue
Block a user