pub struct TextureAtlasBuilder<'a> { /* private fields */ }
Expand description
A builder which is used to create a texture atlas from many individual sprites.
Implementations§
Source§impl<'a> TextureAtlasBuilder<'a>
impl<'a> TextureAtlasBuilder<'a>
Sourcepub fn initial_size(&mut self, size: UVec2) -> &mut TextureAtlasBuilder<'a>
pub fn initial_size(&mut self, size: UVec2) -> &mut TextureAtlasBuilder<'a>
Sets the initial size of the atlas in pixels.
Sourcepub fn max_size(&mut self, size: UVec2) -> &mut TextureAtlasBuilder<'a>
pub fn max_size(&mut self, size: UVec2) -> &mut TextureAtlasBuilder<'a>
Sets the max size of the atlas in pixels.
Sourcepub fn format(&mut self, format: TextureFormat) -> &mut TextureAtlasBuilder<'a>
pub fn format(&mut self, format: TextureFormat) -> &mut TextureAtlasBuilder<'a>
Sets the texture format for textures in the atlas.
Sourcepub fn auto_format_conversion(
&mut self,
auto_format_conversion: bool,
) -> &mut TextureAtlasBuilder<'a>
pub fn auto_format_conversion( &mut self, auto_format_conversion: bool, ) -> &mut TextureAtlasBuilder<'a>
Control whether the added texture should be converted to the atlas format, if different.
Sourcepub fn add_texture(
&mut self,
image_id: Option<AssetId<Image>>,
texture: &'a Image,
) -> &mut TextureAtlasBuilder<'a>
pub fn add_texture( &mut self, image_id: Option<AssetId<Image>>, texture: &'a Image, ) -> &mut TextureAtlasBuilder<'a>
Adds a texture to be copied to the texture atlas.
Optionally an asset id can be passed that can later be used with the texture layout to retrieve the index of this texture. The insertion order will reflect the index of the added texture in the finished texture atlas.
Examples found in repository?
217fn create_texture_atlas(
218 folder: &LoadedFolder,
219 padding: Option<UVec2>,
220 sampling: Option<ImageSampler>,
221 textures: &mut ResMut<Assets<Image>>,
222) -> (TextureAtlasLayout, TextureAtlasSources, Handle<Image>) {
223 // Build a texture atlas using the individual sprites
224 let mut texture_atlas_builder = TextureAtlasBuilder::default();
225 texture_atlas_builder.padding(padding.unwrap_or_default());
226 for handle in folder.handles.iter() {
227 let id = handle.id().typed_unchecked::<Image>();
228 let Some(texture) = textures.get(id) else {
229 warn!(
230 "{} did not resolve to an `Image` asset.",
231 handle.path().unwrap()
232 );
233 continue;
234 };
235
236 texture_atlas_builder.add_texture(Some(id), texture);
237 }
238
239 let (texture_atlas_layout, texture_atlas_sources, texture) =
240 texture_atlas_builder.build().unwrap();
241 let texture = textures.add(texture);
242
243 // Update the sampling settings of the texture atlas
244 let image = textures.get_mut(&texture).unwrap();
245 image.sampler = sampling.unwrap_or_default();
246
247 (texture_atlas_layout, texture_atlas_sources, texture)
248}
Sourcepub fn padding(&mut self, padding: UVec2) -> &mut TextureAtlasBuilder<'a>
pub fn padding(&mut self, padding: UVec2) -> &mut TextureAtlasBuilder<'a>
Sets the amount of padding in pixels to add between the textures in the texture atlas.
The x
value provide will be added to the right edge, while the y
value will be added to the bottom edge.
Examples found in repository?
217fn create_texture_atlas(
218 folder: &LoadedFolder,
219 padding: Option<UVec2>,
220 sampling: Option<ImageSampler>,
221 textures: &mut ResMut<Assets<Image>>,
222) -> (TextureAtlasLayout, TextureAtlasSources, Handle<Image>) {
223 // Build a texture atlas using the individual sprites
224 let mut texture_atlas_builder = TextureAtlasBuilder::default();
225 texture_atlas_builder.padding(padding.unwrap_or_default());
226 for handle in folder.handles.iter() {
227 let id = handle.id().typed_unchecked::<Image>();
228 let Some(texture) = textures.get(id) else {
229 warn!(
230 "{} did not resolve to an `Image` asset.",
231 handle.path().unwrap()
232 );
233 continue;
234 };
235
236 texture_atlas_builder.add_texture(Some(id), texture);
237 }
238
239 let (texture_atlas_layout, texture_atlas_sources, texture) =
240 texture_atlas_builder.build().unwrap();
241 let texture = textures.add(texture);
242
243 // Update the sampling settings of the texture atlas
244 let image = textures.get_mut(&texture).unwrap();
245 image.sampler = sampling.unwrap_or_default();
246
247 (texture_atlas_layout, texture_atlas_sources, texture)
248}
Sourcepub fn build(
&mut self,
) -> Result<(TextureAtlasLayout, TextureAtlasSources, Image), TextureAtlasBuilderError>
pub fn build( &mut self, ) -> Result<(TextureAtlasLayout, TextureAtlasSources, Image), TextureAtlasBuilderError>
Consumes the builder, and returns the newly created texture atlas and the associated atlas layout.
Assigns indices to the textures based on the insertion order. Internally it copies all rectangles from the textures and copies them into a new texture.
§Usage
fn my_system(mut textures: ResMut<Assets<Image>>, mut layouts: ResMut<Assets<TextureAtlasLayout>>) {
// Declare your builder
let mut builder = TextureAtlasBuilder::default();
// Customize it
// ...
// Build your texture and the atlas layout
let (atlas_layout, atlas_sources, texture) = builder.build().unwrap();
let texture = textures.add(texture);
let layout = layouts.add(atlas_layout);
}
§Errors
If there is not enough space in the atlas texture, an error will be returned. It is then recommended to make a larger sprite sheet.
Examples found in repository?
217fn create_texture_atlas(
218 folder: &LoadedFolder,
219 padding: Option<UVec2>,
220 sampling: Option<ImageSampler>,
221 textures: &mut ResMut<Assets<Image>>,
222) -> (TextureAtlasLayout, TextureAtlasSources, Handle<Image>) {
223 // Build a texture atlas using the individual sprites
224 let mut texture_atlas_builder = TextureAtlasBuilder::default();
225 texture_atlas_builder.padding(padding.unwrap_or_default());
226 for handle in folder.handles.iter() {
227 let id = handle.id().typed_unchecked::<Image>();
228 let Some(texture) = textures.get(id) else {
229 warn!(
230 "{} did not resolve to an `Image` asset.",
231 handle.path().unwrap()
232 );
233 continue;
234 };
235
236 texture_atlas_builder.add_texture(Some(id), texture);
237 }
238
239 let (texture_atlas_layout, texture_atlas_sources, texture) =
240 texture_atlas_builder.build().unwrap();
241 let texture = textures.add(texture);
242
243 // Update the sampling settings of the texture atlas
244 let image = textures.get_mut(&texture).unwrap();
245 image.sampler = sampling.unwrap_or_default();
246
247 (texture_atlas_layout, texture_atlas_sources, texture)
248}
Trait Implementations§
Source§impl<'a> Debug for TextureAtlasBuilder<'a>
impl<'a> Debug for TextureAtlasBuilder<'a>
Source§impl Default for TextureAtlasBuilder<'_>
impl Default for TextureAtlasBuilder<'_>
Source§fn default() -> TextureAtlasBuilder<'_>
fn default() -> TextureAtlasBuilder<'_>
Auto Trait Implementations§
impl<'a> Freeze for TextureAtlasBuilder<'a>
impl<'a> RefUnwindSafe for TextureAtlasBuilder<'a>
impl<'a> Send for TextureAtlasBuilder<'a>
impl<'a> Sync for TextureAtlasBuilder<'a>
impl<'a> Unpin for TextureAtlasBuilder<'a>
impl<'a> UnwindSafe for TextureAtlasBuilder<'a>
Blanket Implementations§
Source§impl<T, U> AsBindGroupShaderType<U> for T
impl<T, U> AsBindGroupShaderType<U> for T
Source§fn as_bind_group_shader_type(&self, _images: &RenderAssets<GpuImage>) -> U
fn as_bind_group_shader_type(&self, _images: &RenderAssets<GpuImage>) -> U
T
ShaderType
for self
. When used in AsBindGroup
derives, it is safe to assume that all images in self
exist.Source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
Source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Source§impl<T> Downcast for Twhere
T: Any,
impl<T> Downcast for Twhere
T: Any,
Source§fn into_any(self: Box<T>) -> Box<dyn Any>
fn into_any(self: Box<T>) -> Box<dyn Any>
Box<dyn Trait>
(where Trait: Downcast
) to Box<dyn Any>
, which can then be
downcast
into Box<dyn ConcreteType>
where ConcreteType
implements Trait
.Source§fn into_any_rc(self: Rc<T>) -> Rc<dyn Any>
fn into_any_rc(self: Rc<T>) -> Rc<dyn Any>
Rc<Trait>
(where Trait: Downcast
) to Rc<Any>
, which can then be further
downcast
into Rc<ConcreteType>
where ConcreteType
implements Trait
.Source§fn as_any(&self) -> &(dyn Any + 'static)
fn as_any(&self) -> &(dyn Any + 'static)
&Trait
(where Trait: Downcast
) to &Any
. This is needed since Rust cannot
generate &Any
’s vtable from &Trait
’s.Source§fn as_any_mut(&mut self) -> &mut (dyn Any + 'static)
fn as_any_mut(&mut self) -> &mut (dyn Any + 'static)
&mut Trait
(where Trait: Downcast
) to &Any
. This is needed since Rust cannot
generate &mut Any
’s vtable from &mut Trait
’s.Source§impl<T> Downcast for Twhere
T: Any,
impl<T> Downcast for Twhere
T: Any,
Source§fn into_any(self: Box<T>) -> Box<dyn Any>
fn into_any(self: Box<T>) -> Box<dyn Any>
Box<dyn Trait>
(where Trait: Downcast
) to Box<dyn Any>
. Box<dyn Any>
can
then be further downcast
into Box<ConcreteType>
where ConcreteType
implements Trait
.Source§fn into_any_rc(self: Rc<T>) -> Rc<dyn Any>
fn into_any_rc(self: Rc<T>) -> Rc<dyn Any>
Rc<Trait>
(where Trait: Downcast
) to Rc<Any>
. Rc<Any>
can then be
further downcast
into Rc<ConcreteType>
where ConcreteType
implements Trait
.Source§fn as_any(&self) -> &(dyn Any + 'static)
fn as_any(&self) -> &(dyn Any + 'static)
&Trait
(where Trait: Downcast
) to &Any
. This is needed since Rust cannot
generate &Any
’s vtable from &Trait
’s.Source§fn as_any_mut(&mut self) -> &mut (dyn Any + 'static)
fn as_any_mut(&mut self) -> &mut (dyn Any + 'static)
&mut Trait
(where Trait: Downcast
) to &Any
. This is needed since Rust cannot
generate &mut Any
’s vtable from &mut Trait
’s.Source§impl<T> DowncastSend for T
impl<T> DowncastSend for T
Source§impl<T> DowncastSync for T
impl<T> DowncastSync for T
Source§impl<T> FmtForward for T
impl<T> FmtForward for T
Source§fn fmt_binary(self) -> FmtBinary<Self>where
Self: Binary,
fn fmt_binary(self) -> FmtBinary<Self>where
Self: Binary,
self
to use its Binary
implementation when Debug
-formatted.Source§fn fmt_display(self) -> FmtDisplay<Self>where
Self: Display,
fn fmt_display(self) -> FmtDisplay<Self>where
Self: Display,
self
to use its Display
implementation when
Debug
-formatted.Source§fn fmt_lower_exp(self) -> FmtLowerExp<Self>where
Self: LowerExp,
fn fmt_lower_exp(self) -> FmtLowerExp<Self>where
Self: LowerExp,
self
to use its LowerExp
implementation when
Debug
-formatted.Source§fn fmt_lower_hex(self) -> FmtLowerHex<Self>where
Self: LowerHex,
fn fmt_lower_hex(self) -> FmtLowerHex<Self>where
Self: LowerHex,
self
to use its LowerHex
implementation when
Debug
-formatted.Source§fn fmt_octal(self) -> FmtOctal<Self>where
Self: Octal,
fn fmt_octal(self) -> FmtOctal<Self>where
Self: Octal,
self
to use its Octal
implementation when Debug
-formatted.Source§fn fmt_pointer(self) -> FmtPointer<Self>where
Self: Pointer,
fn fmt_pointer(self) -> FmtPointer<Self>where
Self: Pointer,
self
to use its Pointer
implementation when
Debug
-formatted.Source§fn fmt_upper_exp(self) -> FmtUpperExp<Self>where
Self: UpperExp,
fn fmt_upper_exp(self) -> FmtUpperExp<Self>where
Self: UpperExp,
self
to use its UpperExp
implementation when
Debug
-formatted.Source§fn fmt_upper_hex(self) -> FmtUpperHex<Self>where
Self: UpperHex,
fn fmt_upper_hex(self) -> FmtUpperHex<Self>where
Self: UpperHex,
self
to use its UpperHex
implementation when
Debug
-formatted.Source§impl<S> FromSample<S> for S
impl<S> FromSample<S> for S
fn from_sample_(s: S) -> S
Source§impl<T> FromWorld for Twhere
T: Default,
impl<T> FromWorld for Twhere
T: Default,
Source§fn from_world(_world: &mut World) -> T
fn from_world(_world: &mut World) -> T
Creates Self
using default()
.
Source§impl<T> Instrument for T
impl<T> Instrument for T
Source§fn instrument(self, span: Span) -> Instrumented<Self> ⓘ
fn instrument(self, span: Span) -> Instrumented<Self> ⓘ
Source§fn in_current_span(self) -> Instrumented<Self> ⓘ
fn in_current_span(self) -> Instrumented<Self> ⓘ
Source§impl<T> IntoEither for T
impl<T> IntoEither for T
Source§fn into_either(self, into_left: bool) -> Either<Self, Self> ⓘ
fn into_either(self, into_left: bool) -> Either<Self, Self> ⓘ
self
into a Left
variant of Either<Self, Self>
if into_left
is true
.
Converts self
into a Right
variant of Either<Self, Self>
otherwise. Read moreSource§fn into_either_with<F>(self, into_left: F) -> Either<Self, Self> ⓘ
fn into_either_with<F>(self, into_left: F) -> Either<Self, Self> ⓘ
self
into a Left
variant of Either<Self, Self>
if into_left(&self)
returns true
.
Converts self
into a Right
variant of Either<Self, Self>
otherwise. Read moreSource§impl<F, T> IntoSample<T> for Fwhere
T: FromSample<F>,
impl<F, T> IntoSample<T> for Fwhere
T: FromSample<F>,
fn into_sample(self) -> T
Source§impl<T> Pipe for Twhere
T: ?Sized,
impl<T> Pipe for Twhere
T: ?Sized,
Source§fn pipe<R>(self, func: impl FnOnce(Self) -> R) -> Rwhere
Self: Sized,
fn pipe<R>(self, func: impl FnOnce(Self) -> R) -> Rwhere
Self: Sized,
Source§fn pipe_ref<'a, R>(&'a self, func: impl FnOnce(&'a Self) -> R) -> Rwhere
R: 'a,
fn pipe_ref<'a, R>(&'a self, func: impl FnOnce(&'a Self) -> R) -> Rwhere
R: 'a,
self
and passes that borrow into the pipe function. Read moreSource§fn pipe_ref_mut<'a, R>(&'a mut self, func: impl FnOnce(&'a mut Self) -> R) -> Rwhere
R: 'a,
fn pipe_ref_mut<'a, R>(&'a mut self, func: impl FnOnce(&'a mut Self) -> R) -> Rwhere
R: 'a,
self
and passes that borrow into the pipe function. Read moreSource§fn pipe_borrow<'a, B, R>(&'a self, func: impl FnOnce(&'a B) -> R) -> R
fn pipe_borrow<'a, B, R>(&'a self, func: impl FnOnce(&'a B) -> R) -> R
Source§fn pipe_borrow_mut<'a, B, R>(
&'a mut self,
func: impl FnOnce(&'a mut B) -> R,
) -> R
fn pipe_borrow_mut<'a, B, R>( &'a mut self, func: impl FnOnce(&'a mut B) -> R, ) -> R
Source§fn pipe_as_ref<'a, U, R>(&'a self, func: impl FnOnce(&'a U) -> R) -> R
fn pipe_as_ref<'a, U, R>(&'a self, func: impl FnOnce(&'a U) -> R) -> R
self
, then passes self.as_ref()
into the pipe function.Source§fn pipe_as_mut<'a, U, R>(&'a mut self, func: impl FnOnce(&'a mut U) -> R) -> R
fn pipe_as_mut<'a, U, R>(&'a mut self, func: impl FnOnce(&'a mut U) -> R) -> R
self
, then passes self.as_mut()
into the pipe
function.Source§fn pipe_deref<'a, T, R>(&'a self, func: impl FnOnce(&'a T) -> R) -> R
fn pipe_deref<'a, T, R>(&'a self, func: impl FnOnce(&'a T) -> R) -> R
self
, then passes self.deref()
into the pipe function.Source§impl<T> Pointable for T
impl<T> Pointable for T
Source§impl<R, P> ReadPrimitive<R> for P
impl<R, P> ReadPrimitive<R> for P
Source§fn read_from_little_endian(read: &mut R) -> Result<Self, Error>
fn read_from_little_endian(read: &mut R) -> Result<Self, Error>
ReadEndian::read_from_little_endian()
.Source§impl<T> Tap for T
impl<T> Tap for T
Source§fn tap_borrow<B>(self, func: impl FnOnce(&B)) -> Self
fn tap_borrow<B>(self, func: impl FnOnce(&B)) -> Self
Borrow<B>
of a value. Read moreSource§fn tap_borrow_mut<B>(self, func: impl FnOnce(&mut B)) -> Self
fn tap_borrow_mut<B>(self, func: impl FnOnce(&mut B)) -> Self
BorrowMut<B>
of a value. Read moreSource§fn tap_ref<R>(self, func: impl FnOnce(&R)) -> Self
fn tap_ref<R>(self, func: impl FnOnce(&R)) -> Self
AsRef<R>
view of a value. Read moreSource§fn tap_ref_mut<R>(self, func: impl FnOnce(&mut R)) -> Self
fn tap_ref_mut<R>(self, func: impl FnOnce(&mut R)) -> Self
AsMut<R>
view of a value. Read moreSource§fn tap_deref<T>(self, func: impl FnOnce(&T)) -> Self
fn tap_deref<T>(self, func: impl FnOnce(&T)) -> Self
Deref::Target
of a value. Read moreSource§fn tap_deref_mut<T>(self, func: impl FnOnce(&mut T)) -> Self
fn tap_deref_mut<T>(self, func: impl FnOnce(&mut T)) -> Self
Deref::Target
of a value. Read moreSource§fn tap_dbg(self, func: impl FnOnce(&Self)) -> Self
fn tap_dbg(self, func: impl FnOnce(&Self)) -> Self
.tap()
only in debug builds, and is erased in release builds.Source§fn tap_mut_dbg(self, func: impl FnOnce(&mut Self)) -> Self
fn tap_mut_dbg(self, func: impl FnOnce(&mut Self)) -> Self
.tap_mut()
only in debug builds, and is erased in release
builds.Source§fn tap_borrow_dbg<B>(self, func: impl FnOnce(&B)) -> Self
fn tap_borrow_dbg<B>(self, func: impl FnOnce(&B)) -> Self
.tap_borrow()
only in debug builds, and is erased in release
builds.Source§fn tap_borrow_mut_dbg<B>(self, func: impl FnOnce(&mut B)) -> Self
fn tap_borrow_mut_dbg<B>(self, func: impl FnOnce(&mut B)) -> Self
.tap_borrow_mut()
only in debug builds, and is erased in release
builds.Source§fn tap_ref_dbg<R>(self, func: impl FnOnce(&R)) -> Self
fn tap_ref_dbg<R>(self, func: impl FnOnce(&R)) -> Self
.tap_ref()
only in debug builds, and is erased in release
builds.Source§fn tap_ref_mut_dbg<R>(self, func: impl FnOnce(&mut R)) -> Self
fn tap_ref_mut_dbg<R>(self, func: impl FnOnce(&mut R)) -> Self
.tap_ref_mut()
only in debug builds, and is erased in release
builds.Source§fn tap_deref_dbg<T>(self, func: impl FnOnce(&T)) -> Self
fn tap_deref_dbg<T>(self, func: impl FnOnce(&T)) -> Self
.tap_deref()
only in debug builds, and is erased in release
builds.