mirror of
https://github.com/bevyengine/bevy
synced 2024-11-26 14:40:19 +00:00
f8e0fc190a
# Objective Bevy users often want to create circles and other simple shapes. All the machinery is in place to accomplish this, and there are external crates that help. But when writing code for e.g. a new bevy example, it's not really possible to draw a circle without bringing in a new asset, writing a bunch of scary looking mesh code, or adding a dependency. In particular, this PR was inspired by this interaction in another PR: https://github.com/bevyengine/bevy/pull/3721#issuecomment-1016774535 ## Solution This PR adds `shape::RegularPolygon` and `shape::Circle` (which is just a `RegularPolygon` that defaults to a large number of sides) ## Discussion There's a lot of ongoing discussion about shapes in <https://github.com/bevyengine/rfcs/pull/12> and at least one other lingering shape PR (although it seems incomplete). That RFC currently includes `RegularPolygon` and `Circle` shapes, so I don't think that having working mesh generation code in the engine for those shapes would add much burden to an author of an implementation. But if we'd prefer not to add additional shapes until after that's sorted out, I'm happy to close this for now. ## Alternatives for users For any users stumbling on this issue, here are some plugins that will help if you need more shapes. https://github.com/Nilirad/bevy_prototype_lyon https://github.com/johanhelsing/bevy_smud https://github.com/Weasy666/bevy_svg https://github.com/redpandamonium/bevy_more_shapes https://github.com/ForesightMiningSoftwareCorporation/bevy_polyline
42 lines
1.2 KiB
Rust
42 lines
1.2 KiB
Rust
use bevy::{prelude::*, sprite::MaterialMesh2dBundle};
|
|
|
|
fn main() {
|
|
App::new()
|
|
.add_plugins(DefaultPlugins)
|
|
.add_startup_system(setup)
|
|
.run();
|
|
}
|
|
|
|
fn setup(
|
|
mut commands: Commands,
|
|
mut meshes: ResMut<Assets<Mesh>>,
|
|
mut materials: ResMut<Assets<ColorMaterial>>,
|
|
) {
|
|
commands.spawn_bundle(OrthographicCameraBundle::new_2d());
|
|
|
|
// Rectangle
|
|
commands.spawn_bundle(SpriteBundle {
|
|
sprite: Sprite {
|
|
color: Color::rgb(0.25, 0.25, 0.75),
|
|
custom_size: Some(Vec2::new(50.0, 100.0)),
|
|
..default()
|
|
},
|
|
..default()
|
|
});
|
|
|
|
// Circle
|
|
commands.spawn_bundle(MaterialMesh2dBundle {
|
|
mesh: meshes.add(shape::Circle::new(50.).into()).into(),
|
|
material: materials.add(ColorMaterial::from(Color::PURPLE)),
|
|
transform: Transform::from_translation(Vec3::new(-100., 0., 0.)),
|
|
..default()
|
|
});
|
|
|
|
// Hexagon
|
|
commands.spawn_bundle(MaterialMesh2dBundle {
|
|
mesh: meshes.add(shape::RegularPolygon::new(50., 6).into()).into(),
|
|
material: materials.add(ColorMaterial::from(Color::TURQUOISE)),
|
|
transform: Transform::from_translation(Vec3::new(100., 0., 0.)),
|
|
..default()
|
|
});
|
|
}
|