diff options
Diffstat (limited to 'servers/rendering_server.cpp')
-rw-r--r-- | servers/rendering_server.cpp | 21 |
1 files changed, 12 insertions, 9 deletions
diff --git a/servers/rendering_server.cpp b/servers/rendering_server.cpp index 0c5c263265..4a95dc1963 100644 --- a/servers/rendering_server.cpp +++ b/servers/rendering_server.cpp @@ -402,9 +402,9 @@ Error RenderingServer::_surface_set_data(Array p_arrays, uint32_t p_format, uint const Vector3 *src = array.ptr(); for (int i = 0; i < p_vertex_array_len; i++) { Vector2 res = src[i].octahedron_encode(); - int16_t vector[2] = { - (int16_t)CLAMP(res.x * 65535, 0, 65535), - (int16_t)CLAMP(res.y * 65535, 0, 65535), + uint16_t vector[2] = { + (uint16_t)CLAMP(res.x * 65535, 0, 65535), + (uint16_t)CLAMP(res.y * 65535, 0, 65535), }; memcpy(&vw[p_offsets[ai] + i * p_vertex_stride], vector, 4); @@ -422,9 +422,9 @@ Error RenderingServer::_surface_set_data(Array p_arrays, uint32_t p_format, uint for (int i = 0; i < p_vertex_array_len; i++) { const Vector3 src(src_ptr[i * 4 + 0], src_ptr[i * 4 + 1], src_ptr[i * 4 + 2]); Vector2 res = src.octahedron_tangent_encode(src_ptr[i * 4 + 3]); - int16_t vector[2] = { - (int16_t)CLAMP(res.x * 65535, 0, 65535), - (int16_t)CLAMP(res.y * 65535, 0, 65535), + uint16_t vector[2] = { + (uint16_t)CLAMP(res.x * 65535, 0, 65535), + (uint16_t)CLAMP(res.y * 65535, 0, 65535), }; memcpy(&vw[p_offsets[ai] + i * p_vertex_stride], vector, 4); @@ -437,9 +437,9 @@ Error RenderingServer::_surface_set_data(Array p_arrays, uint32_t p_format, uint for (int i = 0; i < p_vertex_array_len; i++) { const Vector3 src(src_ptr[i * 4 + 0], src_ptr[i * 4 + 1], src_ptr[i * 4 + 2]); Vector2 res = src.octahedron_tangent_encode(src_ptr[i * 4 + 3]); - int16_t vector[2] = { - (int16_t)CLAMP(res.x * 65535, 0, 65535), - (int16_t)CLAMP(res.y * 65535, 0, 65535), + uint16_t vector[2] = { + (uint16_t)CLAMP(res.x * 65535, 0, 65535), + (uint16_t)CLAMP(res.y * 65535, 0, 65535), }; memcpy(&vw[p_offsets[ai] + i * p_vertex_stride], vector, 4); @@ -1697,7 +1697,10 @@ void RenderingServer::_bind_methods() { ClassDB::bind_method(D_METHOD("texture_set_path", "texture", "path"), &RenderingServer::texture_set_path); ClassDB::bind_method(D_METHOD("texture_get_path", "texture"), &RenderingServer::texture_get_path); + ClassDB::bind_method(D_METHOD("texture_get_format", "texture"), &RenderingServer::texture_get_format); + ClassDB::bind_method(D_METHOD("texture_set_force_redraw_if_visible", "texture", "enable"), &RenderingServer::texture_set_force_redraw_if_visible); + ClassDB::bind_method(D_METHOD("texture_rd_create", "rd_texture", "layer_type"), &RenderingServer::texture_rd_create, DEFVAL(RenderingServer::TEXTURE_LAYERED_2D_ARRAY)); ClassDB::bind_method(D_METHOD("texture_get_rd_texture", "texture", "srgb"), &RenderingServer::texture_get_rd_texture, DEFVAL(false)); ClassDB::bind_method(D_METHOD("texture_get_native_handle", "texture", "srgb"), &RenderingServer::texture_get_native_handle, DEFVAL(false)); |