Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in
Toggle navigation
V
vlc-2-2
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Redmine
Redmine
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Operations
Operations
Metrics
Environments
Analytics
Analytics
CI / CD
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
videolan
vlc-2-2
Commits
761ea8aa
Commit
761ea8aa
authored
Jul 09, 2013
by
Nicolas Bertrand
Committed by
Jean-Baptiste Kempf
Jul 09, 2013
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
OpenGL: Addition of XYZ to RGB conversion in GLSL
Signed-off-by:
Jean-Baptiste Kempf
<
jb@videolan.org
>
parent
a27daf20
Changes
1
Show whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
57 additions
and
3 deletions
+57
-3
modules/video_output/opengl.c
modules/video_output/opengl.c
+57
-3
No files found.
modules/video_output/opengl.c
View file @
761ea8aa
...
@@ -340,6 +340,46 @@ static void BuildRGBAFragmentShader(vout_display_opengl_t *vgl,
...
@@ -340,6 +340,46 @@ static void BuildRGBAFragmentShader(vout_display_opengl_t *vgl,
vgl
->
ShaderSource
(
*
shader
,
1
,
&
code
,
NULL
);
vgl
->
ShaderSource
(
*
shader
,
1
,
&
code
,
NULL
);
vgl
->
CompileShader
(
*
shader
);
vgl
->
CompileShader
(
*
shader
);
}
}
static
void
BuildXYZFragmentShader
(
vout_display_opengl_t
*
vgl
,
GLint
*
shader
)
{
/* Shader for XYZ to RGB correction
* 3 steps :
* - XYZ gamma correction
* - XYZ to RGB matrix conversion
* - reverse RGB gamma correction
*/
const
char
*
code
=
"#version "
GLSL_VERSION
"
\n
"
PRECISION
"uniform sampler2D Texture0;"
"uniform vec4 xyz_gamma = vec4(2.6);"
"uniform vec4 rgb_gamma = vec4(1.0/2.2);"
// WARN: matrix Is filled column by column (not row !)
"uniform mat4 matrix_xyz_rgb = mat4("
" 3.240454 , -0.9692660, 0.0556434, 0.0,"
" -1.5371385, 1.8760108, -0.2040259, 0.0,"
" -0.4985314, 0.0415560, 1.0572252, 0.0,"
" 0.0, 0.0, 0.0, 1.0 "
" );"
"varying vec4 TexCoord0;"
"void main()"
"{ "
" vec4 v_in, v_out;"
" v_in = texture2D(Texture0, TexCoord0.st);"
" v_in = pow(v_in, xyz_gamma);"
" v_out = matrix_xyz_rgb * v_in ;"
" v_out = pow(v_out, rgb_gamma) ;"
" v_out = clamp(v_out, 0.0, 1.0) ;"
" gl_FragColor = v_out;"
"}"
;
*
shader
=
vgl
->
CreateShader
(
GL_FRAGMENT_SHADER
);
vgl
->
ShaderSource
(
*
shader
,
1
,
&
code
,
NULL
);
vgl
->
CompileShader
(
*
shader
);
}
#endif
#endif
vout_display_opengl_t
*
vout_display_opengl_New
(
video_format_t
*
fmt
,
vout_display_opengl_t
*
vout_display_opengl_New
(
video_format_t
*
fmt
,
...
@@ -465,6 +505,7 @@ vout_display_opengl_t *vout_display_opengl_New(video_format_t *fmt,
...
@@ -465,6 +505,7 @@ vout_display_opengl_t *vout_display_opengl_New(video_format_t *fmt,
vgl
->
tex_type
=
GL_UNSIGNED_BYTE
;
vgl
->
tex_type
=
GL_UNSIGNED_BYTE
;
/* Use YUV if possible and needed */
/* Use YUV if possible and needed */
bool
need_fs_yuv
=
false
;
bool
need_fs_yuv
=
false
;
bool
need_fs_xyz
=
false
;
bool
need_fs_rgba
=
USE_OPENGL_ES
==
2
;
bool
need_fs_rgba
=
USE_OPENGL_ES
==
2
;
float
yuv_range_correction
=
1
.
0
;
float
yuv_range_correction
=
1
.
0
;
...
@@ -498,6 +539,15 @@ vout_display_opengl_t *vout_display_opengl_New(video_format_t *fmt,
...
@@ -498,6 +539,15 @@ vout_display_opengl_t *vout_display_opengl_New(video_format_t *fmt,
}
}
}
}
if
(
fmt
->
i_chroma
==
VLC_CODEC_XYZ12
)
{
vlc_fourcc_GetChromaDescription
(
fmt
->
i_chroma
);
need_fs_xyz
=
true
;
vgl
->
fmt
=
*
fmt
;
vgl
->
fmt
.
i_chroma
=
VLC_CODEC_XYZ12
;
vgl
->
tex_format
=
GL_RGB
;
vgl
->
tex_internal
=
GL_RGB
;
vgl
->
tex_type
=
GL_UNSIGNED_SHORT
;
}
vgl
->
chroma
=
vlc_fourcc_GetChromaDescription
(
vgl
->
fmt
.
i_chroma
);
vgl
->
chroma
=
vlc_fourcc_GetChromaDescription
(
vgl
->
fmt
.
i_chroma
);
vgl
->
use_multitexture
=
vgl
->
chroma
->
plane_count
>
1
;
vgl
->
use_multitexture
=
vgl
->
chroma
->
plane_count
>
1
;
...
@@ -521,10 +571,14 @@ vout_display_opengl_t *vout_display_opengl_New(video_format_t *fmt,
...
@@ -521,10 +571,14 @@ vout_display_opengl_t *vout_display_opengl_New(video_format_t *fmt,
vgl
->
shader
[
1
]
=
vgl
->
shader
[
1
]
=
vgl
->
shader
[
2
]
=
-
1
;
vgl
->
shader
[
2
]
=
-
1
;
vgl
->
local_count
=
0
;
vgl
->
local_count
=
0
;
if
(
supports_shaders
&&
(
need_fs_yuv
||
need_fs_rgba
))
{
if
(
supports_shaders
&&
(
need_fs_yuv
||
need_fs_
xyz
||
need_fs_
rgba
))
{
#ifdef SUPPORTS_SHADERS
#ifdef SUPPORTS_SHADERS
if
(
need_fs_xyz
)
BuildXYZFragmentShader
(
vgl
,
&
vgl
->
shader
[
0
]);
else
BuildYUVFragmentShader
(
vgl
,
&
vgl
->
shader
[
0
],
&
vgl
->
local_count
,
BuildYUVFragmentShader
(
vgl
,
&
vgl
->
shader
[
0
],
&
vgl
->
local_count
,
vgl
->
local_value
,
fmt
,
yuv_range_correction
);
vgl
->
local_value
,
fmt
,
yuv_range_correction
);
BuildRGBAFragmentShader
(
vgl
,
&
vgl
->
shader
[
1
]);
BuildRGBAFragmentShader
(
vgl
,
&
vgl
->
shader
[
1
]);
BuildVertexShader
(
vgl
,
&
vgl
->
shader
[
2
]);
BuildVertexShader
(
vgl
,
&
vgl
->
shader
[
2
]);
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment