Skip to content

Commit 2ec44a1

Browse files
committed
Update dependencies & readme
1 parent 76dd29b commit 2ec44a1

13 files changed

+45
-27
lines changed

Cargo.lock

+8
Some generated files are not rendered by default. Learn more about customizing how changed files appear on GitHub.

Cargo.toml

+4-4
Original file line numberDiff line numberDiff line change
@@ -9,15 +9,15 @@ nalgebra = { version = "0.33.0", features = [
99
"convert-glam028",
1010
"convert-glam027",
1111
] }
12-
prism = { path = "../prism" }
12+
prism = { git = "https://github.com/entropylost/prism" }
1313
color-eyre = "0.6.2"
14-
sefirot = { path = "../sefirot/sefirot", features = [
14+
sefirot = { git = "https://github.com/entropylost/sefirot", features = [
1515
"bevy",
1616
"glam",
1717
"nalgebra",
1818
] }
19-
sefirot_grid = { path = "../sefirot/sefirot_grid" }
20-
bevy_sefirot = { path = "../sefirot/bevy_sefirot" }
19+
sefirot_grid = { git = "https://github.com/entropylost/sefirot" }
20+
bevy_sefirot = { git = "https://github.com/entropylost/sefirot" }
2121
bevy_egui = "0.29.0"
2222
egui = "0.28.1"
2323
bevy_flycam = "0.14.1"

README.md

+13-8
Original file line numberDiff line numberDiff line change
@@ -12,23 +12,28 @@ Install [Rust](https://www.rust-lang.org/tools/install), clone this repository,
1212

1313
To launch the program, execute `cargo r --release scenes/glassbreak-3.scene`. When running, the keys `WASD[Space][Shift]` can be used to move the camera, and the mouse will rotate the camera, togglable via `[Esc]`. The key `\` will toggle the controls display, and `[Enter]` will run/pause the simulation.
1414

15-
The files use the [rusty object notation](https://github.com/ron-rs/ron) (ron) serialization format, with the `.scene` extension used to describe loadable scenes, and `.pts` to describe sets of points which can be referenced by objects in the scene files. The parameters used for the objects and constants can be seen in [`src/data.rs`](src/data.rs), as well as the default values.
15+
The files use the [Rusty Object Notation](https://github.com/ron-rs/ron) (RON) serialization format, with files ending in the `.scene` extension used to describe loadable scenes, and `.pts` to describe sets of points which can be referenced by objects in the scenes. The parameters used for the objects and constants can be seen in [`src/data.rs`](src/data.rs), as well as the default values. [`src/bin/generate.rs`](src/bin/generate.rs) also shows an example program that can be used to generate a `.pts` file.
1616

1717
## Gallery
1818

1919

2020
<table align="center">
2121
<tr>
22-
<td align="center"><img src="images/glassbreak-3-fracture.png" alt="Glassbreak 3 Fracture Pattern"></td>
23-
<td align="center"><img src="images/glassbreak-large-front.png" alt="Glassbreak Large Front Fracture>"></td>
24-
<td align="center"><img src="images/glassbreak-large-back.png" alt="Glassbreak Large Back Fracture>"></td>
22+
<td align="center"><img src="images/glassbreak-3-anim.gif" alt="Glassbreak 3 Fracture Pattern"><a href="scenes/glassbreak-3.scene"><code>glassbreak-3</code></a> (see <a href="images/glassbreak-3-fracture.png">still</a>)</td>
23+
<td align="center"><img src="images/rigid-collide-4-side.png" alt="Rigid Collide 4 Side View"><a href="scenes/rigid-collide-4.scene"><code>rigid-collide-4</code></a> (side)</td>
24+
<td align="center"><a href="images/glassbreak-large-front.png"><img src="images/glassbreak-large-front-50.png" alt="Glassbreak Large Front Fracture (downscaled)"></a><a href="scenes/glassbreak-large.scene"><code>glassbreak-large</code></a> (front)</td>
2525
</tr>
2626
<tr>
27-
<td align="center"><img src="images/rigid-collide-4-side.png" alt="Rigid Collide 4 Side View"></td>
28-
<td align="center"><img src="images/glassbreak-traced.png" alt="Rendered glassbreak"></td>
29-
<td align="center"><img src="images/tablebreak-cone.png" alt="Hertzian cone display"></td>
27+
<td align="center"><img src="images/prism-front.png" alt="Prism Front View"><a href="scenes/prism.scene">The Illumaniti</a></td>
28+
<td align="center"><img src="images/rigid-collide-4-front.png" alt="Rigid Collide 4 Front View"><a href="scenes/rigid-collide-4.scene"><code>rigid-collide-4</code></a> (front)</td>
29+
<td align="center"><img src="images/glassbreak-large-back.png" alt="Glassbreak Large Back Fracture"><a href="scenes/glassbreak-large.scene"><code>glassbreak-large</code></a> (back)</td>
3030
</tr>
3131
<tr>
32-
<td colspan="3" align="center"><img src="images/banner-pattern.png" alt="Wide glassbreak pattern"></td>
32+
<td align="center"><img src="images/glassbreak-traced.png" alt="Rendered glassbreak"><a href="scenes/glassbreak-3.scene"><code>glassbreak-3</code></a> using <a href="https://github.com/entropylost/morningstar/tree/render">the alternate renderer</a></td>
33+
<td align="center"><img src="images/tablecrush-cone.png" alt="Tablecrush Hertzian cone"><a href="scenes/tablecrush.scene"><code>tablecrush</code></a> making a Hertzian cone</td>
34+
<td align="center"><a href="images/collide-200x60x60.png"><img src="images/collide-200x60x60-50.png" alt="200x60x60 Collision"></a><a href="scenes/tablecrush.scene">Ball hitting a 200 by 60 by 60 block</td>
35+
</tr>
36+
<tr>
37+
<td colspan="3" align="center"><img src="images/banner-pattern.png" alt="Wide glassbreak pattern"><a href="scenes/glassbreak-wide.scene"><code>glassbreak-wide</code></a></td>
3338
</tr>
3439
</table>

images/collide-200x60x60-50.png

430 KB
Loading

images/collide-200x60x60.png

1.98 MB
Loading

images/glassbreak-3-anim.gif

2.17 MB
Loading

images/glassbreak-large-front-50.png

716 KB
Loading

images/prism-front.png

1.13 MB
Loading

images/rigid-collide-4-front.png

811 KB
Loading
File renamed without changes.

scenes/prism.scene

+6-6
Original file line numberDiff line numberDiff line change
@@ -1,27 +1,27 @@
11
Scene(
22
objects: [
33
(
4-
color: Srgba((red:-1.0,green:-1.0,blue:-1.0,alpha:1.0)),
4+
// color: Srgba((red:-1.0,green:-1.0,blue:-1.0,alpha:1.0)),
55
particles: "prismpanel.pts",
66
unfix: true,
7-
lightness_multiplier: 15.0,
8-
lightness_power: 3.0,
7+
// lightness_multiplier: 15.0,
8+
// lightness_power: 3.0,
99
),
1010
(
1111
color: Srgba((red:0.1,green:0.1,blue:0.1,alpha:1.0)),
1212
particles: "largeball.pts",
1313
position: (0.0, 40.0, 15.0),
14-
velocity: (0.0, 0.0, -1.0),
14+
velocity: (0.0, 1.0, -1.0),
1515
mass: inf,
1616
),
1717
],
1818
constants: (
19-
background_color: Srgba((red:0.1,green:0.1,blue:0.1,alpha:1.0)),
19+
// background_color: Srgba((red:0.1,green:0.1,blue:0.1,alpha:1.0)),
2020
ambient_only: true,
2121
dt: 0.016,
2222
substeps: 20,
2323
breaking_model: Distance(
24-
max: 1.00007,
24+
max: 1.0001,
2525
),
2626
// breaking_model: Stress(
2727
// normal: 2e-4,

src/bin/generate.rs

+3-6
Original file line numberDiff line numberDiff line change
@@ -2,16 +2,13 @@ use std::fs::File;
22

33
use bevy::math::{IVec3, Vec3};
44
use bevy::utils::{default, HashMap};
5-
use ext::Volume2d;
65
use morningstar::data::*;
7-
use nalgebra::{Vector2, Vector3};
6+
use nalgebra::Vector3;
87
use prism::shape::*;
98
use prism::*;
109
use smallvec::SmallVec;
1110

1211
fn main() {
13-
let scaling = 60.0;
14-
1512
let volume = Cuboid::new(Vector3::new(100.0, 100.0, 2.5));
1613

1714
let points = volume.packed_points(PackedSettings {
@@ -50,7 +47,7 @@ fn main() {
5047
let ix = ix + IVec3::new(x, y, z);
5148
if let Some(neighbors) = grid.get(&ix) {
5249
for &(n, pos) in neighbors {
53-
if n != i as u32 && ((pos - p.position) / Vec3::new(1.2, 0.5, 1.0)).length() < bond_radius {
50+
if n != i as u32 && (pos - p.position).length() < bond_radius {
5451
bonds.push(Bond { other_particle: n });
5552
p.bond_count += 1;
5653
}
@@ -66,7 +63,7 @@ fn main() {
6663
}
6764
}
6865

69-
let file = File::create("scenes/panel-big-aniso.pts").unwrap();
66+
let file = File::create("scenes/panel-big.pts").unwrap();
7067

7168
ron::ser::to_writer(file, &Particles { particles, bonds }).unwrap();
7269
}

src/lib.rs

+11-3
Original file line numberDiff line numberDiff line change
@@ -282,7 +282,7 @@ impl Default for Controls {
282282
Self {
283283
slice: SliceAxis::None,
284284
running: false,
285-
slice_position: 0.0..0.0,
285+
slice_position: -100.0..0.0,
286286
slice_bounds: -100.0..100.0,
287287
visualize_bonds: false,
288288
remove_singletons: false,
@@ -329,11 +329,13 @@ fn update_ui(
329329
&mut controls.slice_position.start,
330330
bounds.start..=bounds.end,
331331
)
332-
.text("Slice Start"),
332+
.text("Slice Start")
333+
.clamp_to_range(false),
333334
);
334335
ui.add(
335336
egui::Slider::new(&mut controls.slice_position.end, bounds.start..=bounds.end)
336-
.text("Slice End"),
337+
.text("Slice End")
338+
.clamp_to_range(false),
337339
);
338340
ui.checkbox(&mut controls.visualize_bonds, "Render Bonds");
339341
ui.checkbox(&mut controls.remove_singletons, "Remove Single Particles");
@@ -348,6 +350,12 @@ fn update_ui(
348350
controls.slice_position.start = mid;
349351
controls.slice_position.end = mid;
350352
}
353+
if controls.slice_position.start == bounds.start {
354+
controls.slice_position.start = -f32::INFINITY;
355+
}
356+
if controls.slice_position.end == bounds.end {
357+
controls.slice_position.end = f32::INFINITY;
358+
}
351359
}
352360

353361
#[expect(clippy::too_many_arguments)]

0 commit comments

Comments
 (0)