2020-04-12 03:27:46 +00:00
|
|
|
use bevy::{prelude::*};
|
2020-03-29 08:34:08 +00:00
|
|
|
|
|
|
|
fn main() {
|
2020-04-12 03:27:46 +00:00
|
|
|
App::build()
|
|
|
|
.add_default_plugins()
|
|
|
|
.setup(setup)
|
|
|
|
.run();
|
2020-03-29 08:34:08 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
#[derive(Uniforms, Default)]
|
|
|
|
struct MyMaterial {
|
|
|
|
pub color: Color,
|
|
|
|
}
|
|
|
|
|
|
|
|
fn add_shader_to_render_graph(resources: &mut Resources) {
|
|
|
|
let mut render_graph = resources.get_mut::<RenderGraph>().unwrap();
|
|
|
|
let mut pipelines = resources
|
|
|
|
.get_mut::<AssetStorage<PipelineDescriptor>>()
|
|
|
|
.unwrap();
|
|
|
|
let mut shaders = resources.get_mut::<AssetStorage<Shader>>().unwrap();
|
|
|
|
|
|
|
|
render_graph
|
|
|
|
.build(&mut pipelines, &mut shaders)
|
|
|
|
.add_resource_provider(UniformResourceProvider::<MyMaterial>::new(true))
|
|
|
|
.add_pipeline_to_pass(resource_name::pass::MAIN, "MyMaterial", |builder| {
|
|
|
|
builder
|
|
|
|
.with_vertex_shader(Shader::from_glsl(
|
|
|
|
ShaderStage::Vertex,
|
|
|
|
r#"
|
|
|
|
#version 450
|
|
|
|
layout(location = 0) in vec4 Vertex_Position;
|
|
|
|
layout(location = 0) out vec4 v_Position;
|
|
|
|
layout(set = 0, binding = 0) uniform Camera {
|
|
|
|
mat4 ViewProj;
|
|
|
|
};
|
|
|
|
layout(set = 1, binding = 0) uniform Object {
|
|
|
|
mat4 Model;
|
|
|
|
};
|
|
|
|
void main() {
|
|
|
|
v_Position = Model * Vertex_Position;
|
|
|
|
gl_Position = ViewProj * v_Position;
|
|
|
|
}
|
|
|
|
"#,
|
|
|
|
))
|
|
|
|
.with_fragment_shader(Shader::from_glsl(
|
|
|
|
ShaderStage::Fragment,
|
|
|
|
r#"
|
|
|
|
#version 450
|
|
|
|
layout(location = 0) in vec4 v_Position;
|
|
|
|
layout(location = 0) out vec4 o_Target;
|
|
|
|
layout(set = 1, binding = 1) uniform MyMaterial_color {
|
|
|
|
vec4 color;
|
|
|
|
};
|
|
|
|
void main() {
|
|
|
|
o_Target = color;
|
|
|
|
}
|
|
|
|
"#,
|
|
|
|
))
|
|
|
|
.with_default_config();
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
fn setup(world: &mut World, resources: &mut Resources) {
|
|
|
|
// add our shader to the render graph
|
|
|
|
add_shader_to_render_graph(resources);
|
|
|
|
|
|
|
|
// create materials
|
|
|
|
let mut material_storage = AssetStorage::<MyMaterial>::new();
|
2020-04-12 03:27:46 +00:00
|
|
|
let material = material_storage.add(MyMaterial {
|
2020-03-29 08:34:08 +00:00
|
|
|
color: Color::rgb(0.0, 0.8, 0.0),
|
|
|
|
});
|
|
|
|
|
|
|
|
resources.insert(material_storage);
|
|
|
|
|
|
|
|
// batch materials to improve performance
|
|
|
|
let mut asset_batchers = resources.get_mut::<AssetBatchers>().unwrap();
|
|
|
|
asset_batchers.batch_types2::<Mesh, MyMaterial>();
|
|
|
|
|
|
|
|
// get a handle to our newly created shader pipeline
|
|
|
|
let mut pipeline_storage = resources
|
|
|
|
.get_mut::<AssetStorage<PipelineDescriptor>>()
|
|
|
|
.unwrap();
|
|
|
|
let pipeline_handle = pipeline_storage.get_named("MyMaterial").unwrap();
|
|
|
|
|
|
|
|
let mut mesh_storage = resources.get_mut::<AssetStorage<Mesh>>().unwrap();
|
|
|
|
let cube_handle = mesh_storage.add(Mesh::load(MeshType::Cube));
|
|
|
|
|
|
|
|
world
|
|
|
|
.build()
|
|
|
|
// cube
|
|
|
|
.add_entity(MeshMaterialEntity::<MyMaterial> {
|
|
|
|
mesh: cube_handle,
|
|
|
|
renderable: Renderable {
|
|
|
|
pipelines: vec![pipeline_handle],
|
|
|
|
..Default::default()
|
|
|
|
},
|
2020-04-12 03:27:46 +00:00
|
|
|
material,
|
|
|
|
translation: Translation::new(0.0, 0.0, 0.0),
|
2020-03-29 08:34:08 +00:00
|
|
|
..Default::default()
|
|
|
|
})
|
|
|
|
// camera
|
|
|
|
.add_entity(CameraEntity {
|
|
|
|
local_to_world: LocalToWorld(Mat4::look_at_rh(
|
|
|
|
Vec3::new(3.0, 8.0, 5.0),
|
|
|
|
Vec3::new(0.0, 0.0, 0.0),
|
|
|
|
Vec3::new(0.0, 0.0, 1.0),
|
|
|
|
)),
|
|
|
|
..Default::default()
|
2020-04-07 20:25:01 +00:00
|
|
|
});
|
2020-03-29 08:34:08 +00:00
|
|
|
}
|