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) {
|
||||
assertTrue(fontSize > 0);
|
||||
return mathRound<float_t>(this->getScale(fontSize) * 18);
|
||||
return this->getScale(fontSize) * 18;
|
||||
}
|
||||
|
||||
float_t TrueTypeFont::getInitialLineHeight(float_t fontSize) {
|
||||
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) {
|
||||
assertTrue(fontSize > 0);
|
||||
return mathRound<float_t>(58.0f * this->getScale(fontSize));
|
||||
return 96.0f * this->getScale(fontSize);
|
||||
}
|
||||
|
||||
void TrueTypeFont::buffer(
|
||||
@ -105,7 +105,14 @@ void TrueTypeFont::buffer(
|
||||
// Setup the initial loop state, and X/Y coords for the quad.
|
||||
int32_t i = 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;
|
||||
char c;
|
||||
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
|
||||
);
|
||||
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);
|
||||
return items;
|
||||
}
|
||||
|
@ -135,7 +135,6 @@ void VisualNovelTextbox::textboxOnSceneUpdate() {
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
if(this->talkSound != nullptr) {
|
||||
auto vnManager = this->getVisualNovelManager();
|
||||
assertNotNull(vnManager);
|
||||
|
@ -6,6 +6,7 @@
|
||||
#include "DawnGame.hpp"
|
||||
#include "scenes/SubSceneRendererScene.hpp"
|
||||
#include "scenes/Scene_1.hpp"
|
||||
#include "scenes/TestUIScene.hpp"
|
||||
|
||||
using namespace Dawn;
|
||||
|
||||
@ -25,7 +26,7 @@ int32_t DawnGame::init() {
|
||||
this->renderManager.init();
|
||||
this->audioManager.init();
|
||||
|
||||
this->scene = new Scene_1(this);
|
||||
this->scene = new TestUIScene(this);
|
||||
|
||||
return DAWN_GAME_INIT_RESULT_SUCCESS;
|
||||
}
|
||||
|
@ -8,4 +8,5 @@ target_sources(${DAWN_TARGET_NAME}
|
||||
PRIVATE
|
||||
PixelVNScene.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