mirror of
				https://github.com/SoftFever/OrcaSlicer.git
				synced 2025-10-31 12:41:20 -06:00 
			
		
		
		
	 7e34244b05
			
		
	
	
		7e34244b05
		
	
	
	
	
		
			
			Slic3r::Config is now an object. Multiple partial config objects are used throughout the codebase as local repositories, then merged and serialized when necessary.
		
			
				
	
	
		
			77 lines
		
	
	
	
		
			2.2 KiB
		
	
	
	
		
			Perl
		
	
	
	
	
	
			
		
		
	
	
			77 lines
		
	
	
	
		
			2.2 KiB
		
	
	
	
		
			Perl
		
	
	
	
	
	
| package Slic3r::Fill::Base;
 | |
| use Moo;
 | |
| 
 | |
| 
 | |
| has 'print'               => (is => 'rw');
 | |
| has 'layer'               => (is => 'rw');
 | |
| has 'max_print_dimension' => (is => 'rw');
 | |
| has 'angle'               => (is => 'rw', default => sub { $Slic3r::Config->fill_angle });
 | |
| 
 | |
| use constant PI => 4 * atan2(1, 1);
 | |
| 
 | |
| sub angles () { [0, PI/2] }
 | |
| 
 | |
| sub infill_direction {
 | |
|     my $self = shift;
 | |
|     my ($surface) = @_;
 | |
|     
 | |
|     # set infill angle
 | |
|     my (@rotate, @shift);
 | |
|     $rotate[0] = Slic3r::Geometry::deg2rad($self->angle);
 | |
|     $rotate[1] = [ $self->max_print_dimension * sqrt(2) / 2, $self->max_print_dimension * sqrt(2) / 2 ];
 | |
|     @shift = @{$rotate[1]};
 | |
|     
 | |
|     if ($self->layer) {
 | |
|         # alternate fill direction
 | |
|         my $layer_num = $self->layer->id / $surface->depth_layers;
 | |
|         my $angle = $self->angles->[$layer_num % @{$self->angles}];
 | |
|         $rotate[0] = Slic3r::Geometry::deg2rad($self->angle) + $angle if $angle;
 | |
|     }
 | |
|         
 | |
|     # use bridge angle
 | |
|     if (defined $surface->bridge_angle) {
 | |
|         Slic3r::debugf "Filling bridge with angle %d\n", $surface->bridge_angle;
 | |
|         $rotate[0] = Slic3r::Geometry::deg2rad($surface->bridge_angle);
 | |
|     }
 | |
|     
 | |
|     @shift = @{ +(Slic3r::Geometry::rotate_points(@rotate, \@shift))[0] };
 | |
|     return [\@rotate, \@shift];
 | |
| }
 | |
| 
 | |
| sub rotate_points {
 | |
|     my $self = shift;
 | |
|     my ($expolygon, $rotate_vector) = @_;
 | |
|     my @rotate = @{$rotate_vector->[0]};
 | |
|     my @shift  = @{$rotate_vector->[1]};
 | |
|     
 | |
|     # rotate points as needed
 | |
|     if ($rotate[0]) {
 | |
|         $expolygon->rotate(@rotate);
 | |
|         $expolygon->translate(@shift);
 | |
|     }
 | |
| }
 | |
| 
 | |
| sub rotate_points_back {
 | |
|     my $self = shift;
 | |
|     my ($paths, $rotate_vector) = @_;
 | |
|     my @rotate = @{$rotate_vector->[0]};
 | |
|     my @shift  = @{$rotate_vector->[1]};
 | |
|     
 | |
|     if ($rotate[0]) {
 | |
|         @$paths = map [ Slic3r::Geometry::rotate_points(-$rotate[0], $rotate[1], @$_) ], 
 | |
|             map [ Slic3r::Geometry::move_points([map -$_, @shift], @$_) ], @$paths;
 | |
|     }
 | |
| }
 | |
| 
 | |
| sub adjust_solid_spacing {
 | |
|     my $self = shift;
 | |
|     my %params = @_;
 | |
|     
 | |
|     my $number_of_lines = int($params{width} / $params{distance}) + 1;
 | |
|     return $params{distance} if $number_of_lines <= 1;
 | |
|     
 | |
|     my $extra_space = $params{width} % $params{distance};
 | |
|     return $params{distance} + $extra_space / ($number_of_lines - 1);
 | |
| }
 | |
| 
 | |
| 1;
 |