mirror of
				https://github.com/SoftFever/OrcaSlicer.git
				synced 2025-10-31 12:41:20 -06:00 
			
		
		
		
	
		
			
				
	
	
		
			55 lines
		
	
	
	
		
			2.1 KiB
		
	
	
	
		
			Perl
		
	
	
	
	
	
			
		
		
	
	
			55 lines
		
	
	
	
		
			2.1 KiB
		
	
	
	
		
			Perl
		
	
	
	
	
	
| package Slic3r::Flow;
 | |
| use Moo;
 | |
| 
 | |
| use Slic3r::Geometry qw(PI);
 | |
| 
 | |
| has 'nozzle_diameter'   => (is => 'rw', required => 1);
 | |
| has 'layer_height'      => (is => 'rw', default => sub { $Slic3r::layer_height });
 | |
| 
 | |
| has 'width'             => (is => 'rw');
 | |
| has 'min_spacing'       => (is => 'rw');
 | |
| has 'spacing'           => (is => 'rw');
 | |
| 
 | |
| sub BUILD {
 | |
|     my $self = shift;
 | |
|     
 | |
|     my ($flow_width, $min_flow_spacing, $flow_spacing);
 | |
|     if ($self->width) {
 | |
|         $flow_width = $self->width =~ /^(\d+(?:\.\d+)?)%$/
 | |
|             ? ($self->layer_height * $1 / 100)
 | |
|             : $self->width;
 | |
|     } else {
 | |
|         # here we calculate a sane default by matching the flow speed (at the nozzle)
 | |
|         # and the feed rate
 | |
|         my $volume = ($self->nozzle_diameter**2) * PI/4;
 | |
|         my $shape_threshold = $self->nozzle_diameter * $self->layer_height
 | |
|             + ($self->layer_height**2) * PI/4;
 | |
|         if ($volume >= $shape_threshold) {
 | |
|             # rectangle with semicircles at the ends
 | |
|             $flow_width = (($self->nozzle_diameter**2) * PI + ($self->layer_height**2) * (4 - PI)) / (4 * $self->layer_height);
 | |
|         } else {
 | |
|             # rectangle with squished semicircles at the ends
 | |
|             $flow_width = $self->nozzle_diameter * ($self->nozzle_diameter/$self->layer_height - 4/PI + 1);
 | |
|         }
 | |
|         
 | |
|         my $min_flow_width = $self->nozzle_diameter * 1.05;
 | |
|         my $max_flow_width = $self->nozzle_diameter * 1.4;
 | |
|         $flow_width = $max_flow_width if $flow_width > $max_flow_width;
 | |
|         $flow_width = $min_flow_width if $flow_width < $min_flow_width;
 | |
|     }
 | |
|     
 | |
|     if ($flow_width >= ($self->nozzle_diameter + $self->layer_height)) {
 | |
|         # rectangle with semicircles at the ends
 | |
|         $min_flow_spacing = $flow_width - $self->layer_height * (1 - PI/4);
 | |
|     } else {
 | |
|         # rectangle with shrunk semicircles at the ends
 | |
|         $min_flow_spacing = $flow_width * (1 - PI/4) + $self->nozzle_diameter * PI/4;
 | |
|     }
 | |
|     $flow_spacing = $flow_width - $Slic3r::overlap_factor * ($flow_width - $min_flow_spacing);
 | |
|     
 | |
|     $self->width($flow_width);
 | |
|     $self->min_spacing($min_flow_spacing);
 | |
|     $self->spacing($flow_spacing);
 | |
| }
 | |
| 
 | |
| 1;
 | 
