From f2304db358a38c6f64cc563eddc9f0c7539937fb Mon Sep 17 00:00:00 2001
From: renderexpert
Date: Fri, 10 Jan 2025 20:03:39 +0000
Subject: [PATCH 01/73] Add imGui shaders
Signed-off-by: renderexpert
---
data/vulkan_shaders/reflection.json | 2 +-
data/vulkan_shaders/shaders_pack.spv | Bin 338652 -> 341244 bytes
shaders/GL/imgui.fsh.glsl | 10 +++++++
shaders/GL/imgui.vsh.glsl | 19 +++++++++++++
shaders/GL/shader_index.txt | 1 +
shaders/Metal/imgui.metal | 39 +++++++++++++++++++++++++++
shaders/gl_program_params.cpp | 10 +++++++
shaders/gl_program_params.hpp | 2 ++
shaders/metal_program_params.hpp | 2 ++
shaders/metal_program_params.mm | 7 +++++
shaders/metal_program_pool.mm | 1 +
shaders/program_params.cpp | 1 +
shaders/program_params.hpp | 10 +++++++
shaders/programs.hpp | 2 ++
shaders/vulkan_program_params.cpp | 7 +++++
shaders/vulkan_program_params.hpp | 2 ++
16 files changed, 114 insertions(+), 1 deletion(-)
create mode 100644 shaders/GL/imgui.fsh.glsl
create mode 100644 shaders/GL/imgui.vsh.glsl
create mode 100644 shaders/Metal/imgui.metal
diff --git a/data/vulkan_shaders/reflection.json b/data/vulkan_shaders/reflection.json
index bca74ae8eb..b428a2a4eb 100644
--- a/data/vulkan_shaders/reflection.json
+++ b/data/vulkan_shaders/reflection.json
@@ -1 +1 @@
-[{"prg":0,"info":{"vs_uni":0,"tex":[{"name":"u_colorTex","idx":1,"frag":0}],"fs_uni":0},"vs_off":0,"vs_size":3772,"fs_off":3772,"fs_size":2552},{"prg":1,"info":{"vs_uni":0,"fs_uni":0,"tex":[{"name":"u_colorTex","idx":1,"frag":1}]},"vs_off":6324,"vs_size":3412,"fs_off":9736,"fs_size":1508},{"prg":2,"info":{"vs_uni":0,"fs_uni":0,"tex":[{"name":"u_colorTex","idx":1,"frag":1},{"name":"u_maskTex","idx":2,"frag":1}]},"vs_off":11244,"vs_size":3560,"fs_off":14804,"fs_size":1756},{"prg":3,"info":{"vs_uni":0,"fs_uni":0,"tex":[{"name":"u_colorTex","idx":1,"frag":1}]},"vs_off":16560,"vs_size":4468,"fs_off":21028,"fs_size":2508},{"prg":4,"info":{"vs_uni":0,"fs_uni":0,"tex":[{"name":"u_colorTex","idx":1,"frag":1}]},"vs_off":23536,"vs_size":4468,"fs_off":28004,"fs_size":2508},{"prg":5,"info":{"vs_uni":0,"tex":[{"name":"u_colorTex","idx":1,"frag":0},{"name":"u_maskTex","idx":2,"frag":1}],"fs_uni":0},"vs_off":30512,"vs_size":4440,"fs_off":34952,"fs_size":2084},{"prg":6,"info":{"vs_uni":0,"tex":[{"name":"u_colorTex","idx":1,"frag":0},{"name":"u_maskTex","idx":2,"frag":1}],"fs_uni":0},"vs_off":37036,"vs_size":3768,"fs_off":40804,"fs_size":2084},{"prg":7,"info":{"vs_uni":0,"tex":[{"name":"u_colorTex","idx":1,"frag":0},{"name":"u_maskTex","idx":2,"frag":1}],"fs_uni":0},"vs_off":42888,"vs_size":3104,"fs_off":45992,"fs_size":1992},{"prg":8,"info":{"vs_uni":0,"tex":[{"name":"u_colorTex","idx":1,"frag":0},{"name":"u_maskTex","idx":2,"frag":1}],"fs_uni":0},"vs_off":47984,"vs_size":3104,"fs_off":51088,"fs_size":1992},{"prg":9,"info":{"vs_uni":0,"tex":[{"name":"u_colorTex","idx":1,"frag":0}],"fs_uni":0},"vs_off":53080,"vs_size":3352,"fs_off":56432,"fs_size":1336},{"prg":10,"info":{"vs_uni":0,"tex":[{"name":"u_colorTex","idx":1,"frag":0}],"fs_uni":0},"vs_off":57768,"vs_size":3352,"fs_off":61120,"fs_size":1336},{"prg":11,"info":{"vs_uni":0,"fs_uni":0,"tex":[{"name":"u_colorTex","idx":1,"frag":1}]},"vs_off":62456,"vs_size":3692,"fs_off":66148,"fs_size":1904},{"prg":12,"info":{"vs_uni":0,"tex":[{"name":"u_colorTex","idx":1,"frag":0}],"fs_uni":0},"vs_off":68052,"vs_size":2716,"fs_off":70768,"fs_size":1336},{"prg":13,"info":{"vs_uni":0,"tex":[{"name":"u_colorTex","idx":1,"frag":0}],"fs_uni":0},"vs_off":72104,"vs_size":5084,"fs_off":77188,"fs_size":1332},{"prg":14,"info":{"vs_uni":0,"fs_uni":-1,"tex":[{"name":"u_colorTex","idx":1,"frag":1}]},"vs_off":78520,"vs_size":5436,"fs_off":83956,"fs_size":1800},{"prg":15,"info":{"vs_uni":0,"fs_uni":0,"tex":[{"name":"u_colorTex","idx":1,"frag":1},{"name":"u_maskTex","idx":2,"frag":1}]},"vs_off":85756,"vs_size":5452,"fs_off":91208,"fs_size":1828},{"prg":16,"info":{"vs_uni":0,"fs_uni":0,"tex":[{"name":"u_colorTex","idx":1,"frag":1}]},"vs_off":93036,"vs_size":3988,"fs_off":97024,"fs_size":1508},{"prg":17,"info":{"vs_uni":0,"tex":[{"name":"u_colorTex","idx":1,"frag":0}],"fs_uni":0},"vs_off":98532,"vs_size":3352,"fs_off":101884,"fs_size":1336},{"prg":18,"info":{"vs_uni":0,"tex":[{"name":"u_colorTex","idx":1,"frag":0}],"fs_uni":0},"vs_off":103220,"vs_size":3696,"fs_off":106916,"fs_size":2092},{"prg":19,"info":{"vs_uni":0,"tex":[{"name":"u_colorTex","idx":1,"frag":0},{"name":"u_maskTex","idx":2,"frag":1}],"fs_uni":0},"vs_off":109008,"vs_size":3516,"fs_off":112524,"fs_size":1716},{"prg":20,"info":{"vs_uni":0,"fs_uni":0,"tex":[{"name":"u_colorTex","idx":1,"frag":1}]},"vs_off":114240,"vs_size":1820,"fs_off":116060,"fs_size":1416},{"prg":21,"info":{"vs_uni":0,"fs_uni":0,"tex":[{"name":"u_colorTex","idx":1,"frag":1}]},"vs_off":117476,"vs_size":2064,"fs_off":119540,"fs_size":1416},{"prg":22,"info":{"vs_uni":0,"fs_uni":0,"tex":[{"name":"u_colorTex","idx":1,"frag":1}]},"vs_off":120956,"vs_size":3640,"fs_off":124596,"fs_size":1540},{"prg":23,"info":{"vs_uni":0,"fs_uni":0,"tex":[{"name":"u_colorTex","idx":1,"frag":1}]},"vs_off":126136,"vs_size":4140,"fs_off":130276,"fs_size":1540},{"prg":24,"info":{"vs_uni":0,"tex":[{"name":"u_colorTex","idx":1,"frag":0}],"fs_uni":0},"vs_off":131816,"vs_size":5812,"fs_off":137628,"fs_size":1868},{"prg":25,"info":{"vs_uni":0,"fs_uni":-1,"tex":[{"name":"u_colorTex","idx":1,"frag":1}]},"vs_off":139496,"vs_size":4976,"fs_off":144472,"fs_size":832},{"prg":26,"info":{"vs_uni":0,"fs_uni":-1,"tex":[{"name":"u_colorTex","idx":1,"frag":1}]},"vs_off":145304,"vs_size":4440,"fs_off":149744,"fs_size":1984},{"prg":27,"info":{"vs_uni":0,"fs_uni":0,"tex":[{"name":"u_colorTex","idx":1,"frag":1}]},"vs_off":151728,"vs_size":5928,"fs_off":157656,"fs_size":4644},{"prg":28,"info":{"vs_uni":0,"fs_uni":0,"tex":[{"name":"u_colorTex","idx":1,"frag":1}]},"vs_off":162300,"vs_size":5928,"fs_off":168228,"fs_size":4240},{"prg":29,"info":{"vs_uni":0,"fs_uni":0,"tex":[{"name":"u_colorTex","idx":1,"frag":1}]},"vs_off":172468,"vs_size":5228,"fs_off":177696,"fs_size":2332},{"prg":30,"info":{"vs_uni":0,"fs_uni":0,"tex":[{"name":"u_colorTex","idx":1,"frag":1}]},"vs_off":180028,"vs_size":4772,"fs_off":184800,"fs_size":3332},{"prg":31,"info":{"vs_uni":0,"fs_uni":0,"tex":[{"name":"u_colorTex","idx":1,"frag":1}]},"vs_off":188132,"vs_size":3624,"fs_off":191756,"fs_size":2344},{"prg":32,"info":{"vs_uni":0,"fs_uni":0,"tex":[{"name":"u_colorTex","idx":1,"frag":1}]},"vs_off":194100,"vs_size":4468,"fs_off":198568,"fs_size":2508},{"prg":33,"info":{"vs_uni":0,"fs_uni":0,"tex":[{"name":"u_colorTex","idx":1,"frag":1}]},"vs_off":201076,"vs_size":4468,"fs_off":205544,"fs_size":2508},{"prg":34,"info":{"vs_uni":-1,"fs_uni":0,"tex":[{"name":"u_colorTex","idx":1,"frag":1}]},"vs_off":208052,"vs_size":1104,"fs_off":209156,"fs_size":992},{"prg":35,"info":{"vs_uni":-1,"fs_uni":0,"tex":[{"name":"u_colorTex","idx":1,"frag":1}]},"vs_off":210148,"vs_size":920,"fs_off":211068,"fs_size":1180},{"prg":36,"info":{"vs_uni":0,"fs_uni":0,"tex":[{"name":"u_colorTex","idx":1,"frag":1}]},"vs_off":212248,"vs_size":2044,"fs_off":214292,"fs_size":1904},{"prg":37,"info":{"vs_uni":0,"fs_uni":0,"tex":[{"name":"u_colorTex","idx":1,"frag":1}]},"vs_off":216196,"vs_size":2416,"fs_off":218612,"fs_size":1856},{"prg":38,"info":{"vs_uni":0,"fs_uni":0,"tex":[{"name":"u_colorTex","idx":1,"frag":1}]},"vs_off":220468,"vs_size":1880,"fs_off":222348,"fs_size":1628},{"prg":39,"info":{"vs_uni":0,"fs_uni":0,"tex":[{"name":"u_colorTex","idx":1,"frag":1}]},"vs_off":223976,"vs_size":1880,"fs_off":225856,"fs_size":1692},{"prg":40,"info":{"vs_uni":0,"tex":[{"name":"u_colorTex","idx":1,"frag":0}],"fs_uni":0},"vs_off":227548,"vs_size":4280,"fs_off":231828,"fs_size":2552},{"prg":41,"info":{"vs_uni":0,"fs_uni":0,"tex":[{"name":"u_colorTex","idx":1,"frag":1}]},"vs_off":234380,"vs_size":4056,"fs_off":238436,"fs_size":1508},{"prg":42,"info":{"vs_uni":0,"fs_uni":0,"tex":[{"name":"u_colorTex","idx":1,"frag":1},{"name":"u_maskTex","idx":2,"frag":1}]},"vs_off":239944,"vs_size":4204,"fs_off":244148,"fs_size":1756},{"prg":43,"info":{"vs_uni":0,"fs_uni":0,"tex":[{"name":"u_colorTex","idx":1,"frag":1}]},"vs_off":245904,"vs_size":4904,"fs_off":250808,"fs_size":2508},{"prg":44,"info":{"vs_uni":0,"fs_uni":0,"tex":[{"name":"u_colorTex","idx":1,"frag":1}]},"vs_off":253316,"vs_size":4904,"fs_off":258220,"fs_size":2508},{"prg":45,"info":{"vs_uni":0,"fs_uni":0,"tex":[{"name":"u_colorTex","idx":1,"frag":1}]},"vs_off":260728,"vs_size":4904,"fs_off":265632,"fs_size":2508},{"prg":46,"info":{"vs_uni":0,"fs_uni":0,"tex":[{"name":"u_colorTex","idx":1,"frag":1}]},"vs_off":268140,"vs_size":4904,"fs_off":273044,"fs_size":2508},{"prg":47,"info":{"vs_uni":0,"tex":[{"name":"u_colorTex","idx":1,"frag":0},{"name":"u_maskTex","idx":2,"frag":1}],"fs_uni":0},"vs_off":275552,"vs_size":4928,"fs_off":280480,"fs_size":2084},{"prg":48,"info":{"vs_uni":0,"tex":[{"name":"u_colorTex","idx":1,"frag":0},{"name":"u_maskTex","idx":2,"frag":1}],"fs_uni":0},"vs_off":282564,"vs_size":4412,"fs_off":286976,"fs_size":2084},{"prg":49,"info":{"vs_uni":0,"fs_uni":0,"tex":[{"name":"u_colorTex","idx":1,"frag":1},{"name":"u_maskTex","idx":2,"frag":1}]},"vs_off":289060,"vs_size":6368,"fs_off":295428,"fs_size":3820},{"prg":50,"info":{"vs_uni":0,"fs_uni":0,"tex":[{"name":"u_colorTex","idx":1,"frag":1}]},"vs_off":299248,"vs_size":3492,"fs_off":302740,"fs_size":1616},{"prg":51,"info":{"vs_uni":0,"fs_uni":0,"tex":[{"name":"u_colorTex","idx":1,"frag":1}]},"vs_off":304356,"vs_size":5984,"fs_off":310340,"fs_size":2428},{"prg":52,"info":{"vs_uni":0,"fs_uni":-1,"tex":[{"name":"u_colorTex","idx":1,"frag":1}]},"vs_off":312768,"vs_size":1924,"fs_off":314692,"fs_size":4236},{"prg":53,"info":{"vs_uni":0,"fs_uni":0,"tex":[{"name":"u_colorTex","idx":1,"frag":1},{"name":"u_smaaArea","idx":2,"frag":1},{"name":"u_smaaSearch","idx":3,"frag":1}]},"vs_off":318928,"vs_size":2300,"fs_off":321228,"fs_size":12356},{"prg":54,"info":{"vs_uni":0,"fs_uni":0,"tex":[{"name":"u_colorTex","idx":1,"frag":1},{"name":"u_blendingWeightTex","idx":2,"frag":1}]},"vs_off":333584,"vs_size":1372,"fs_off":334956,"fs_size":3696}]
\ No newline at end of file
+[{"prg":0,"info":{"vs_uni":0,"tex":[{"name":"u_colorTex","idx":1,"frag":0}],"fs_uni":0},"vs_off":0,"vs_size":3772,"fs_off":3772,"fs_size":2552},{"prg":1,"info":{"vs_uni":0,"fs_uni":0,"tex":[{"name":"u_colorTex","idx":1,"frag":1}]},"vs_off":6324,"vs_size":3412,"fs_off":9736,"fs_size":1508},{"prg":2,"info":{"vs_uni":0,"fs_uni":0,"tex":[{"name":"u_colorTex","idx":1,"frag":1},{"name":"u_maskTex","idx":2,"frag":1}]},"vs_off":11244,"vs_size":3560,"fs_off":14804,"fs_size":1756},{"prg":3,"info":{"vs_uni":0,"fs_uni":0,"tex":[{"name":"u_colorTex","idx":1,"frag":1}]},"vs_off":16560,"vs_size":4468,"fs_off":21028,"fs_size":2508},{"prg":4,"info":{"vs_uni":0,"fs_uni":0,"tex":[{"name":"u_colorTex","idx":1,"frag":1}]},"vs_off":23536,"vs_size":4468,"fs_off":28004,"fs_size":2508},{"prg":5,"info":{"vs_uni":0,"tex":[{"name":"u_colorTex","idx":1,"frag":0},{"name":"u_maskTex","idx":2,"frag":1}],"fs_uni":0},"vs_off":30512,"vs_size":4440,"fs_off":34952,"fs_size":2084},{"prg":6,"info":{"vs_uni":0,"tex":[{"name":"u_colorTex","idx":1,"frag":0},{"name":"u_maskTex","idx":2,"frag":1}],"fs_uni":0},"vs_off":37036,"vs_size":3768,"fs_off":40804,"fs_size":2084},{"prg":7,"info":{"vs_uni":0,"tex":[{"name":"u_colorTex","idx":1,"frag":0},{"name":"u_maskTex","idx":2,"frag":1}],"fs_uni":0},"vs_off":42888,"vs_size":3104,"fs_off":45992,"fs_size":1992},{"prg":8,"info":{"vs_uni":0,"tex":[{"name":"u_colorTex","idx":1,"frag":0},{"name":"u_maskTex","idx":2,"frag":1}],"fs_uni":0},"vs_off":47984,"vs_size":3104,"fs_off":51088,"fs_size":1992},{"prg":9,"info":{"vs_uni":0,"tex":[{"name":"u_colorTex","idx":1,"frag":0}],"fs_uni":0},"vs_off":53080,"vs_size":3352,"fs_off":56432,"fs_size":1336},{"prg":10,"info":{"vs_uni":0,"tex":[{"name":"u_colorTex","idx":1,"frag":0}],"fs_uni":0},"vs_off":57768,"vs_size":3352,"fs_off":61120,"fs_size":1336},{"prg":11,"info":{"vs_uni":0,"fs_uni":0,"tex":[{"name":"u_colorTex","idx":1,"frag":1}]},"vs_off":62456,"vs_size":3692,"fs_off":66148,"fs_size":1904},{"prg":12,"info":{"vs_uni":0,"tex":[{"name":"u_colorTex","idx":1,"frag":0}],"fs_uni":0},"vs_off":68052,"vs_size":2716,"fs_off":70768,"fs_size":1336},{"prg":13,"info":{"vs_uni":0,"tex":[{"name":"u_colorTex","idx":1,"frag":0}],"fs_uni":0},"vs_off":72104,"vs_size":5084,"fs_off":77188,"fs_size":1332},{"prg":14,"info":{"vs_uni":0,"fs_uni":-1,"tex":[{"name":"u_colorTex","idx":1,"frag":1}]},"vs_off":78520,"vs_size":5436,"fs_off":83956,"fs_size":1800},{"prg":15,"info":{"vs_uni":0,"fs_uni":0,"tex":[{"name":"u_colorTex","idx":1,"frag":1},{"name":"u_maskTex","idx":2,"frag":1}]},"vs_off":85756,"vs_size":5452,"fs_off":91208,"fs_size":1828},{"prg":16,"info":{"vs_uni":0,"fs_uni":0,"tex":[{"name":"u_colorTex","idx":1,"frag":1}]},"vs_off":93036,"vs_size":3988,"fs_off":97024,"fs_size":1508},{"prg":17,"info":{"vs_uni":0,"tex":[{"name":"u_colorTex","idx":1,"frag":0}],"fs_uni":0},"vs_off":98532,"vs_size":3352,"fs_off":101884,"fs_size":1336},{"prg":18,"info":{"vs_uni":0,"tex":[{"name":"u_colorTex","idx":1,"frag":0}],"fs_uni":0},"vs_off":103220,"vs_size":3696,"fs_off":106916,"fs_size":2092},{"prg":19,"info":{"vs_uni":0,"tex":[{"name":"u_colorTex","idx":1,"frag":0},{"name":"u_maskTex","idx":2,"frag":1}],"fs_uni":0},"vs_off":109008,"vs_size":3516,"fs_off":112524,"fs_size":1716},{"prg":20,"info":{"vs_uni":0,"fs_uni":0,"tex":[{"name":"u_colorTex","idx":1,"frag":1}]},"vs_off":114240,"vs_size":1820,"fs_off":116060,"fs_size":1416},{"prg":21,"info":{"vs_uni":0,"fs_uni":0,"tex":[{"name":"u_colorTex","idx":1,"frag":1}]},"vs_off":117476,"vs_size":2064,"fs_off":119540,"fs_size":1416},{"prg":22,"info":{"vs_uni":0,"fs_uni":0,"tex":[{"name":"u_colorTex","idx":1,"frag":1}]},"vs_off":120956,"vs_size":3640,"fs_off":124596,"fs_size":1540},{"prg":23,"info":{"vs_uni":0,"fs_uni":0,"tex":[{"name":"u_colorTex","idx":1,"frag":1}]},"vs_off":126136,"vs_size":4140,"fs_off":130276,"fs_size":1540},{"prg":24,"info":{"vs_uni":0,"tex":[{"name":"u_colorTex","idx":1,"frag":0}],"fs_uni":0},"vs_off":131816,"vs_size":5812,"fs_off":137628,"fs_size":1868},{"prg":25,"info":{"vs_uni":0,"fs_uni":-1,"tex":[{"name":"u_colorTex","idx":1,"frag":1}]},"vs_off":139496,"vs_size":4976,"fs_off":144472,"fs_size":832},{"prg":26,"info":{"vs_uni":0,"fs_uni":-1,"tex":[{"name":"u_colorTex","idx":1,"frag":1}]},"vs_off":145304,"vs_size":4440,"fs_off":149744,"fs_size":1984},{"prg":27,"info":{"vs_uni":0,"fs_uni":0,"tex":[{"name":"u_colorTex","idx":1,"frag":1}]},"vs_off":151728,"vs_size":5928,"fs_off":157656,"fs_size":4644},{"prg":28,"info":{"vs_uni":0,"fs_uni":0,"tex":[{"name":"u_colorTex","idx":1,"frag":1}]},"vs_off":162300,"vs_size":5928,"fs_off":168228,"fs_size":4240},{"prg":29,"info":{"vs_uni":0,"fs_uni":0,"tex":[{"name":"u_colorTex","idx":1,"frag":1}]},"vs_off":172468,"vs_size":5228,"fs_off":177696,"fs_size":2332},{"prg":30,"info":{"vs_uni":0,"fs_uni":0,"tex":[{"name":"u_colorTex","idx":1,"frag":1}]},"vs_off":180028,"vs_size":4772,"fs_off":184800,"fs_size":3332},{"prg":31,"info":{"vs_uni":0,"fs_uni":0,"tex":[{"name":"u_colorTex","idx":1,"frag":1}]},"vs_off":188132,"vs_size":3624,"fs_off":191756,"fs_size":2344},{"prg":32,"info":{"vs_uni":0,"fs_uni":0,"tex":[{"name":"u_colorTex","idx":1,"frag":1}]},"vs_off":194100,"vs_size":4468,"fs_off":198568,"fs_size":2508},{"prg":33,"info":{"vs_uni":0,"fs_uni":0,"tex":[{"name":"u_colorTex","idx":1,"frag":1}]},"vs_off":201076,"vs_size":4468,"fs_off":205544,"fs_size":2508},{"prg":34,"info":{"vs_uni":-1,"fs_uni":0,"tex":[{"name":"u_colorTex","idx":1,"frag":1}]},"vs_off":208052,"vs_size":1104,"fs_off":209156,"fs_size":992},{"prg":35,"info":{"vs_uni":-1,"fs_uni":0,"tex":[{"name":"u_colorTex","idx":1,"frag":1}]},"vs_off":210148,"vs_size":920,"fs_off":211068,"fs_size":1180},{"prg":36,"info":{"vs_uni":0,"fs_uni":0,"tex":[{"name":"u_colorTex","idx":1,"frag":1}]},"vs_off":212248,"vs_size":2044,"fs_off":214292,"fs_size":1904},{"prg":37,"info":{"vs_uni":0,"fs_uni":0,"tex":[{"name":"u_colorTex","idx":1,"frag":1}]},"vs_off":216196,"vs_size":2416,"fs_off":218612,"fs_size":1856},{"prg":38,"info":{"vs_uni":0,"fs_uni":0,"tex":[{"name":"u_colorTex","idx":1,"frag":1}]},"vs_off":220468,"vs_size":1880,"fs_off":222348,"fs_size":1628},{"prg":39,"info":{"vs_uni":0,"fs_uni":0,"tex":[{"name":"u_colorTex","idx":1,"frag":1}]},"vs_off":223976,"vs_size":1880,"fs_off":225856,"fs_size":1692},{"prg":40,"info":{"vs_uni":0,"tex":[{"name":"u_colorTex","idx":1,"frag":0}],"fs_uni":0},"vs_off":227548,"vs_size":4280,"fs_off":231828,"fs_size":2552},{"prg":41,"info":{"vs_uni":0,"fs_uni":0,"tex":[{"name":"u_colorTex","idx":1,"frag":1}]},"vs_off":234380,"vs_size":4056,"fs_off":238436,"fs_size":1508},{"prg":42,"info":{"vs_uni":0,"fs_uni":0,"tex":[{"name":"u_colorTex","idx":1,"frag":1},{"name":"u_maskTex","idx":2,"frag":1}]},"vs_off":239944,"vs_size":4204,"fs_off":244148,"fs_size":1756},{"prg":43,"info":{"vs_uni":0,"fs_uni":0,"tex":[{"name":"u_colorTex","idx":1,"frag":1}]},"vs_off":245904,"vs_size":4904,"fs_off":250808,"fs_size":2508},{"prg":44,"info":{"vs_uni":0,"fs_uni":0,"tex":[{"name":"u_colorTex","idx":1,"frag":1}]},"vs_off":253316,"vs_size":4904,"fs_off":258220,"fs_size":2508},{"prg":45,"info":{"vs_uni":0,"fs_uni":0,"tex":[{"name":"u_colorTex","idx":1,"frag":1}]},"vs_off":260728,"vs_size":4904,"fs_off":265632,"fs_size":2508},{"prg":46,"info":{"vs_uni":0,"fs_uni":0,"tex":[{"name":"u_colorTex","idx":1,"frag":1}]},"vs_off":268140,"vs_size":4904,"fs_off":273044,"fs_size":2508},{"prg":47,"info":{"vs_uni":0,"tex":[{"name":"u_colorTex","idx":1,"frag":0},{"name":"u_maskTex","idx":2,"frag":1}],"fs_uni":0},"vs_off":275552,"vs_size":4928,"fs_off":280480,"fs_size":2084},{"prg":48,"info":{"vs_uni":0,"tex":[{"name":"u_colorTex","idx":1,"frag":0},{"name":"u_maskTex","idx":2,"frag":1}],"fs_uni":0},"vs_off":282564,"vs_size":4412,"fs_off":286976,"fs_size":2084},{"prg":49,"info":{"vs_uni":0,"fs_uni":0,"tex":[{"name":"u_colorTex","idx":1,"frag":1},{"name":"u_maskTex","idx":2,"frag":1}]},"vs_off":289060,"vs_size":6368,"fs_off":295428,"fs_size":3820},{"prg":50,"info":{"vs_uni":0,"fs_uni":0,"tex":[{"name":"u_colorTex","idx":1,"frag":1}]},"vs_off":299248,"vs_size":3492,"fs_off":302740,"fs_size":1616},{"prg":51,"info":{"vs_uni":0,"fs_uni":0,"tex":[{"name":"u_colorTex","idx":1,"frag":1}]},"vs_off":304356,"vs_size":5984,"fs_off":310340,"fs_size":2428},{"prg":52,"info":{"vs_uni":0,"fs_uni":-1,"tex":[{"name":"u_colorTex","idx":1,"frag":1}]},"vs_off":312768,"vs_size":1924,"fs_off":314692,"fs_size":4236},{"prg":53,"info":{"vs_uni":0,"fs_uni":0,"tex":[{"name":"u_colorTex","idx":1,"frag":1},{"name":"u_smaaArea","idx":2,"frag":1},{"name":"u_smaaSearch","idx":3,"frag":1}]},"vs_off":318928,"vs_size":2300,"fs_off":321228,"fs_size":12356},{"prg":54,"info":{"vs_uni":0,"fs_uni":0,"tex":[{"name":"u_colorTex","idx":1,"frag":1},{"name":"u_blendingWeightTex","idx":2,"frag":1}]},"vs_off":333584,"vs_size":1372,"fs_off":334956,"fs_size":3696},{"prg":55,"info":{"vs_uni":0,"fs_uni":-1,"tex":[{"name":"u_colorTex","idx":1,"frag":1}]},"vs_off":338652,"vs_size":1700,"fs_off":340352,"fs_size":892}]
\ No newline at end of file
diff --git a/data/vulkan_shaders/shaders_pack.spv b/data/vulkan_shaders/shaders_pack.spv
index 2e8dcdff7c0c64cc2d500cef5459aa409ab63e9d..ac7f25de5b3e6a87c72af7f9194ece320d2b3d63 100644
GIT binary patch
delta 1161
zcmZ8hO-xfk5Z--nAH|>6w#&1nMQlYyDJm#b5>%`|5xr1M^khPaNMfQ^K#eDXq(*Ow
zFJTish(-_IJb3Zs!5E{#8|tN(MlU8_Ffs9f#_xOdVd6GlXXl&Qnc10bD<2z{zBNph
zW!Wm*W%a_Tw0YliYt3a#=FN>)R@_}BgjfTt17d&+B)!GkCG$0h!9
zK`~nxr~~NI0BIXpu=S*ktqW?sZ(2T?tLX`FT)og&LnZ-6rk$Zu09T-=eQl~Q3HwIu
znNk7G!uD@Sj_I?IY)VE5^Eu^&y)*MsMWczvRnrmao0MpSWO+=*6x$$o0X!P$yRoNF
zP(mJitUlB6T6UPZ_bTZXU#dw~5(hYv1319LiWyy2Fb;VzsQU@O2N~_{n!?Y)H8TsA
z4zc<8m70flr0XrT7ENVNMa{1tcEo%dl@YU4kq1rjv6}OrI6K2Jgv`tdsb`Pd^`?@y
p+VAE1P3DQJpZ%iLKK@nwKi-?T2*=G)@xgQKtd>=g`;DkQz+Zv%i%S3i
delta 19
acmezKQsmB6k%kt=7N!>F7M3lnceDUq=Li@8
diff --git a/shaders/GL/imgui.fsh.glsl b/shaders/GL/imgui.fsh.glsl
new file mode 100644
index 0000000000..4c4fcb13ff
--- /dev/null
+++ b/shaders/GL/imgui.fsh.glsl
@@ -0,0 +1,10 @@
+varying vec2 v_texCoords;
+varying vec4 v_color;
+
+uniform sampler2D u_colorTex;
+
+void main()
+{
+ LOW_P vec4 color = texture2D(u_colorTex, v_texCoords);
+ gl_FragColor = color * v_color;
+}
diff --git a/shaders/GL/imgui.vsh.glsl b/shaders/GL/imgui.vsh.glsl
new file mode 100644
index 0000000000..977894c4ff
--- /dev/null
+++ b/shaders/GL/imgui.vsh.glsl
@@ -0,0 +1,19 @@
+attribute vec2 a_position;
+attribute vec2 a_texCoords;
+attribute vec4 a_color;
+
+varying vec2 v_texCoords;
+varying vec4 v_color;
+
+uniform mat4 u_projection;
+
+void main()
+{
+ v_texCoords = a_texCoords;
+ v_color = a_color;
+ gl_Position = vec4(a_position, 0, 1) * u_projection;
+#ifdef VULKAN
+ gl_Position.y = -gl_Position.y;
+ gl_Position.z = (gl_Position.z + gl_Position.w) * 0.5;
+#endif
+}
diff --git a/shaders/GL/shader_index.txt b/shaders/GL/shader_index.txt
index 6103d27589..9decc59502 100644
--- a/shaders/GL/shader_index.txt
+++ b/shaders/GL/shader_index.txt
@@ -53,3 +53,4 @@ TrafficCircle traffic_circle.vsh.glsl traffic_circle.fsh.glsl
SmaaEdges smaa_edges.vsh.glsl smaa_edges.fsh.glsl
SmaaBlendingWeight smaa_blending_weight.vsh.glsl smaa_blending_weight.fsh.glsl
SmaaFinal smaa_final.vsh.glsl smaa_final.fsh.glsl
+ImGui imgui.vsh.glsl imgui.fsh.glsl
diff --git a/shaders/Metal/imgui.metal b/shaders/Metal/imgui.metal
new file mode 100644
index 0000000000..932fb5ca9a
--- /dev/null
+++ b/shaders/Metal/imgui.metal
@@ -0,0 +1,39 @@
+#include
+#include
+using namespace metal;
+
+typedef struct
+{
+ float2 a_position [[attribute(0)]];
+ float2 a_texCoords [[attribute(1)]];
+ float4 a_color [[attribute(2)]];
+} Vertex_T;
+
+typedef struct
+{
+ float4 position [[position]];
+ float2 texCoords;
+ float4 color;
+} Fragment_T;
+
+typedef struct
+{
+ float4x4 u_projection;
+} Uniforms_T;
+
+vertex Fragment_T vsImGui(const Vertex_T in [[stage_in]],
+ constant Uniforms_T & uniforms [[buffer(1)]])
+{
+ Fragment_T out;
+ out.position = float4(in.a_position, 0.0, 1.0) * uniforms.u_projection;
+ out.texCoords = in.a_texCoords;
+ out.color = in.a_color;
+ return out;
+}
+
+fragment float4 fsImGui(const Fragment_T in [[stage_in]],
+ texture2d u_colorTex [[texture(0)]],
+ sampler u_colorTexSampler [[sampler(0)]])
+{
+ return in.color * u_colorTex.sample(u_colorTexSampler, in.texCoords);
+}
diff --git a/shaders/gl_program_params.cpp b/shaders/gl_program_params.cpp
index 59f13ea7dc..cf372db3e6 100644
--- a/shaders/gl_program_params.cpp
+++ b/shaders/gl_program_params.cpp
@@ -230,4 +230,14 @@ void GLProgramParamsSetter::Apply(ref_ptr context,
Parameter::CheckApply(guard, "u_framebufferMetrics", params.m_framebufferMetrics);
}
+
+void GLProgramParamsSetter::Apply(ref_ptr context,
+ ref_ptr program,
+ ImGuiProgramParams const & params)
+{
+ UNUSED_VALUE(context);
+ UniformsGuard guard(program, params);
+
+ Parameter::CheckApply(guard, "u_projection", params.m_projection);
+}
} // namespace gpu
diff --git a/shaders/gl_program_params.hpp b/shaders/gl_program_params.hpp
index 2ce8fe028d..20626abdc7 100644
--- a/shaders/gl_program_params.hpp
+++ b/shaders/gl_program_params.hpp
@@ -29,5 +29,7 @@ public:
ref_ptr program, ScreenQuadProgramParams const & params) override;
void Apply(ref_ptr context,
ref_ptr program, SMAAProgramParams const & params) override;
+ void Apply(ref_ptr context,
+ ref_ptr program, ImGuiProgramParams const & params) override;
};
} // namespace gpu
diff --git a/shaders/metal_program_params.hpp b/shaders/metal_program_params.hpp
index 4134e770b0..fa0cc09752 100644
--- a/shaders/metal_program_params.hpp
+++ b/shaders/metal_program_params.hpp
@@ -31,6 +31,8 @@ public:
ScreenQuadProgramParams const & params) override;
void Apply(ref_ptr context, ref_ptr program,
SMAAProgramParams const & params) override;
+ void Apply(ref_ptr context, ref_ptr program,
+ ImGuiProgramParams const & params) override;
};
} // namespace metal
} // namespace gpu
diff --git a/shaders/metal_program_params.mm b/shaders/metal_program_params.mm
index d5da8217d7..d63396d258 100644
--- a/shaders/metal_program_params.mm
+++ b/shaders/metal_program_params.mm
@@ -101,5 +101,12 @@ void MetalProgramParamsSetter::Apply(ref_ptr context,
{
ApplyBytes(context, program, params);
}
+
+void MetalProgramParamsSetter::Apply(ref_ptr context,
+ ref_ptr program,
+ ImGuiProgramParams const & params)
+{
+ ApplyBytes(context, program, params);
+}
} // namespace metal
} // namespace gpu
diff --git a/shaders/metal_program_pool.mm b/shaders/metal_program_pool.mm
index 11dca8c56f..9926082ba4 100644
--- a/shaders/metal_program_pool.mm
+++ b/shaders/metal_program_pool.mm
@@ -102,6 +102,7 @@ std::array(Program::ProgramsCount)> const kMeta
ProgramInfo("vsSmaaEdges", "fsSmaaEdges", {{0, 1}}), // SmaaEdges
ProgramInfo("vsSmaaBlendingWeight", "fsSmaaBlendingWeight", {{0, 1}}), // SmaaBlendingWeight
ProgramInfo("vsSmaaFinal", "fsSmaaFinal", {{0, 1}}), // SmaaFinal
+ ProgramInfo("vsImGui", "fsImGui", {{0, 2}}), // ImGui
}};
MTLVertexFormat GetFormatByDataType(MTLDataType dataType)
diff --git a/shaders/program_params.cpp b/shaders/program_params.cpp
index e9119948f3..a774b2eec3 100644
--- a/shaders/program_params.cpp
+++ b/shaders/program_params.cpp
@@ -18,6 +18,7 @@ void ProgramParams::Init()
DebugRectProgramParams::BindPrograms(m_boundParams);
ScreenQuadProgramParams::BindPrograms(m_boundParams);
SMAAProgramParams::BindPrograms(m_boundParams);
+ ImGuiProgramParams::BindPrograms(m_boundParams);
}
// static
diff --git a/shaders/program_params.hpp b/shaders/program_params.hpp
index c2bea7925a..fa17305b74 100644
--- a/shaders/program_params.hpp
+++ b/shaders/program_params.hpp
@@ -222,6 +222,14 @@ struct ALIGNMENT SMAAProgramParams
Program::SmaaFinal)
};
+struct ALIGNMENT ImGuiProgramParams
+{
+ glsl::mat4 m_projection;
+
+ BIND_PROGRAMS(ImGuiProgramParams,
+ Program::ImGui)
+};
+
#undef ALIGNMENT
class ProgramParamsSetter
@@ -248,5 +256,7 @@ public:
ref_ptr program, ScreenQuadProgramParams const & params) = 0;
virtual void Apply(ref_ptr context,
ref_ptr program, SMAAProgramParams const & params) = 0;
+ virtual void Apply(ref_ptr context,
+ ref_ptr program, ImGuiProgramParams const & params) = 0;
};
} // namespace gpu
diff --git a/shaders/programs.hpp b/shaders/programs.hpp
index ca74e7a067..2804d29a06 100644
--- a/shaders/programs.hpp
+++ b/shaders/programs.hpp
@@ -65,6 +65,7 @@ enum class Program
SmaaEdges,
SmaaBlendingWeight,
SmaaFinal,
+ ImGui,
ProgramsCount
};
@@ -128,6 +129,7 @@ inline std::string DebugPrint(Program p)
case Program::SmaaEdges: return "SmaaEdges";
case Program::SmaaBlendingWeight: return "SmaaBlendingWeight";
case Program::SmaaFinal: return "SmaaFinal";
+ case Program::ImGui: return "ImGui";
case Program::ProgramsCount:
CHECK(false, ("Try to output ProgramsCount"));
diff --git a/shaders/vulkan_program_params.cpp b/shaders/vulkan_program_params.cpp
index a764e3a9e5..58dd83ffac 100644
--- a/shaders/vulkan_program_params.cpp
+++ b/shaders/vulkan_program_params.cpp
@@ -229,5 +229,12 @@ void VulkanProgramParamsSetter::Apply(ref_ptr context,
{
ApplyImpl(context, program, params);
}
+
+void VulkanProgramParamsSetter::Apply(ref_ptr context,
+ ref_ptr program,
+ ImGuiProgramParams const & params)
+{
+ ApplyImpl(context, program, params);
+}
} // namespace vulkan
} // namespace gpu
diff --git a/shaders/vulkan_program_params.hpp b/shaders/vulkan_program_params.hpp
index 91ab62f50b..25a2dcf8f9 100644
--- a/shaders/vulkan_program_params.hpp
+++ b/shaders/vulkan_program_params.hpp
@@ -55,6 +55,8 @@ public:
ScreenQuadProgramParams const & params) override;
void Apply(ref_ptr context, ref_ptr program,
SMAAProgramParams const & params) override;
+ void Apply(ref_ptr context, ref_ptr program,
+ ImGuiProgramParams const & params) override;
private:
template
--
2.45.3
From 5e0b24302734ac05633b1c0b98c28a050136b7f7 Mon Sep 17 00:00:00 2001
From: renderexpert
Date: Fri, 10 Jan 2025 19:56:37 +0000
Subject: [PATCH 02/73] Add glfw, imgui and cmake metal dependencies
Signed-off-by: renderexpert
---
.github/workflows/linux-check.yaml | 8 +++++
.gitmodules | 9 +++++
3party/CMake-MetalShaderSupport | 1 +
3party/CMakeLists.txt | 14 ++++++++
3party/glfw | 1 +
3party/imgui/CMakeLists.txt | 16 +++++++++
3party/imgui/imgui | 1 +
data/copyright.html | 57 ++++++++++++++++++++++++++++++
docs/INSTALL.md | 4 +++
9 files changed, 111 insertions(+)
create mode 160000 3party/CMake-MetalShaderSupport
create mode 160000 3party/glfw
create mode 100644 3party/imgui/CMakeLists.txt
create mode 160000 3party/imgui/imgui
diff --git a/.github/workflows/linux-check.yaml b/.github/workflows/linux-check.yaml
index 17adeecbd2..bce6b20487 100644
--- a/.github/workflows/linux-check.yaml
+++ b/.github/workflows/linux-check.yaml
@@ -61,6 +61,10 @@ jobs:
libgl1-mesa-dev \
libglvnd-dev \
libharfbuzz-dev \
+ libxrandr-dev \
+ libxinerama-dev \
+ libxcursor-dev \
+ libxi-dev \
qt6-base-dev \
libqt6svg6-dev \
qt6-positioning-dev \
@@ -128,6 +132,10 @@ jobs:
libgl1-mesa-dev \
libglvnd-dev \
libharfbuzz-dev \
+ libxrandr-dev \
+ libxinerama-dev \
+ libxcursor-dev \
+ libxi-dev \
qt6-base-dev \
libqt6svg6-dev \
qt6-positioning-dev \
diff --git a/.gitmodules b/.gitmodules
index 7d35fe8264..b059cf9425 100644
--- a/.gitmodules
+++ b/.gitmodules
@@ -59,3 +59,12 @@
[submodule "3party/utfcpp"]
path = 3party/utfcpp
url = https://github.com/nemtrif/utfcpp.git
+[submodule "3party/glfw"]
+ path = 3party/glfw
+ url = https://github.com/glfw/glfw.git
+[submodule "3party/CMake-MetalShaderSupport"]
+ path = 3party/CMake-MetalShaderSupport
+ url = https://github.com/dpogue/CMake-MetalShaderSupport.git
+[submodule "3party/imgui/imgui"]
+ path = 3party/imgui/imgui
+ url = https://github.com/ocornut/imgui
diff --git a/3party/CMake-MetalShaderSupport b/3party/CMake-MetalShaderSupport
new file mode 160000
index 0000000000..989857d2e5
--- /dev/null
+++ b/3party/CMake-MetalShaderSupport
@@ -0,0 +1 @@
+Subproject commit 989857d2e5e54869c35ad06fb21a67d12a2dbc67
diff --git a/3party/CMakeLists.txt b/3party/CMakeLists.txt
index 57d0592dc3..e232703b2c 100644
--- a/3party/CMakeLists.txt
+++ b/3party/CMakeLists.txt
@@ -66,4 +66,18 @@ add_subdirectory(vulkan_wrapper)
if (PLATFORM_DESKTOP)
add_subdirectory(libtess2)
+
+ set(GLFW_BUILD_DOCS OFF CACHE BOOL "")
+ set(GLFW_BUILD_EXAMPLES OFF CACHE BOOL "")
+ set(GLFW_BUILD_TESTS OFF CACHE BOOL "")
+ set(GLFW_INSTALL OFF CACHE BOOL "")
+ set(GLFW_VULKAN_STATIC OFF CACHE BOOL "")
+ set(GLFW_BUILD_WAYLAND OFF CACHE BOOL "")
+ # Disable ARC for glfw and re-enable after it because it's globally set in the root CMakeLists.txt
+ set(CMAKE_OBJC_FLAGS "")
+ add_subdirectory(glfw)
+ set_target_properties(glfw PROPERTIES UNITY_BUILD OFF)
+ set(CMAKE_OBJC_FLAGS -fobjc-arc)
+
+ add_subdirectory(imgui)
endif()
diff --git a/3party/glfw b/3party/glfw
new file mode 160000
index 0000000000..21fea01161
--- /dev/null
+++ b/3party/glfw
@@ -0,0 +1 @@
+Subproject commit 21fea01161e0d6b70c0c5c1f52dc8e7a7df14a50
diff --git a/3party/imgui/CMakeLists.txt b/3party/imgui/CMakeLists.txt
new file mode 100644
index 0000000000..ebbdde8c48
--- /dev/null
+++ b/3party/imgui/CMakeLists.txt
@@ -0,0 +1,16 @@
+project(imgui)
+
+set(SRC
+ imgui/imgui_draw.cpp
+ imgui/imgui_tables.cpp
+ imgui/imgui_widgets.cpp
+ imgui/imgui.cpp
+ imgui/backends/imgui_impl_glfw.cpp
+)
+
+add_library(${PROJECT_NAME} ${SRC})
+target_include_directories(${PROJECT_NAME}
+ PRIVATE ${OMIM_ROOT}/3party/glfw/include
+ PUBLIC ${OMIM_ROOT}/3party/imgui/imgui
+ PUBLIC .
+)
diff --git a/3party/imgui/imgui b/3party/imgui/imgui
new file mode 160000
index 0000000000..6982ce43f5
--- /dev/null
+++ b/3party/imgui/imgui
@@ -0,0 +1 @@
+Subproject commit 6982ce43f5b143c5dce5fab0ce07dd4867b705ae
diff --git a/data/copyright.html b/data/copyright.html
index b83b74ae60..c517a2b17c 100644
--- a/data/copyright.html
+++ b/data/copyright.html
@@ -155,6 +155,12 @@
Chromium's Courgette;
BSD License
+ CMake Metal support files
+ © 2024 Darryl Pogue and Contributors;License
+
+ Dear ImGui
+ © 2014-2025 Omar Cornut; MIT License
+
Expat
© 1998–2000 Thai Open Source Software Center Ltd and Clark Cooper,
© 2001–2019 Expat maintainers; MIT License
@@ -164,6 +170,9 @@
FreeType
© 2013 The FreeType Project; FTL
+ GLFW
+ © 2002-2006 Marcus Geelnard;2006-2019 Camilla Löwy; Zlib License
+
GLM
© 2005–2014 G-Truc Creation; MIT License
@@ -1058,6 +1067,54 @@ of the copyright holder.
+
+
+
CMake Metal support files
+
Copyright 2024 Darryl Pogue and Contributors
+
All rights reserved.
+
+
Redistribution and use in source and binary forms, with or without modification, are permitted provided that the following conditions are met:
+
+
* Redistributions of source code must retain the above copyright notice, this list of conditions and the following disclaimer.
+
+
* Redistributions in binary form must reproduce the above copyright notice, this list of conditions and the following disclaimer in the documentation and/or other materials provided with the distribution.
+
+
* Neither the name of Kitware, Inc. nor the names of Contributors may be used to endorse or promote products derived from this software without specific prior written permission.
+
+
THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
+ "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
+ LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
+ A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
+ HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
+ SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
+ LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
+ DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
+ THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
+ (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
+ OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
+
+
------------------------------------------------------------------------------
+
+
See version control history for details of individual contributions.
+
+
The above copyright and license notice applies to distributions of
+ CMake in source and binary form. Third-party software packages supplied
+ with CMake under compatible licenses provide their own copyright notices
+ documented in corresponding subdirectories or source files.
+
+
------------------------------------------------------------------------------
+
+
CMake was initially developed by Kitware with the following sponsorship:
+
+
* National Library of Medicine at the National Institutes of Health as part of the Insight Segmentation and Registration Toolkit (ITK).
+
+
* US National Labs (Los Alamos, Livermore, Sandia) ASC Parallel Visualization Initiative.
+
+
* National Alliance for Medical Image Computing (NAMIC) is funded by the National Institutes of Health through the NIH Roadmap for Medical Research, Grant U54 EB005149.
+
+
* Kitware, Inc.
+
+
The FreeType Project License
diff --git a/docs/INSTALL.md b/docs/INSTALL.md
index dc9375be16..281dfe84ad 100644
--- a/docs/INSTALL.md
+++ b/docs/INSTALL.md
@@ -115,6 +115,10 @@ sudo apt update && sudo apt install -y \
libqt6positioning6-plugins \
libqt6positioning6 \
libsqlite3-dev \
+ libxrandr-dev \
+ libxinerama-dev \
+ libxcursor-dev \
+ libxi-dev \
zlib1g-dev
```
--
2.45.3
From 1ea96c406900bff00ade12784ef6d3dc547ce20f Mon Sep 17 00:00:00 2001
From: Konstantin Pastbin
Date: Mon, 24 Feb 2025 19:08:48 +0700
Subject: [PATCH 03/73] [styles] Add captions to linear cliffs, city walls,
embankments
Signed-off-by: Konstantin Pastbin
---
.../default/include/Basemap_label.mapcss | 19 +++++++++++++++++++
.../include/priorities_4_overlays.prio.txt | 6 ++++++
.../outdoors/include/Basemap_label.mapcss | 6 ++++++
.../include/priorities_4_overlays.prio.txt | 6 ++++++
4 files changed, 37 insertions(+)
diff --git a/data/styles/default/include/Basemap_label.mapcss b/data/styles/default/include/Basemap_label.mapcss
index e5ecac4f97..b284c50099 100644
--- a/data/styles/default/include/Basemap_label.mapcss
+++ b/data/styles/default/include/Basemap_label.mapcss
@@ -496,6 +496,25 @@ node|z15-[natural=beach],
area|z16-[leisure=beach_resort],
{text: name; font-size: 10; text-color: @poi_label; text-offset: 1;}
+/* Barriers, cliffs */
+
+line[natural=cliff],
+line[barrier=city_wall],
+line[historic=citywalls],
+line[man_made=embankment],
+{text-position: line;}
+
+line|z16-[natural=cliff],
+line|z16-[barrier=city_wall],
+line|z16-[historic=citywalls],
+line|z18-[man_made=embankment],
+{text: name; font-size: 9; text-color: @label_light; text-halo-opacity: 0.8; text-halo-radius: 1; text-halo-color: @label_halo_medium;}
+line|z18-[natural=cliff],
+line|z18-[barrier=city_wall],
+line|z18-[historic=citywalls],
+line|z18-[man_made=embankment],
+{font-size: 10;}
+
/* 6.WATER */
node|z1-[place=ocean],
diff --git a/data/styles/default/include/priorities_4_overlays.prio.txt b/data/styles/default/include/priorities_4_overlays.prio.txt
index 39c51a10f3..25fcb087d4 100644
--- a/data/styles/default/include/priorities_4_overlays.prio.txt
+++ b/data/styles/default/include/priorities_4_overlays.prio.txt
@@ -656,6 +656,10 @@ highway-tertiary-bridge::shield # shield::shield z13- (also
highway-tertiary-tunnel::shield # shield::shield z13- (also has pathtext z12-, line z11-, line(casing) z16-)
=== 2960
+barrier-city_wall
+historic-citywalls
+=== 2957
+
highway-residential::shield # shield::shield z15- (also has pathtext z13-, line z12-)
highway-residential-area::shield # shield::shield z15- (also has pathtext z13-, line z12-)
highway-residential-bridge::shield # shield::shield z15- (also has pathtext z13-, line z12-, line::bridgeblack z14-, line::bridgewhite z14-)
@@ -998,6 +1002,7 @@ amenity-shelter-public_transport # icon z17- (also has captio
emergency-lifeguard # icon z17- (also has caption(optional) z18-)
leisure-fitness_station # icon z17- (also has caption(optional) z17-)
leisure-playground # icon z17- (also has caption(optional) z17-, area z16-)
+natural-cliff
=== 1500
sport-american_football # icon z17- (also has caption(optional) z17-)
@@ -1157,6 +1162,7 @@ shop-wholesale # icon z18- (also has captio
amenity-shower # icon z17- (also has caption(optional) z17-)
amenity-toilets # icon z18- (also has caption(optional) z18-)
+man_made-embankment
office # icon z18- (also has caption(optional) z18-)
shop # icon z18- (also has caption(optional) z18-)
=== 470
diff --git a/data/styles/outdoors/include/Basemap_label.mapcss b/data/styles/outdoors/include/Basemap_label.mapcss
index d2b4b6edb0..f879434beb 100644
--- a/data/styles/outdoors/include/Basemap_label.mapcss
+++ b/data/styles/outdoors/include/Basemap_label.mapcss
@@ -1,6 +1,12 @@
/* Keep here changes of the base map style file only. */
@import("../../default/include/Basemap_label.mapcss");
+/* Barriers, cliffs */
+
+line|z14-[natural=cliff],
+{text: name; font-size: 11; text-color: @label_light; text-halo-opacity: 0.8; text-halo-radius: 1; text-halo-color: @label_halo_medium;}
+line|z16-[natural=cliff],
+{font-size: 12; text-color: @label_medium; text-halo-color: @label_halo_light;}
/* 9. ISOLINES */
diff --git a/data/styles/outdoors/include/priorities_4_overlays.prio.txt b/data/styles/outdoors/include/priorities_4_overlays.prio.txt
index 6dfc8b70c9..7723c53cd7 100644
--- a/data/styles/outdoors/include/priorities_4_overlays.prio.txt
+++ b/data/styles/outdoors/include/priorities_4_overlays.prio.txt
@@ -656,6 +656,10 @@ highway-tertiary-bridge::shield # shield::shield z13- (also
highway-tertiary-tunnel::shield # shield::shield z13- (also has pathtext z12-, line z11-, line(casing) z16-)
=== 2960
+barrier-city_wall
+historic-citywalls
+=== 2957
+
highway-residential::shield # shield::shield z15- (also has pathtext z13-, line z12-)
highway-residential-area::shield # shield::shield z15- (also has pathtext z13-, line z12-)
highway-residential-bridge::shield # shield::shield z15- (also has pathtext z13-, line z12-, line::bridgeblack z14-, line::bridgewhite z14-)
@@ -998,6 +1002,7 @@ amenity-shelter-public_transport # icon z14- (also has captio
emergency-lifeguard # icon z14- (also has caption(optional) z18-)
leisure-fitness_station # icon z17- (also has caption(optional) z17-)
leisure-playground # icon z17- (also has caption(optional) z17-, area z16-)
+natural-cliff
=== 1500
sport-american_football # icon z17- (also has caption(optional) z17-)
@@ -1157,6 +1162,7 @@ shop-wholesale # icon z18- (also has captio
amenity-shower # icon z17- (also has caption(optional) z17-)
amenity-toilets # icon z15- (also has caption(optional) z18-)
+man_made-embankment
office # icon z18- (also has caption(optional) z18-)
shop # icon z18- (also has caption(optional) z18-)
=== 470
--
2.45.3
From cf7a71b5907e4fe022b246942afd48e390a7229b Mon Sep 17 00:00:00 2001
From: Konstantin Pastbin
Date: Mon, 24 Feb 2025 19:23:59 +0700
Subject: [PATCH 04/73] [styles] Add pathtexts to power lines
Signed-off-by: Konstantin Pastbin
---
data/styles/outdoors/include/Basemap_label.mapcss | 8 ++++++++
.../outdoors/include/priorities_4_overlays.prio.txt | 1 +
2 files changed, 9 insertions(+)
diff --git a/data/styles/outdoors/include/Basemap_label.mapcss b/data/styles/outdoors/include/Basemap_label.mapcss
index f879434beb..e158bcd2e5 100644
--- a/data/styles/outdoors/include/Basemap_label.mapcss
+++ b/data/styles/outdoors/include/Basemap_label.mapcss
@@ -8,6 +8,14 @@ line|z14-[natural=cliff],
line|z16-[natural=cliff],
{font-size: 12; text-color: @label_medium; text-halo-color: @label_halo_light;}
+line[power=line],
+{text-position: line;}
+line|z15-[power=line],
+{text: name; font-size: 10; text-color: @label_light; text-halo-opacity: 0.7; text-halo-radius: 1; text-halo-color: @label_halo_medium;}
+line|z16-[power=line],
+{font-size: 11;}
+
+
/* 9. ISOLINES */
line[isoline]
diff --git a/data/styles/outdoors/include/priorities_4_overlays.prio.txt b/data/styles/outdoors/include/priorities_4_overlays.prio.txt
index 7723c53cd7..74068f4bef 100644
--- a/data/styles/outdoors/include/priorities_4_overlays.prio.txt
+++ b/data/styles/outdoors/include/priorities_4_overlays.prio.txt
@@ -1073,6 +1073,7 @@ natural-spring-drinking_water_no # icon z12- (also has captio
isoline-step_10 # pathtext z16- (also has line z15-)
isoline-zero # pathtext z15- (also has line z15-)
+power-line
=== 1000
amenity-grave_yard # icon z17- (also has caption(optional) z17-, area z14-)
--
2.45.3
From b9d0138cd1c926c222f2f322b78f62fb1df2f284 Mon Sep 17 00:00:00 2001
From: Konstantin Pastbin
Date: Mon, 24 Feb 2025 19:14:04 +0700
Subject: [PATCH 05/73] [styles] Regenerate for pathtexts
Signed-off-by: Konstantin Pastbin
---
data/drules_proto.bin | Bin 430538 -> 430898 bytes
data/drules_proto.txt | 144 ++++++++++++
data/drules_proto_default_dark.bin | Bin 413840 -> 414200 bytes
data/drules_proto_default_dark.txt | 144 ++++++++++++
data/drules_proto_default_light.bin | Bin 415197 -> 415557 bytes
data/drules_proto_default_light.txt | 144 ++++++++++++
data/drules_proto_outdoors_dark.bin | Bin 432726 -> 433246 bytes
data/drules_proto_outdoors_dark.txt | 208 ++++++++++++++++++
data/drules_proto_outdoors_light.bin | Bin 434194 -> 434714 bytes
data/drules_proto_outdoors_light.txt | 208 ++++++++++++++++++
.../default/include/priorities_3_FG.prio.txt | 8 +-
.../include/priorities_4_overlays.prio.txt | 8 +-
.../outdoors/include/priorities_3_FG.prio.txt | 12 +-
.../include/priorities_4_overlays.prio.txt | 10 +-
14 files changed, 867 insertions(+), 19 deletions(-)
diff --git a/data/drules_proto.bin b/data/drules_proto.bin
index 3e0b3a964072085508680308604df06c0701bb59..70b4c4df445e66ab7a89c236077692241cf45821 100644
GIT binary patch
delta 583
zcmX@LSZdQUsSSk}n65KVF23Nw=r?)K1uHQtAue7HPJtsG6PYA#U*A5TS)x~5$Zzrw
z+)^eNp}M#*bQR#1T657#1Z)?YuI6VKw?Dhcs1?R^gL%4;29qbF-}D#_CR`4iJ_C>3
z6}TLlB|?7F1vFu1V#@gd<*+(#dz&WH%znln(-n3y^)mWSU$>LVQUcQ#*O-NTIfSQg
z*vVv$OI8Fdi^Y;_%-dskG5wHZI>$0S{3g>8pe-`Dm@Kix%N=eZ-|69aTnQCRsx*00mho9#bm*BfT`K*
z(sr*)j9Ot#UznzsX)t+0Ot6CL2h%{^U>c|wL<4nNZTHh+n%U2|XZnksOudYj)5~@-
zS+WROatKea*u`WHVu^rR+Y@&){g7jN#XLRw7SoaK1rM3j8QWLgVFF@iAZFRV>JDqi
FHUK6SLGb_p
diff --git a/data/drules_proto.txt b/data/drules_proto.txt
index 5fb3a8f910..84305e5227 100644
--- a/data/drules_proto.txt
+++ b/data/drules_proto.txt
@@ -16053,6 +16053,14 @@ cont {
}
priority: 320
}
+ path_text {
+ primary {
+ height: 9
+ color: 4473924
+ stroke_color: 871230427
+ }
+ priority: 2957
+ }
}
element {
scale: 17
@@ -16067,6 +16075,14 @@ cont {
}
priority: 320
}
+ path_text {
+ primary {
+ height: 9
+ color: 4473924
+ stroke_color: 871230427
+ }
+ priority: 2957
+ }
}
element {
scale: 18
@@ -16081,6 +16097,14 @@ cont {
}
priority: 320
}
+ path_text {
+ primary {
+ height: 10
+ color: 4473924
+ stroke_color: 871230427
+ }
+ priority: 2957
+ }
}
element {
scale: 19
@@ -16095,6 +16119,14 @@ cont {
}
priority: 320
}
+ path_text {
+ primary {
+ height: 10
+ color: 4473924
+ stroke_color: 871230427
+ }
+ priority: 2957
+ }
}
element {
scale: 20
@@ -16109,6 +16141,14 @@ cont {
}
priority: 320
}
+ path_text {
+ primary {
+ height: 10
+ color: 4473924
+ stroke_color: 871230427
+ }
+ priority: 2957
+ }
}
}
cont {
@@ -44069,6 +44109,14 @@ cont {
}
priority: 360
}
+ path_text {
+ primary {
+ height: 9
+ color: 4473924
+ stroke_color: 871230427
+ }
+ priority: 2957
+ }
}
element {
scale: 17
@@ -44083,6 +44131,14 @@ cont {
}
priority: 360
}
+ path_text {
+ primary {
+ height: 9
+ color: 4473924
+ stroke_color: 871230427
+ }
+ priority: 2957
+ }
}
element {
scale: 18
@@ -44097,6 +44153,14 @@ cont {
}
priority: 360
}
+ path_text {
+ primary {
+ height: 10
+ color: 4473924
+ stroke_color: 871230427
+ }
+ priority: 2957
+ }
}
element {
scale: 19
@@ -44111,6 +44175,14 @@ cont {
}
priority: 360
}
+ path_text {
+ primary {
+ height: 10
+ color: 4473924
+ stroke_color: 871230427
+ }
+ priority: 2957
+ }
}
element {
scale: 20
@@ -44125,6 +44197,14 @@ cont {
}
priority: 360
}
+ path_text {
+ primary {
+ height: 10
+ color: 4473924
+ stroke_color: 871230427
+ }
+ priority: 2957
+ }
}
}
cont {
@@ -55893,6 +55973,14 @@ cont {
}
priority: 100
}
+ path_text {
+ primary {
+ height: 10
+ color: 4473924
+ stroke_color: 871230427
+ }
+ priority: 470
+ }
}
element {
scale: 19
@@ -55907,6 +55995,14 @@ cont {
}
priority: 100
}
+ path_text {
+ primary {
+ height: 10
+ color: 4473924
+ stroke_color: 871230427
+ }
+ priority: 470
+ }
}
element {
scale: 20
@@ -55921,6 +56017,14 @@ cont {
}
priority: 100
}
+ path_text {
+ primary {
+ height: 10
+ color: 4473924
+ stroke_color: 871230427
+ }
+ priority: 470
+ }
}
}
cont {
@@ -58611,6 +58715,14 @@ cont {
}
priority: 100
}
+ path_text {
+ primary {
+ height: 9
+ color: 4473924
+ stroke_color: 871230427
+ }
+ priority: 1500
+ }
}
element {
scale: 17
@@ -58625,6 +58737,14 @@ cont {
}
priority: 100
}
+ path_text {
+ primary {
+ height: 9
+ color: 4473924
+ stroke_color: 871230427
+ }
+ priority: 1500
+ }
}
element {
scale: 18
@@ -58639,6 +58759,14 @@ cont {
}
priority: 100
}
+ path_text {
+ primary {
+ height: 10
+ color: 4473924
+ stroke_color: 871230427
+ }
+ priority: 1500
+ }
}
element {
scale: 19
@@ -58653,6 +58781,14 @@ cont {
}
priority: 100
}
+ path_text {
+ primary {
+ height: 10
+ color: 4473924
+ stroke_color: 871230427
+ }
+ priority: 1500
+ }
}
element {
scale: 20
@@ -58667,6 +58803,14 @@ cont {
}
priority: 100
}
+ path_text {
+ primary {
+ height: 10
+ color: 4473924
+ stroke_color: 871230427
+ }
+ priority: 1500
+ }
}
}
cont {
diff --git a/data/drules_proto_default_dark.bin b/data/drules_proto_default_dark.bin
index 0613990dbcec173a0a3765925326d04a1f442ae6..dbc81ebb5eb2d2f54f5311d4687e82f682b02d1e 100644
GIT binary patch
delta 593
zcmbQRQ1ZuO$qj3cFqu=zi>`WFC2bipcxOh1@1)iOm$t=;Z=*SFaiC%Fb
zzv-MDcw{H%AGZ<%YvjVv*odSNQ+6*