Struct glium::texture::texture2d::Texture2d
[−]
[src]
pub struct Texture2d(_);
A two-dimensional texture containing floating-point data.
Methods
impl Texture2d
[src]
fn sampled(&self) -> Sampler<Texture2d>
Builds a Sampler
marker object that allows you to indicate
how the texture should be sampled from inside a shader.
Example
let uniforms = uniform! { color_texture: texture.sampled().magnify_filter(glium::uniforms::MagnifySamplerFilter::Nearest) };
impl Texture2d
[src]
fn get_internal_format(&self) -> Result<InternalFormat, GetFormatError>
Determines the internal format of this texture.
The backend may not support querying the actual format, in which case an error is returned.
fn new<'a, F, T>(facade: &F, data: T) -> Result<Texture2d, TextureCreationError> where T: Texture2dDataSource<'a>, F: Facade
Builds a new texture by uploading data.
This function will automatically generate all mipmaps of the texture.
fn with_mipmaps<'a, F, T>(facade: &F, data: T, mipmaps: MipmapsOption) -> Result<Texture2d, TextureCreationError> where T: Texture2dDataSource<'a>, F: Facade
Builds a new texture by uploading data.
fn with_format<'a, F, T>(facade: &F, data: T, format: UncompressedFloatFormat, mipmaps: MipmapsOption) -> Result<Texture2d, TextureCreationError> where T: Texture2dDataSource<'a>, F: Facade
Builds a new texture with a specific format.
fn empty<F>(facade: &F, width: u32, height: u32) -> Result<Texture2d, TextureCreationError> where F: Facade
Creates an empty texture.
No mipmap level (except for the main level) will be allocated or generated.
The texture will contain undefined data.
fn empty_with_format<F>(facade: &F, format: UncompressedFloatFormat, mipmaps: MipmapsOption, width: u32, height: u32) -> Result<Texture2d, TextureCreationError> where F: Facade
Creates an empty texture with a specific format.
The texture (and its mipmaps) will contain undefined data.
fn empty_with_mipmaps<F>(facade: &F, mipmaps: MipmapsOption, width: u32, height: u32) -> Result<Texture2d, TextureCreationError> where F: Facade
Creates an empty texture. Specifies whether is has mipmaps.
The texture (and its mipmaps) will contain undefined data.
unsafe fn from_id<F: Facade>(facade: &F, format: UncompressedFloatFormat, id: GLuint, owned: bool, mipmap: MipmapsOption, ty: Dimensions) -> Texture2d
Builds a new texture reference from an existing, externally created OpenGL texture.
If owned
is true, this reference will take ownership of the texture and be responsible
for cleaning it up. Otherwise, the texture must be cleaned up externally, but only
after this reference's lifetime has ended.
fn width(&self) -> u32
Returns the width of that image.
fn height(&self) -> u32
Returns the height of that image.
fn dimensions(&self) -> (u32, u32)
Returns the width and height of that image.
fn as_surface<'a>(&'a self) -> SimpleFrameBuffer<'a>
Starts drawing on the texture.
All the function calls to the framebuffer will draw on the texture instead of the screen.
Low-level information
The first time that this function is called, a FrameBuffer Object will be
created and cached. The following calls to as_surface
will load the existing
FBO and re-use it. When the texture is destroyed, the FBO is destroyed too.
fn get_mipmap_levels(&self) -> u32
Returns the number of mipmap levels of the texture.
The minimum value is 1, since there is always a main texture.
fn read<T>(&self) -> T where T: Texture2dDataSink<(u8, u8, u8, u8)>
Reads the content of the texture to RAM.
You should avoid doing this at all cost during performance-critical
operations (for example, while you're drawing).
Use read_to_pixel_buffer
instead.
fn read_to_pixel_buffer(&self) -> PixelBuffer<(u8, u8, u8, u8)>
Reads the content of the texture into a buffer in video memory.
This operation copies the texture's data into a buffer in video memory
(a pixel buffer). Contrary to the read
function, this operation is
done asynchronously and doesn't need a synchronization.
fn write<'a, T>(&self, rect: Rect, data: T) where T: Texture2dDataSource<'a>
Uploads some data in the texture.
Note that this may cause a synchronization if you use the texture right before or right after this call. Prefer creating a whole new texture if you change a huge part of it.
Panic
Panics if the the dimensions of data
don't match the Rect
.
fn resident(self) -> Result<ResidentTexture, BindlessTexturesNotSupportedError>
Turns the texture into a ResidentTexture
.
This allows you to use the texture in a much more efficient way by storing a "reference to it" in a buffer (actually not a reference but a raw pointer).
See the documentation of ResidentTexture
for more infos.
fn mipmap(&self, level: u32) -> Option<Texture2dMipmap>
Access a single mipmap level of this texture.
fn main_level(&self) -> Texture2dMipmap
Access the main mipmap level of this texture.
Methods from Deref<Target=TextureAny>
fn get_width(&self) -> u32
Returns the width of the texture.
fn get_height(&self) -> Option<u32>
Returns the height of the texture.
fn get_depth(&self) -> Option<u32>
Returns the depth of the texture.
fn kind(&self) -> TextureKind
Returns the kind of texture.
fn dimensions(&self) -> Dimensions
Returns the dimensions of the texture.
fn get_array_size(&self) -> Option<u32>
Returns the array size of the texture.
fn get_samples(&self) -> Option<u32>
Returns the number of samples of the texture if it is a multisampling texture.
fn first_layer(&self) -> TextureAnyLayer
Returns a structure that represents the first layer of the texture. All textures have a first layer.
fn layer(&self, layer: u32) -> Option<TextureAnyLayer>
Returns a structure that represents a specific layer of the texture.
Non-array textures have only one layer. The number of layers can be queried with
get_array_size
.
Returns None
if out of range.
fn get_texture_type(&self) -> Dimensions
Returns the type of the texture (1D, 2D, 3D, etc.).
fn get_internal_format(&self) -> Result<InternalFormat, GetFormatError>
Determines the internal format of this texture.
fn get_mipmap_levels(&self) -> u32
Returns the number of mipmap levels of the texture.
fn main_level(&self) -> TextureAnyMipmap
Returns a structure that represents the main mipmap level of the texture.
fn mipmap(&self, level: u32) -> Option<TextureAnyMipmap>
Returns a structure that represents a specific mipmap of the texture.
Returns None
if out of range.
unsafe fn generate_mipmaps(&self)
Binds this texture and generates mipmaps.
Trait Implementations
impl GlObject for Texture2d
[src]
type Id = GLuint
The type of identifier for this object.
fn get_id(&self) -> GLuint
Returns the id of the object.
impl Debug for Texture2d
[src]
impl Deref for Texture2d
[src]
type Target = TextureAny
The resulting type after dereferencing
fn deref<'a>(&'a self) -> &'a TextureAny
The method called to dereference a value
impl<'a> AsUniformValue for &'a Texture2d
[src]
fn as_uniform_value(&self) -> UniformValue
Builds a UniformValue
.
impl<'t> ToColorAttachment<'t> for &'t Texture2d
[src]
fn to_color_attachment(self) -> ColorAttachment<'t>
Builds the ColorAttachment
.