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