mirror of
				https://github.com/SoftFever/OrcaSlicer.git
				synced 2025-10-30 20:21:12 -06:00 
			
		
		
		
	
		
			
				
	
	
		
			91 lines
		
	
	
	
		
			2.5 KiB
		
	
	
	
		
			Perl
		
	
	
	
	
	
			
		
		
	
	
			91 lines
		
	
	
	
		
			2.5 KiB
		
	
	
	
		
			Perl
		
	
	
	
	
	
| package Slic3r::Fill::Base;
 | ||
| use Moo;
 | ||
| 
 | ||
| has 'layer_id'            => (is => 'rw');
 | ||
| has 'z'                   => (is => 'rw'); # in unscaled coordinates
 | ||
| has 'angle'               => (is => 'rw'); # in radians, ccw, 0 = East
 | ||
| has 'spacing'             => (is => 'rw'); # in unscaled coordinates
 | ||
| has 'loop_clipping'       => (is => 'rw', default => sub { 0 }); # in scaled coordinates
 | ||
| has 'bounding_box'        => (is => 'ro', required => 0);  # Slic3r::Geometry::BoundingBox object
 | ||
| 
 | ||
| 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);
 | ||
| }
 | ||
| 
 | ||
| sub no_sort { 0 }
 | ||
| sub use_bridge_flow { 0 }
 | ||
| 
 | ||
| 
 | ||
| package Slic3r::Fill::WithDirection;
 | ||
| use Moo::Role;
 | ||
| 
 | ||
| use Slic3r::Geometry qw(PI rad2deg);
 | ||
| 
 | ||
| sub angles () { [0, PI/2] }
 | ||
| 
 | ||
| sub infill_direction {
 | ||
|     my $self = shift;
 | ||
|     my ($surface) = @_;
 | ||
|     
 | ||
|     if (!defined $self->angle) {
 | ||
|         warn "Using undefined infill angle";
 | ||
|         $self->angle(0);
 | ||
|     }
 | ||
|     
 | ||
|     # set infill angle
 | ||
|     my (@rotate);
 | ||
|     $rotate[0] = $self->angle;
 | ||
|     $rotate[1] = $self->bounding_box
 | ||
|         ? $self->bounding_box->center
 | ||
|         : $surface->expolygon->bounding_box->center;
 | ||
|     my $shift = $rotate[1]->clone;
 | ||
|     
 | ||
|     if (defined $self->layer_id) {
 | ||
|         # alternate fill direction
 | ||
|         my $layer_num = $self->layer_id / $surface->thickness_layers;
 | ||
|         my $angle = $self->angles->[$layer_num % @{$self->angles}];
 | ||
|         $rotate[0] = $self->angle + $angle if $angle;
 | ||
|     }
 | ||
|         
 | ||
|     # use bridge angle
 | ||
|     if ($surface->bridge_angle >= 0) {
 | ||
|         Slic3r::debugf "Filling bridge with angle %d\n", rad2deg($surface->bridge_angle);
 | ||
|         $rotate[0] = $surface->bridge_angle;
 | ||
|     }
 | ||
|     
 | ||
|     $rotate[0] += PI/2;
 | ||
|     $shift->rotate(@rotate);
 | ||
|     return [\@rotate, $shift];
 | ||
| }
 | ||
| 
 | ||
| # this method accepts any object that implements rotate() and translate()
 | ||
| sub rotate_points {
 | ||
|     my $self = shift;
 | ||
|     my ($expolygon, $rotate_vector) = @_;
 | ||
|     
 | ||
|     # rotate points
 | ||
|     my ($rotate, $shift) = @$rotate_vector;
 | ||
|     $rotate = [ -$rotate->[0], $rotate->[1] ];
 | ||
|     $expolygon->rotate(@$rotate);
 | ||
|     $expolygon->translate(@$shift);
 | ||
| }
 | ||
| 
 | ||
| sub rotate_points_back {
 | ||
|     my $self = shift;
 | ||
|     my ($paths, $rotate_vector) = @_;
 | ||
|     
 | ||
|     my ($rotate, $shift) = @$rotate_vector;
 | ||
|     $shift = [ map -$_, @$shift ];
 | ||
|     
 | ||
|     $_->translate(@$shift) for @$paths;
 | ||
|     $_->rotate(@$rotate) for @$paths;
 | ||
| }
 | ||
| 
 | ||
| 1;
 | 
