Mercurial > games > semicongine
annotate tests/test_vulkan_wrapper.nim @ 114:056e08dfad10
yay: first triangle rendering with new engine implmentation
author | Sam <sam@basx.dev> |
---|---|
date | Mon, 03 Apr 2023 00:06:24 +0700 |
parents | 7b695fb335ed |
children | e18538442837 |
rev | line source |
---|---|
96 | 1 import std/options |
2 | |
93 | 3 import semicongine/vulkan |
94 | 4 import semicongine/platform/window |
98 | 5 import semicongine/math |
109 | 6 import semicongine/entity |
7 import semicongine/scene | |
111
6fd10b7e2d6a
did: allow runtime shader-input definitions
Sam <sam@basx.dev>
parents:
109
diff
changeset
|
8 import semicongine/gpu_data |
112
0c5a74885796
did: real implementation of buffer and memory, getting closer to collect shit for drawing per pipeline
Sam <sam@basx.dev>
parents:
111
diff
changeset
|
9 import semicongine/mesh |
99
4deffc94484a
add: vertex and (initial) shader types and methods
Sam <sam@basx.dev>
parents:
98
diff
changeset
|
10 |
104 | 11 proc diagnostics(instance: Instance) = |
94 | 12 # diagnostic output |
93 | 13 echo "Devices" |
14 for device in instance.getPhysicalDevices(): | |
15 echo " " & $device | |
96 | 16 echo " Rating: " & $device.rateGraphics() |
93 | 17 echo " Extensions" |
18 for extension in device.getExtensions(): | |
19 echo " " & $extension | |
96 | 20 echo " Properties" |
21 echo " " & $device.getProperties() | |
22 echo " Features" | |
23 echo " " & $device.getFeatures() | |
93 | 24 echo " Queue families" |
25 for queueFamily in device.getQueueFamilies(): | |
26 echo " " & $queueFamily | |
94 | 27 echo " Surface present modes" |
96 | 28 for mode in device.getSurfacePresentModes(): |
94 | 29 echo " " & $mode |
30 echo " Surface formats" | |
96 | 31 for format in device.getSurfaceFormats(): |
94 | 32 echo " " & $format |
93 | 33 |
104 | 34 when isMainModule: |
35 # print basic driver infos | |
36 echo "Layers" | |
37 for layer in getLayers(): | |
38 echo " " & layer | |
39 echo "Instance extensions" | |
40 for extension in getInstanceExtensions(): | |
41 echo " " & extension | |
42 | |
43 # create instance | |
44 var thewindow = createWindow("Test") | |
45 var instance = thewindow.createInstance( | |
46 vulkanVersion=VK_MAKE_API_VERSION(0, 1, 3, 0), | |
47 instanceExtensions= @["VK_EXT_debug_utils"], | |
114
056e08dfad10
yay: first triangle rendering with new engine implmentation
Sam <sam@basx.dev>
parents:
113
diff
changeset
|
48 layers= @["VK_LAYER_KHRONOS_validation", "VK_LAYER_MESA_overlay"] |
104 | 49 ) |
50 var debugger = instance.createDebugMessenger() | |
51 | |
93 | 52 # create devices |
96 | 53 let selectedPhysicalDevice = instance.getPhysicalDevices().filterBestGraphics() |
54 var device = instance.createDevice( | |
55 selectedPhysicalDevice, | |
56 @[], | |
57 @[], | |
58 selectedPhysicalDevice.filterForGraphicsPresentationQueues() | |
59 ) | |
60 | |
114
056e08dfad10
yay: first triangle rendering with new engine implmentation
Sam <sam@basx.dev>
parents:
113
diff
changeset
|
61 const |
056e08dfad10
yay: first triangle rendering with new engine implmentation
Sam <sam@basx.dev>
parents:
113
diff
changeset
|
62 vertexInput = initAttributeGroup( |
056e08dfad10
yay: first triangle rendering with new engine implmentation
Sam <sam@basx.dev>
parents:
113
diff
changeset
|
63 asAttribute(default(Vec3f), "position"), |
056e08dfad10
yay: first triangle rendering with new engine implmentation
Sam <sam@basx.dev>
parents:
113
diff
changeset
|
64 asAttribute(default(Vec3f), "color"), |
056e08dfad10
yay: first triangle rendering with new engine implmentation
Sam <sam@basx.dev>
parents:
113
diff
changeset
|
65 ) |
056e08dfad10
yay: first triangle rendering with new engine implmentation
Sam <sam@basx.dev>
parents:
113
diff
changeset
|
66 vertexOutput = initAttributeGroup(asAttribute(default(Vec3f), "outcolor")) |
056e08dfad10
yay: first triangle rendering with new engine implmentation
Sam <sam@basx.dev>
parents:
113
diff
changeset
|
67 fragOutput = initAttributeGroup(asAttribute(default(Vec4f), "color")) |
056e08dfad10
yay: first triangle rendering with new engine implmentation
Sam <sam@basx.dev>
parents:
113
diff
changeset
|
68 vertexCode = compileGlslShader( |
056e08dfad10
yay: first triangle rendering with new engine implmentation
Sam <sam@basx.dev>
parents:
113
diff
changeset
|
69 stage=VK_SHADER_STAGE_VERTEX_BIT, |
056e08dfad10
yay: first triangle rendering with new engine implmentation
Sam <sam@basx.dev>
parents:
113
diff
changeset
|
70 inputs=vertexInput, |
056e08dfad10
yay: first triangle rendering with new engine implmentation
Sam <sam@basx.dev>
parents:
113
diff
changeset
|
71 outputs=vertexOutput, |
056e08dfad10
yay: first triangle rendering with new engine implmentation
Sam <sam@basx.dev>
parents:
113
diff
changeset
|
72 body="""gl_Position = vec4(position, 1.0); outcolor = color;""" |
056e08dfad10
yay: first triangle rendering with new engine implmentation
Sam <sam@basx.dev>
parents:
113
diff
changeset
|
73 ) |
056e08dfad10
yay: first triangle rendering with new engine implmentation
Sam <sam@basx.dev>
parents:
113
diff
changeset
|
74 fragmentCode = compileGlslShader( |
056e08dfad10
yay: first triangle rendering with new engine implmentation
Sam <sam@basx.dev>
parents:
113
diff
changeset
|
75 stage=VK_SHADER_STAGE_FRAGMENT_BIT, |
056e08dfad10
yay: first triangle rendering with new engine implmentation
Sam <sam@basx.dev>
parents:
113
diff
changeset
|
76 inputs=vertexOutput, |
056e08dfad10
yay: first triangle rendering with new engine implmentation
Sam <sam@basx.dev>
parents:
113
diff
changeset
|
77 outputs=fragOutput, |
056e08dfad10
yay: first triangle rendering with new engine implmentation
Sam <sam@basx.dev>
parents:
113
diff
changeset
|
78 body="color = vec4(outcolor, 1);" |
056e08dfad10
yay: first triangle rendering with new engine implmentation
Sam <sam@basx.dev>
parents:
113
diff
changeset
|
79 ) |
106 | 80 var |
114
056e08dfad10
yay: first triangle rendering with new engine implmentation
Sam <sam@basx.dev>
parents:
113
diff
changeset
|
81 vertexshader = device.createShaderModule(vertexCode) |
056e08dfad10
yay: first triangle rendering with new engine implmentation
Sam <sam@basx.dev>
parents:
113
diff
changeset
|
82 fragmentshader = device.createShaderModule(fragmentCode) |
108 | 83 surfaceFormat = device.physicalDevice.getSurfaceFormats().filterSurfaceFormat() |
111
6fd10b7e2d6a
did: allow runtime shader-input definitions
Sam <sam@basx.dev>
parents:
109
diff
changeset
|
84 renderPass = device.simpleForwardRenderPass(surfaceFormat.format, vertexshader, fragmentshader, 2) |
114
056e08dfad10
yay: first triangle rendering with new engine implmentation
Sam <sam@basx.dev>
parents:
113
diff
changeset
|
85 (swapchain, res) = device.createSwapchain(renderPass, surfaceFormat, device.firstGraphicsQueue().get().family, 2) |
108 | 86 if res != VK_SUCCESS: |
87 raise newException(Exception, "Unable to create swapchain") | |
96 | 88 |
113
7b695fb335ed
did: first final implementation of scene-graph <-> pipeline connection, not working yet
Sam <sam@basx.dev>
parents:
112
diff
changeset
|
89 var thescene = Scene( |
7b695fb335ed
did: first final implementation of scene-graph <-> pipeline connection, not working yet
Sam <sam@basx.dev>
parents:
112
diff
changeset
|
90 name: "main", |
7b695fb335ed
did: first final implementation of scene-graph <-> pipeline connection, not working yet
Sam <sam@basx.dev>
parents:
112
diff
changeset
|
91 root: newEntity("root", |
114
056e08dfad10
yay: first triangle rendering with new engine implmentation
Sam <sam@basx.dev>
parents:
113
diff
changeset
|
92 newEntity("triangle1", initMesh( |
056e08dfad10
yay: first triangle rendering with new engine implmentation
Sam <sam@basx.dev>
parents:
113
diff
changeset
|
93 positions=[newVec3f(0.0, -0.5), newVec3f(0.5, 0.5), newVec3f(-0.5, 0.5)], |
056e08dfad10
yay: first triangle rendering with new engine implmentation
Sam <sam@basx.dev>
parents:
113
diff
changeset
|
94 colors=[newVec3f(1.0, 0.0, 0.0), newVec3f(0.0, 1.0, 0.0), newVec3f(0.0, 0.0, 1.0)], |
056e08dfad10
yay: first triangle rendering with new engine implmentation
Sam <sam@basx.dev>
parents:
113
diff
changeset
|
95 )), |
113
7b695fb335ed
did: first final implementation of scene-graph <-> pipeline connection, not working yet
Sam <sam@basx.dev>
parents:
112
diff
changeset
|
96 ) |
7b695fb335ed
did: first final implementation of scene-graph <-> pipeline connection, not working yet
Sam <sam@basx.dev>
parents:
112
diff
changeset
|
97 ) |
111
6fd10b7e2d6a
did: allow runtime shader-input definitions
Sam <sam@basx.dev>
parents:
109
diff
changeset
|
98 thescene.setupDrawables(renderPass) |
109 | 99 |
111
6fd10b7e2d6a
did: allow runtime shader-input definitions
Sam <sam@basx.dev>
parents:
109
diff
changeset
|
100 echo "Setup successfull, start rendering" |
114
056e08dfad10
yay: first triangle rendering with new engine implmentation
Sam <sam@basx.dev>
parents:
113
diff
changeset
|
101 for i in 0 ..< 1000: |
111
6fd10b7e2d6a
did: allow runtime shader-input definitions
Sam <sam@basx.dev>
parents:
109
diff
changeset
|
102 discard swapchain.drawScene(thescene) |
108 | 103 echo "Rendered ", swapchain.framesRendered, " frames" |
114
056e08dfad10
yay: first triangle rendering with new engine implmentation
Sam <sam@basx.dev>
parents:
113
diff
changeset
|
104 checkVkResult device.vk.vkDeviceWaitIdle() |
056e08dfad10
yay: first triangle rendering with new engine implmentation
Sam <sam@basx.dev>
parents:
113
diff
changeset
|
105 |
056e08dfad10
yay: first triangle rendering with new engine implmentation
Sam <sam@basx.dev>
parents:
113
diff
changeset
|
106 # cleanup |
96 | 107 echo "Start cleanup" |
93 | 108 |
114
056e08dfad10
yay: first triangle rendering with new engine implmentation
Sam <sam@basx.dev>
parents:
113
diff
changeset
|
109 # logical |
056e08dfad10
yay: first triangle rendering with new engine implmentation
Sam <sam@basx.dev>
parents:
113
diff
changeset
|
110 thescene.destroy() |
108 | 111 |
114
056e08dfad10
yay: first triangle rendering with new engine implmentation
Sam <sam@basx.dev>
parents:
113
diff
changeset
|
112 # rendering objects |
103
1e2027dfc642
add: finally working initial approach for shader definitions
Sam <sam@basx.dev>
parents:
102
diff
changeset
|
113 vertexshader.destroy() |
1e2027dfc642
add: finally working initial approach for shader definitions
Sam <sam@basx.dev>
parents:
102
diff
changeset
|
114 fragmentshader.destroy() |
111
6fd10b7e2d6a
did: allow runtime shader-input definitions
Sam <sam@basx.dev>
parents:
109
diff
changeset
|
115 renderPass.destroy() |
96 | 116 swapchain.destroy() |
114
056e08dfad10
yay: first triangle rendering with new engine implmentation
Sam <sam@basx.dev>
parents:
113
diff
changeset
|
117 |
056e08dfad10
yay: first triangle rendering with new engine implmentation
Sam <sam@basx.dev>
parents:
113
diff
changeset
|
118 # global objects |
96 | 119 device.destroy() |
93 | 120 debugger.destroy() |
121 instance.destroy() |