cogl-primitives: Ensure the mipmaps for a layer before logging quads

With the atlas texture backend ensuring the mipmaps can make it become
a completely different texture which will have different texture
coordinates or may even be sliced. Therefore we need to ensure the
mipmaps before deciding which quads to log in the journal. This adds a
new private function to cogl-material which ensures the mipmaps if
needed.
This commit is contained in:
Neil Roberts 2010-01-14 17:57:43 +00:00
parent ae7825275e
commit 12b45aaa30
3 changed files with 27 additions and 4 deletions

View File

@ -204,6 +204,12 @@ typedef enum _CoglMaterialLayerFlags
*/ */
gulong _cogl_material_layer_get_flags (CoglHandle layer_handle); gulong _cogl_material_layer_get_flags (CoglHandle layer_handle);
/*
* Ensures the mipmaps are available for the texture in the layer if
* the filter settings would require it
*/
void _cogl_material_layer_ensure_mipmaps (CoglHandle layer_handler);
/* /*
* CoglMaterialFlushFlag: * CoglMaterialFlushFlag:
* @COGL_MATERIAL_FLUSH_FALLBACK_MASK: The fallback_layers member is set to * @COGL_MATERIAL_FLUSH_FALLBACK_MASK: The fallback_layers member is set to

View File

@ -1326,6 +1326,19 @@ _cogl_material_layer_flush_gl_sampler_state (CoglMaterialLayer *layer,
_cogl_matrix_stack_flush_to_gl (unit->matrix_stack, COGL_MATRIX_TEXTURE); _cogl_matrix_stack_flush_to_gl (unit->matrix_stack, COGL_MATRIX_TEXTURE);
} }
void
_cogl_material_layer_ensure_mipmaps (CoglHandle layer_handle)
{
CoglMaterialLayer *layer;
layer = _cogl_material_layer_pointer_from_handle (layer_handle);
if (layer->texture &&
(is_mipmap_filter (layer->min_filter) ||
is_mipmap_filter (layer->mag_filter)))
_cogl_texture_ensure_mipmaps (layer->texture);
}
/* /*
* _cogl_material_flush_layers_gl_state: * _cogl_material_flush_layers_gl_state:
* @fallback_mask: is a bitmask of the material layers that need to be * @fallback_mask: is a bitmask of the material layers that need to be
@ -1397,6 +1410,8 @@ _cogl_material_flush_layers_gl_state (CoglMaterial *material,
#endif #endif
CoglTextureUnit *unit; CoglTextureUnit *unit;
_cogl_material_layer_ensure_mipmaps (layer_handle);
new_gl_layer_info.layer0_overridden = new_gl_layer_info.layer0_overridden =
layer0_override_texture ? TRUE : FALSE; layer0_override_texture ? TRUE : FALSE;
new_gl_layer_info.fallback = new_gl_layer_info.fallback =
@ -1407,10 +1422,6 @@ _cogl_material_flush_layers_gl_state (CoglMaterial *material,
tex_handle = layer->texture; tex_handle = layer->texture;
if (tex_handle != COGL_INVALID_HANDLE) if (tex_handle != COGL_INVALID_HANDLE)
{ {
if (is_mipmap_filter (layer->min_filter)
|| is_mipmap_filter (layer->mag_filter))
_cogl_texture_ensure_mipmaps (tex_handle);
_cogl_texture_set_filters (tex_handle, _cogl_texture_set_filters (tex_handle,
layer->min_filter, layer->min_filter,
layer->mag_filter); layer->mag_filter);

View File

@ -401,6 +401,12 @@ _cogl_rectangles_with_multitexture_coords (
!= COGL_MATERIAL_LAYER_TYPE_TEXTURE) != COGL_MATERIAL_LAYER_TYPE_TEXTURE)
continue; continue;
/* We need to ensure the mipmaps are ready before deciding
anything else about the texture because it could become
something completely different if it needs to be migrated out
of the atlas */
_cogl_material_layer_ensure_mipmaps (layer);
tex_handle = cogl_material_layer_get_texture (layer); tex_handle = cogl_material_layer_get_texture (layer);
/* COGL_INVALID_HANDLE textures are handled by /* COGL_INVALID_HANDLE textures are handled by