rust/landgen/src/outline_template_based/template_based.rs
author unC0Rr
Tue, 03 Sep 2024 13:56:35 +0200
branchtransitional_engine
changeset 16058 9cbd18220eb7
parent 15952 da6b67f13c12
child 16064 0caa3dfb3ba2
permissions -rw-r--r--
Fix cavern templates
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
15952
da6b67f13c12 Refactor mapgen to allow for easy switching between generators
unC0Rr
parents: 15951
diff changeset
     1
use super::{outline::OutlinePoints, outline_template::OutlineTemplate};
da6b67f13c12 Refactor mapgen to allow for easy switching between generators
unC0Rr
parents: 15951
diff changeset
     2
use crate::{LandGenerationParameters, LandGenerator};
14047
3b3d97ed2286 Start land generators implementation
unc0rr
parents:
diff changeset
     3
use land2d::Land2D;
14087
649ccb9f8cfd Commit broken code for divide_edges in hope for salvation
unc0rr
parents: 14075
diff changeset
     4
14075
3185fb34f3b5 update theme editor to use new land generator implementation
alfadur
parents: 14073
diff changeset
     5
pub struct TemplatedLandGenerator {
14047
3b3d97ed2286 Start land generators implementation
unc0rr
parents:
diff changeset
     6
    outline_template: OutlineTemplate,
3b3d97ed2286 Start land generators implementation
unc0rr
parents:
diff changeset
     7
}
3b3d97ed2286 Start land generators implementation
unc0rr
parents:
diff changeset
     8
3b3d97ed2286 Start land generators implementation
unc0rr
parents:
diff changeset
     9
impl TemplatedLandGenerator {
14072
8a0d69c16cad Implement OutlinePoints for land generators, some ground work for template based landgen
unc0rr
parents: 14047
diff changeset
    10
    pub fn new(outline_template: OutlineTemplate) -> Self {
14047
3b3d97ed2286 Start land generators implementation
unc0rr
parents:
diff changeset
    11
        Self { outline_template }
3b3d97ed2286 Start land generators implementation
unc0rr
parents:
diff changeset
    12
    }
3b3d97ed2286 Start land generators implementation
unc0rr
parents:
diff changeset
    13
}
3b3d97ed2286 Start land generators implementation
unc0rr
parents:
diff changeset
    14
3b3d97ed2286 Start land generators implementation
unc0rr
parents:
diff changeset
    15
impl LandGenerator for TemplatedLandGenerator {
15942
6e22f4390b7e Add basics of wavefront collapse algorithm
unC0Rr
parents: 15934
diff changeset
    16
    fn generate_land<T: Copy + PartialEq + Default, I: Iterator<Item = u32>>(
14047
3b3d97ed2286 Start land generators implementation
unc0rr
parents:
diff changeset
    17
        &self,
14142
69db1d2e4cec land_dump app for testing templated landgen
unc0rr
parents: 14121
diff changeset
    18
        parameters: &LandGenerationParameters<T>,
14047
3b3d97ed2286 Start land generators implementation
unc0rr
parents:
diff changeset
    19
        random_numbers: &mut I,
3b3d97ed2286 Start land generators implementation
unc0rr
parents:
diff changeset
    20
    ) -> Land2D<T> {
16058
9cbd18220eb7 Fix cavern templates
unC0Rr
parents: 15952
diff changeset
    21
        let do_invert = self.outline_template.is_negative
9cbd18220eb7 Fix cavern templates
unC0Rr
parents: 15952
diff changeset
    22
            && (!self.outline_template.can_invert || random_numbers.next().unwrap() & 1 == 0);
9cbd18220eb7 Fix cavern templates
unC0Rr
parents: 15952
diff changeset
    23
        let (basic, zero) = if do_invert {
9cbd18220eb7 Fix cavern templates
unC0Rr
parents: 15952
diff changeset
    24
            (parameters.zero, parameters.basic)
9cbd18220eb7 Fix cavern templates
unC0Rr
parents: 15952
diff changeset
    25
        } else {
9cbd18220eb7 Fix cavern templates
unC0Rr
parents: 15952
diff changeset
    26
            (parameters.basic, parameters.zero)
9cbd18220eb7 Fix cavern templates
unC0Rr
parents: 15952
diff changeset
    27
        };
9cbd18220eb7 Fix cavern templates
unC0Rr
parents: 15952
diff changeset
    28
9cbd18220eb7 Fix cavern templates
unC0Rr
parents: 15952
diff changeset
    29
        let mut land = Land2D::new(&self.outline_template.size, basic);
14047
3b3d97ed2286 Start land generators implementation
unc0rr
parents:
diff changeset
    30
14121
4d22be35cfa2 Finish porting FindPoint()
unc0rr
parents: 14116
diff changeset
    31
        let mut points = OutlinePoints::from_outline_template(
4d22be35cfa2 Finish porting FindPoint()
unc0rr
parents: 14116
diff changeset
    32
            &self.outline_template,
4d22be35cfa2 Finish porting FindPoint()
unc0rr
parents: 14116
diff changeset
    33
            land.play_box(),
15850
44b49f255e31 add type safe power of two sizes
alfadur
parents: 14228
diff changeset
    34
            land.size().size(),
14121
4d22be35cfa2 Finish porting FindPoint()
unc0rr
parents: 14116
diff changeset
    35
            random_numbers,
4d22be35cfa2 Finish porting FindPoint()
unc0rr
parents: 14116
diff changeset
    36
        );
14072
8a0d69c16cad Implement OutlinePoints for land generators, some ground work for template based landgen
unc0rr
parents: 14047
diff changeset
    37
8a0d69c16cad Implement OutlinePoints for land generators, some ground work for template based landgen
unc0rr
parents: 14047
diff changeset
    38
        // mirror
8a0d69c16cad Implement OutlinePoints for land generators, some ground work for template based landgen
unc0rr
parents: 14047
diff changeset
    39
        if self.outline_template.can_mirror {
8a0d69c16cad Implement OutlinePoints for land generators, some ground work for template based landgen
unc0rr
parents: 14047
diff changeset
    40
            if let Some(b) = random_numbers.next() {
8a0d69c16cad Implement OutlinePoints for land generators, some ground work for template based landgen
unc0rr
parents: 14047
diff changeset
    41
                if b & 1 != 0 {
14116
b2feb190e4bc Move flip and mirror to outline methods
unc0rr
parents: 14099
diff changeset
    42
                    points.mirror();
14072
8a0d69c16cad Implement OutlinePoints for land generators, some ground work for template based landgen
unc0rr
parents: 14047
diff changeset
    43
                }
14047
3b3d97ed2286 Start land generators implementation
unc0rr
parents:
diff changeset
    44
            }
3b3d97ed2286 Start land generators implementation
unc0rr
parents:
diff changeset
    45
        }
3b3d97ed2286 Start land generators implementation
unc0rr
parents:
diff changeset
    46
14072
8a0d69c16cad Implement OutlinePoints for land generators, some ground work for template based landgen
unc0rr
parents: 14047
diff changeset
    47
        // flip
8a0d69c16cad Implement OutlinePoints for land generators, some ground work for template based landgen
unc0rr
parents: 14047
diff changeset
    48
        if self.outline_template.can_flip {
8a0d69c16cad Implement OutlinePoints for land generators, some ground work for template based landgen
unc0rr
parents: 14047
diff changeset
    49
            if let Some(b) = random_numbers.next() {
8a0d69c16cad Implement OutlinePoints for land generators, some ground work for template based landgen
unc0rr
parents: 14047
diff changeset
    50
                if b & 1 != 0 {
14116
b2feb190e4bc Move flip and mirror to outline methods
unc0rr
parents: 14099
diff changeset
    51
                    points.flip();
14072
8a0d69c16cad Implement OutlinePoints for land generators, some ground work for template based landgen
unc0rr
parents: 14047
diff changeset
    52
                }
8a0d69c16cad Implement OutlinePoints for land generators, some ground work for template based landgen
unc0rr
parents: 14047
diff changeset
    53
            }
8a0d69c16cad Implement OutlinePoints for land generators, some ground work for template based landgen
unc0rr
parents: 14047
diff changeset
    54
        }
8a0d69c16cad Implement OutlinePoints for land generators, some ground work for template based landgen
unc0rr
parents: 14047
diff changeset
    55
14142
69db1d2e4cec land_dump app for testing templated landgen
unc0rr
parents: 14121
diff changeset
    56
        if !parameters.skip_distort {
69db1d2e4cec land_dump app for testing templated landgen
unc0rr
parents: 14121
diff changeset
    57
            points.distort(parameters.distance_divisor, random_numbers);
69db1d2e4cec land_dump app for testing templated landgen
unc0rr
parents: 14121
diff changeset
    58
        }
69db1d2e4cec land_dump app for testing templated landgen
unc0rr
parents: 14121
diff changeset
    59
69db1d2e4cec land_dump app for testing templated landgen
unc0rr
parents: 14121
diff changeset
    60
        if !parameters.skip_bezier {
14161
3078123e84ea Bezierize land outline
unc0rr
parents: 14142
diff changeset
    61
            points.bezierize(5);
14142
69db1d2e4cec land_dump app for testing templated landgen
unc0rr
parents: 14121
diff changeset
    62
        }
14072
8a0d69c16cad Implement OutlinePoints for land generators, some ground work for template based landgen
unc0rr
parents: 14047
diff changeset
    63
16058
9cbd18220eb7 Fix cavern templates
unC0Rr
parents: 15952
diff changeset
    64
        points.draw(&mut land, zero);
14072
8a0d69c16cad Implement OutlinePoints for land generators, some ground work for template based landgen
unc0rr
parents: 14047
diff changeset
    65
14087
649ccb9f8cfd Commit broken code for divide_edges in hope for salvation
unc0rr
parents: 14075
diff changeset
    66
        for p in &points.fill_points {
16058
9cbd18220eb7 Fix cavern templates
unC0Rr
parents: 15952
diff changeset
    67
            land.fill(*p, zero, zero)
14072
8a0d69c16cad Implement OutlinePoints for land generators, some ground work for template based landgen
unc0rr
parents: 14047
diff changeset
    68
        }
8a0d69c16cad Implement OutlinePoints for land generators, some ground work for template based landgen
unc0rr
parents: 14047
diff changeset
    69
16058
9cbd18220eb7 Fix cavern templates
unC0Rr
parents: 15952
diff changeset
    70
        points.draw(&mut land, basic);
14047
3b3d97ed2286 Start land generators implementation
unc0rr
parents:
diff changeset
    71
3b3d97ed2286 Start land generators implementation
unc0rr
parents:
diff changeset
    72
        land
3b3d97ed2286 Start land generators implementation
unc0rr
parents:
diff changeset
    73
    }
3b3d97ed2286 Start land generators implementation
unc0rr
parents:
diff changeset
    74
}