mirror of
https://gitlab.freedesktop.org/gstreamer/gstreamer.git
synced 2025-01-25 08:38:21 +00:00
d3d12convert: Use new sampler filter update method
... instead of creating new converter Part-of: <https://gitlab.freedesktop.org/gstreamer/gstreamer/-/merge_requests/7550>
This commit is contained in:
parent
a1029d5b87
commit
62caa76155
1 changed files with 7 additions and 9 deletions
|
@ -143,7 +143,6 @@ struct GstD3D12ConvertPrivate
|
||||||
|
|
||||||
/* sampling method, configured via property */
|
/* sampling method, configured via property */
|
||||||
GstD3D12SamplingMethod sampling_method = DEFAULT_SAMPLING_METHOD;
|
GstD3D12SamplingMethod sampling_method = DEFAULT_SAMPLING_METHOD;
|
||||||
GstD3D12SamplingMethod active_sampling_method = DEFAULT_SAMPLING_METHOD;
|
|
||||||
|
|
||||||
/* orientation */
|
/* orientation */
|
||||||
/* method configured via property */
|
/* method configured via property */
|
||||||
|
@ -326,8 +325,10 @@ gst_d3d12_convert_set_sampling_method (GstD3D12Convert * self,
|
||||||
"Sampling method %d -> %d", priv->sampling_method, method);
|
"Sampling method %d -> %d", priv->sampling_method, method);
|
||||||
|
|
||||||
priv->sampling_method = method;
|
priv->sampling_method = method;
|
||||||
if (priv->sampling_method != priv->active_sampling_method)
|
if (priv->ctx && priv->ctx->conv) {
|
||||||
gst_base_transform_reconfigure_src (GST_BASE_TRANSFORM_CAST (self));
|
g_object_set (priv->ctx->conv, "sampler-filter",
|
||||||
|
gst_d3d12_sampling_method_to_native (method), nullptr);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
|
@ -1678,12 +1679,11 @@ gst_d3d12_convert_set_info (GstD3D12BaseFilter * filter,
|
||||||
priv->active_add_borders = priv->add_borders;
|
priv->active_add_borders = priv->add_borders;
|
||||||
priv->active_gamma_mode = priv->gamma_mode;
|
priv->active_gamma_mode = priv->gamma_mode;
|
||||||
priv->active_primaries_mode = priv->primaries_mode;
|
priv->active_primaries_mode = priv->primaries_mode;
|
||||||
priv->active_sampling_method = priv->sampling_method;
|
|
||||||
|
|
||||||
GST_DEBUG_OBJECT (self, "method %d, add-borders %d, gamma-mode %d, "
|
GST_DEBUG_OBJECT (self, "method %d, add-borders %d, gamma-mode %d, "
|
||||||
"primaries-mode %d, sampling %d", priv->active_method,
|
"primaries-mode %d, sampling %d", priv->active_method,
|
||||||
priv->active_add_borders, priv->active_gamma_mode,
|
priv->active_add_borders, priv->active_gamma_mode,
|
||||||
priv->active_primaries_mode, priv->active_sampling_method);
|
priv->active_primaries_mode, priv->sampling_method);
|
||||||
|
|
||||||
if (priv->active_method != GST_VIDEO_ORIENTATION_IDENTITY)
|
if (priv->active_method != GST_VIDEO_ORIENTATION_IDENTITY)
|
||||||
need_flip = TRUE;
|
need_flip = TRUE;
|
||||||
|
@ -1776,8 +1776,7 @@ gst_d3d12_convert_set_info (GstD3D12BaseFilter * filter,
|
||||||
GST_TYPE_VIDEO_PRIMARIES_MODE, priv->active_primaries_mode,
|
GST_TYPE_VIDEO_PRIMARIES_MODE, priv->active_primaries_mode,
|
||||||
GST_D3D12_CONVERTER_OPT_SAMPLER_FILTER,
|
GST_D3D12_CONVERTER_OPT_SAMPLER_FILTER,
|
||||||
GST_TYPE_D3D12_CONVERTER_SAMPLER_FILTER,
|
GST_TYPE_D3D12_CONVERTER_SAMPLER_FILTER,
|
||||||
gst_d3d12_sampling_method_to_native
|
gst_d3d12_sampling_method_to_native (priv->sampling_method), nullptr);
|
||||||
(priv->active_sampling_method), nullptr);
|
|
||||||
|
|
||||||
auto ctx = std::make_unique < ConvertContext > (filter->device);
|
auto ctx = std::make_unique < ConvertContext > (filter->device);
|
||||||
|
|
||||||
|
@ -1929,8 +1928,7 @@ gst_d3d12_convert_before_transform (GstBaseTransform * trans,
|
||||||
if (priv->selected_method != priv->active_method ||
|
if (priv->selected_method != priv->active_method ||
|
||||||
priv->add_borders != priv->active_add_borders ||
|
priv->add_borders != priv->active_add_borders ||
|
||||||
priv->gamma_mode != priv->active_gamma_mode ||
|
priv->gamma_mode != priv->active_gamma_mode ||
|
||||||
priv->primaries_mode != priv->active_primaries_mode ||
|
priv->primaries_mode != priv->active_primaries_mode) {
|
||||||
priv->sampling_method != priv->active_sampling_method) {
|
|
||||||
update = TRUE;
|
update = TRUE;
|
||||||
}
|
}
|
||||||
priv->lock.unlock ();
|
priv->lock.unlock ();
|
||||||
|
|
Loading…
Reference in a new issue