Mercurial > hg > orthanc-stone
annotate OrthancStone/Sources/OpenGL/ImageProcessingProgram.cpp @ 2061:6ea5f40ea0e9 deep-learning
added ImageProcessingProgram
author | Sebastien Jodogne <s.jodogne@gmail.com> |
---|---|
date | Wed, 03 May 2023 16:34:34 +0200 |
parents | |
children | 4e31d76c7ecd |
rev | line source |
---|---|
2061
6ea5f40ea0e9
added ImageProcessingProgram
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
1 /** |
6ea5f40ea0e9
added ImageProcessingProgram
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
2 * Stone of Orthanc |
6ea5f40ea0e9
added ImageProcessingProgram
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
3 * Copyright (C) 2012-2016 Sebastien Jodogne, Medical Physics |
6ea5f40ea0e9
added ImageProcessingProgram
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
4 * Department, University Hospital of Liege, Belgium |
6ea5f40ea0e9
added ImageProcessingProgram
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
5 * Copyright (C) 2017-2022 Osimis S.A., Belgium |
6ea5f40ea0e9
added ImageProcessingProgram
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
6 * Copyright (C) 2021-2022 Sebastien Jodogne, ICTEAM UCLouvain, Belgium |
6ea5f40ea0e9
added ImageProcessingProgram
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
7 * |
6ea5f40ea0e9
added ImageProcessingProgram
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
8 * This program is free software: you can redistribute it and/or |
6ea5f40ea0e9
added ImageProcessingProgram
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
9 * modify it under the terms of the GNU Lesser General Public License |
6ea5f40ea0e9
added ImageProcessingProgram
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
10 * as published by the Free Software Foundation, either version 3 of |
6ea5f40ea0e9
added ImageProcessingProgram
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
11 * the License, or (at your option) any later version. |
6ea5f40ea0e9
added ImageProcessingProgram
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
12 * |
6ea5f40ea0e9
added ImageProcessingProgram
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
13 * This program is distributed in the hope that it will be useful, but |
6ea5f40ea0e9
added ImageProcessingProgram
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
14 * WITHOUT ANY WARRANTY; without even the implied warranty of |
6ea5f40ea0e9
added ImageProcessingProgram
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
15 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU |
6ea5f40ea0e9
added ImageProcessingProgram
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
16 * Lesser General Public License for more details. |
6ea5f40ea0e9
added ImageProcessingProgram
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
17 * |
6ea5f40ea0e9
added ImageProcessingProgram
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
18 * You should have received a copy of the GNU Lesser General Public |
6ea5f40ea0e9
added ImageProcessingProgram
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
19 * License along with this program. If not, see |
6ea5f40ea0e9
added ImageProcessingProgram
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
20 * <http://www.gnu.org/licenses/>. |
6ea5f40ea0e9
added ImageProcessingProgram
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
21 **/ |
6ea5f40ea0e9
added ImageProcessingProgram
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
22 |
6ea5f40ea0e9
added ImageProcessingProgram
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
23 |
6ea5f40ea0e9
added ImageProcessingProgram
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
24 #include "ImageProcessingProgram.h" |
6ea5f40ea0e9
added ImageProcessingProgram
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
25 |
6ea5f40ea0e9
added ImageProcessingProgram
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
26 #include "OpenGLFramebuffer.h" |
6ea5f40ea0e9
added ImageProcessingProgram
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
27 |
6ea5f40ea0e9
added ImageProcessingProgram
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
28 #include <OrthancException.h> |
6ea5f40ea0e9
added ImageProcessingProgram
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
29 |
6ea5f40ea0e9
added ImageProcessingProgram
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
30 |
6ea5f40ea0e9
added ImageProcessingProgram
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
31 static const unsigned int DIMENSIONS = 2; // Number of dimensions (we draw in 2D) |
6ea5f40ea0e9
added ImageProcessingProgram
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
32 static const unsigned int VERTICES = 6; // 2 triangles in 2D (each triangle has 3 vertices) |
6ea5f40ea0e9
added ImageProcessingProgram
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
33 |
6ea5f40ea0e9
added ImageProcessingProgram
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
34 |
6ea5f40ea0e9
added ImageProcessingProgram
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
35 static const float TRIANGLES[DIMENSIONS * VERTICES] = { |
6ea5f40ea0e9
added ImageProcessingProgram
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
36 // First triangle |
6ea5f40ea0e9
added ImageProcessingProgram
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
37 -1.0f, -1.0f, |
6ea5f40ea0e9
added ImageProcessingProgram
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
38 1.0f, -1.0f, |
6ea5f40ea0e9
added ImageProcessingProgram
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
39 -1.0f, 1.0f, |
6ea5f40ea0e9
added ImageProcessingProgram
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
40 // Second triangle |
6ea5f40ea0e9
added ImageProcessingProgram
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
41 -1.0f, 1.0f, |
6ea5f40ea0e9
added ImageProcessingProgram
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
42 1.0f, -1.0f, |
6ea5f40ea0e9
added ImageProcessingProgram
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
43 1.0f, 1.0f |
6ea5f40ea0e9
added ImageProcessingProgram
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
44 }; |
6ea5f40ea0e9
added ImageProcessingProgram
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
45 |
6ea5f40ea0e9
added ImageProcessingProgram
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
46 |
6ea5f40ea0e9
added ImageProcessingProgram
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
47 /** |
6ea5f40ea0e9
added ImageProcessingProgram
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
48 * "varying" indicates variables that are shader by the vertex shader |
6ea5f40ea0e9
added ImageProcessingProgram
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
49 * and the fragment shader. The reason for "v_position" is that |
6ea5f40ea0e9
added ImageProcessingProgram
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
50 * "a_position" (position in the target frame buffer) ranges from -1 |
6ea5f40ea0e9
added ImageProcessingProgram
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
51 * to 1, whereas texture samplers range from 0 to 1. |
6ea5f40ea0e9
added ImageProcessingProgram
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
52 **/ |
6ea5f40ea0e9
added ImageProcessingProgram
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
53 static const char* VERTEX_SHADER = |
6ea5f40ea0e9
added ImageProcessingProgram
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
54 "in vec2 a_position; \n" |
6ea5f40ea0e9
added ImageProcessingProgram
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
55 "out vec2 v_position; \n" |
6ea5f40ea0e9
added ImageProcessingProgram
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
56 "void main() { \n" |
6ea5f40ea0e9
added ImageProcessingProgram
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
57 " v_position = (a_position + 1.0) / 2.0; \n" |
6ea5f40ea0e9
added ImageProcessingProgram
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
58 " gl_Position = vec4(a_position, 0, 1.0); \n" |
6ea5f40ea0e9
added ImageProcessingProgram
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
59 "} \n"; |
6ea5f40ea0e9
added ImageProcessingProgram
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
60 |
6ea5f40ea0e9
added ImageProcessingProgram
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
61 |
6ea5f40ea0e9
added ImageProcessingProgram
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
62 namespace OrthancStone |
6ea5f40ea0e9
added ImageProcessingProgram
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
63 { |
6ea5f40ea0e9
added ImageProcessingProgram
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
64 namespace OpenGL |
6ea5f40ea0e9
added ImageProcessingProgram
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
65 { |
6ea5f40ea0e9
added ImageProcessingProgram
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
66 void ImageProcessingProgram::SetupPosition() |
6ea5f40ea0e9
added ImageProcessingProgram
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
67 { |
6ea5f40ea0e9
added ImageProcessingProgram
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
68 glBindBuffer(GL_ARRAY_BUFFER, quad_vertexbuffer); |
6ea5f40ea0e9
added ImageProcessingProgram
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
69 glBufferData(GL_ARRAY_BUFFER, sizeof(float) * DIMENSIONS * VERTICES, TRIANGLES, GL_STATIC_DRAW); |
6ea5f40ea0e9
added ImageProcessingProgram
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
70 GLint positionLocation = program_.GetAttributeLocation("a_position"); |
6ea5f40ea0e9
added ImageProcessingProgram
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
71 glVertexAttribPointer(positionLocation, 2, GL_FLOAT, GL_FALSE, 0, 0); |
6ea5f40ea0e9
added ImageProcessingProgram
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
72 glEnableVertexAttribArray(positionLocation); |
6ea5f40ea0e9
added ImageProcessingProgram
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
73 } |
6ea5f40ea0e9
added ImageProcessingProgram
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
74 |
6ea5f40ea0e9
added ImageProcessingProgram
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
75 |
6ea5f40ea0e9
added ImageProcessingProgram
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
76 ImageProcessingProgram::ImageProcessingProgram(IOpenGLContext& context, |
6ea5f40ea0e9
added ImageProcessingProgram
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
77 const std::string& fragmentShader) : |
6ea5f40ea0e9
added ImageProcessingProgram
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
78 program_(context), |
6ea5f40ea0e9
added ImageProcessingProgram
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
79 quad_vertexbuffer(0) |
6ea5f40ea0e9
added ImageProcessingProgram
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
80 { |
6ea5f40ea0e9
added ImageProcessingProgram
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
81 if (context.IsContextLost()) |
6ea5f40ea0e9
added ImageProcessingProgram
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
82 { |
6ea5f40ea0e9
added ImageProcessingProgram
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
83 throw Orthanc::OrthancException(Orthanc::ErrorCode_InternalError, |
6ea5f40ea0e9
added ImageProcessingProgram
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
84 "OpenGL context has been lost"); |
6ea5f40ea0e9
added ImageProcessingProgram
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
85 } |
6ea5f40ea0e9
added ImageProcessingProgram
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
86 |
6ea5f40ea0e9
added ImageProcessingProgram
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
87 context.MakeCurrent(); |
6ea5f40ea0e9
added ImageProcessingProgram
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
88 |
6ea5f40ea0e9
added ImageProcessingProgram
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
89 std::string version; |
6ea5f40ea0e9
added ImageProcessingProgram
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
90 |
6ea5f40ea0e9
added ImageProcessingProgram
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
91 #if ORTHANC_ENABLE_WASM == 1 |
6ea5f40ea0e9
added ImageProcessingProgram
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
92 /** |
6ea5f40ea0e9
added ImageProcessingProgram
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
93 * "#version 300 es" corresponds to: |
6ea5f40ea0e9
added ImageProcessingProgram
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
94 * - OpenGL ES version 3.0: https://registry.khronos.org/OpenGL-Refpages/es3.0/ |
6ea5f40ea0e9
added ImageProcessingProgram
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
95 * - WebGL version 2.0 |
6ea5f40ea0e9
added ImageProcessingProgram
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
96 * - GLSL ES version 3.00.6 |
6ea5f40ea0e9
added ImageProcessingProgram
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
97 * - Based on version GLSL version 3.0 |
6ea5f40ea0e9
added ImageProcessingProgram
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
98 * |
6ea5f40ea0e9
added ImageProcessingProgram
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
99 * Explanation for "highp": |
6ea5f40ea0e9
added ImageProcessingProgram
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
100 * https://emscripetn.org/docs/optimizing/Optimizing-WebGL.html |
6ea5f40ea0e9
added ImageProcessingProgram
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
101 * https://webglfundamentals.org/webgl/lessons/webgl-qna-when-to-choose-highp--mediump--lowp-in-shaders.html |
6ea5f40ea0e9
added ImageProcessingProgram
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
102 **/ |
6ea5f40ea0e9
added ImageProcessingProgram
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
103 version = ("#version 300 es\n" |
6ea5f40ea0e9
added ImageProcessingProgram
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
104 "precision highp float;\n" |
6ea5f40ea0e9
added ImageProcessingProgram
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
105 "precision highp sampler2D;\n" |
6ea5f40ea0e9
added ImageProcessingProgram
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
106 "precision highp sampler2DArray;\n"); |
6ea5f40ea0e9
added ImageProcessingProgram
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
107 #else |
6ea5f40ea0e9
added ImageProcessingProgram
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
108 /** |
6ea5f40ea0e9
added ImageProcessingProgram
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
109 * "#version 130" corresponds to: |
6ea5f40ea0e9
added ImageProcessingProgram
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
110 * - OpenGL version 3.0 |
6ea5f40ea0e9
added ImageProcessingProgram
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
111 * - GLSL version 1.30.10 |
6ea5f40ea0e9
added ImageProcessingProgram
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
112 **/ |
6ea5f40ea0e9
added ImageProcessingProgram
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
113 version = "#version 130\n"; |
6ea5f40ea0e9
added ImageProcessingProgram
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
114 #endif |
6ea5f40ea0e9
added ImageProcessingProgram
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
115 |
6ea5f40ea0e9
added ImageProcessingProgram
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
116 program_.CompileShaders(version + VERTEX_SHADER, version + fragmentShader); |
6ea5f40ea0e9
added ImageProcessingProgram
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
117 |
6ea5f40ea0e9
added ImageProcessingProgram
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
118 glGenBuffers(1, &quad_vertexbuffer); |
6ea5f40ea0e9
added ImageProcessingProgram
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
119 if (quad_vertexbuffer == 0) |
6ea5f40ea0e9
added ImageProcessingProgram
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
120 { |
6ea5f40ea0e9
added ImageProcessingProgram
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
121 throw Orthanc::OrthancException(Orthanc::ErrorCode_InternalError, |
6ea5f40ea0e9
added ImageProcessingProgram
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
122 "Cannot create OpenGL buffer"); |
6ea5f40ea0e9
added ImageProcessingProgram
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
123 } |
6ea5f40ea0e9
added ImageProcessingProgram
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
124 } |
6ea5f40ea0e9
added ImageProcessingProgram
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
125 |
6ea5f40ea0e9
added ImageProcessingProgram
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
126 |
6ea5f40ea0e9
added ImageProcessingProgram
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
127 ImageProcessingProgram::~ImageProcessingProgram() |
6ea5f40ea0e9
added ImageProcessingProgram
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
128 { |
6ea5f40ea0e9
added ImageProcessingProgram
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
129 glDeleteBuffers(1, &quad_vertexbuffer); |
6ea5f40ea0e9
added ImageProcessingProgram
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
130 } |
6ea5f40ea0e9
added ImageProcessingProgram
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
131 |
6ea5f40ea0e9
added ImageProcessingProgram
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
132 |
6ea5f40ea0e9
added ImageProcessingProgram
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
133 void ImageProcessingProgram::Use(OpenGLTexture& target, |
6ea5f40ea0e9
added ImageProcessingProgram
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
134 OpenGLFramebuffer& framebuffer, |
6ea5f40ea0e9
added ImageProcessingProgram
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
135 bool checkStatus) |
6ea5f40ea0e9
added ImageProcessingProgram
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
136 { |
6ea5f40ea0e9
added ImageProcessingProgram
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
137 program_.Use(checkStatus); |
6ea5f40ea0e9
added ImageProcessingProgram
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
138 framebuffer.SetTarget(target); |
6ea5f40ea0e9
added ImageProcessingProgram
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
139 SetupPosition(); |
6ea5f40ea0e9
added ImageProcessingProgram
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
140 } |
6ea5f40ea0e9
added ImageProcessingProgram
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
141 |
6ea5f40ea0e9
added ImageProcessingProgram
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
142 |
6ea5f40ea0e9
added ImageProcessingProgram
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
143 void ImageProcessingProgram::Use(OpenGLTextureArray& target, |
6ea5f40ea0e9
added ImageProcessingProgram
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
144 unsigned int targetLayer, |
6ea5f40ea0e9
added ImageProcessingProgram
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
145 OpenGLFramebuffer& framebuffer, |
6ea5f40ea0e9
added ImageProcessingProgram
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
146 bool checkStatus) |
6ea5f40ea0e9
added ImageProcessingProgram
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
147 { |
6ea5f40ea0e9
added ImageProcessingProgram
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
148 program_.Use(checkStatus); |
6ea5f40ea0e9
added ImageProcessingProgram
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
149 framebuffer.SetTarget(target, targetLayer); |
6ea5f40ea0e9
added ImageProcessingProgram
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
150 SetupPosition(); |
6ea5f40ea0e9
added ImageProcessingProgram
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
151 } |
6ea5f40ea0e9
added ImageProcessingProgram
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
152 |
6ea5f40ea0e9
added ImageProcessingProgram
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
153 |
6ea5f40ea0e9
added ImageProcessingProgram
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
154 void ImageProcessingProgram::Render() |
6ea5f40ea0e9
added ImageProcessingProgram
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
155 { |
6ea5f40ea0e9
added ImageProcessingProgram
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
156 glClearColor(0.0, 0.0, 0.0, 1.0); |
6ea5f40ea0e9
added ImageProcessingProgram
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
157 glClear(GL_COLOR_BUFFER_BIT); |
6ea5f40ea0e9
added ImageProcessingProgram
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
158 |
6ea5f40ea0e9
added ImageProcessingProgram
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
159 #if 1 |
6ea5f40ea0e9
added ImageProcessingProgram
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
160 glDrawArrays(GL_TRIANGLES, 0, VERTICES); |
6ea5f40ea0e9
added ImageProcessingProgram
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
161 #else |
6ea5f40ea0e9
added ImageProcessingProgram
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
162 // Simpler, but not available in WebGL |
6ea5f40ea0e9
added ImageProcessingProgram
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
163 glBegin(GL_QUADS); |
6ea5f40ea0e9
added ImageProcessingProgram
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
164 glVertex2f(-1, 1); // vertex 1 |
6ea5f40ea0e9
added ImageProcessingProgram
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
165 glVertex2f(-1, -1); // vertex 2 |
6ea5f40ea0e9
added ImageProcessingProgram
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
166 glVertex2f( 1, -1); // vertex 3 |
6ea5f40ea0e9
added ImageProcessingProgram
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
167 glVertex2f( 1, 1); // vertex 4 |
6ea5f40ea0e9
added ImageProcessingProgram
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
168 glEnd(); |
6ea5f40ea0e9
added ImageProcessingProgram
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
169 #endif |
6ea5f40ea0e9
added ImageProcessingProgram
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
170 |
6ea5f40ea0e9
added ImageProcessingProgram
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
171 ORTHANC_OPENGL_CHECK("glDrawArrays()"); |
6ea5f40ea0e9
added ImageProcessingProgram
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
172 } |
6ea5f40ea0e9
added ImageProcessingProgram
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
173 } |
6ea5f40ea0e9
added ImageProcessingProgram
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
174 } |