mirror of
				https://github.com/SoftFever/OrcaSlicer.git
				synced 2025-10-25 17:51:10 -06:00 
			
		
		
		
	Fixed object position after loading
This commit is contained in:
		
							parent
							
								
									6369e469c0
								
							
						
					
					
						commit
						b3c09a9254
					
				
					 2 changed files with 12 additions and 4 deletions
				
			
		|  | @ -315,6 +315,7 @@ bool GLCanvas3D::Bed::set_shape(const Pointfs& shape) | ||||||
|     if (m_shape == shape && m_type == new_type) |     if (m_shape == shape && m_type == new_type) | ||||||
|         // No change, no need to update the UI.
 |         // No change, no need to update the UI.
 | ||||||
|         return false; |         return false; | ||||||
|  | 
 | ||||||
|     m_shape = shape; |     m_shape = shape; | ||||||
|     m_type = new_type; |     m_type = new_type; | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -420,7 +420,8 @@ struct Plater::priv | ||||||
|     void update_ui_from_settings(); |     void update_ui_from_settings(); | ||||||
|     ProgressStatusBar* statusbar(); |     ProgressStatusBar* statusbar(); | ||||||
|     std::string get_config(const std::string &key) const; |     std::string get_config(const std::string &key) const; | ||||||
|     BoundingBox bed_shape_bb() const; |     BoundingBoxf bed_shape_bb() const; | ||||||
|  |     BoundingBox scaled_bed_shape_bb() const; | ||||||
|     std::vector<size_t> load_files(const std::vector<fs::path> &input_files); |     std::vector<size_t> load_files(const std::vector<fs::path> &input_files); | ||||||
|     std::vector<size_t> load_model_objects(const ModelObjectPtrs &model_objects); |     std::vector<size_t> load_model_objects(const ModelObjectPtrs &model_objects); | ||||||
| 
 | 
 | ||||||
|  | @ -569,7 +570,7 @@ void Plater::priv::update(bool force_autocenter) | ||||||
|         // auto *bed_shape_opt = config->opt<ConfigOptionPoints>("bed_shape");
 |         // auto *bed_shape_opt = config->opt<ConfigOptionPoints>("bed_shape");
 | ||||||
|         // const auto bed_shape = Slic3r::Polygon::new_scale(bed_shape_opt->values);
 |         // const auto bed_shape = Slic3r::Polygon::new_scale(bed_shape_opt->values);
 | ||||||
|         // const BoundingBox bed_shape_bb = bed_shape.bounding_box();
 |         // const BoundingBox bed_shape_bb = bed_shape.bounding_box();
 | ||||||
|         const Vec2d bed_center = bed_shape_bb().center().cast<double>(); |         const Vec2d& bed_center = bed_shape_bb().center(); | ||||||
|         model.center_instances_around_point(bed_center); |         model.center_instances_around_point(bed_center); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|  | @ -605,7 +606,13 @@ std::string Plater::priv::get_config(const std::string &key) const | ||||||
|     return wxGetApp().app_config->get(key); |     return wxGetApp().app_config->get(key); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| BoundingBox Plater::priv::bed_shape_bb() const | BoundingBoxf Plater::priv::bed_shape_bb() const | ||||||
|  | { | ||||||
|  |     BoundingBox bb = scaled_bed_shape_bb(); | ||||||
|  |     return BoundingBoxf(unscale(bb.min), unscale(bb.max)); | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | BoundingBox Plater::priv::scaled_bed_shape_bb() const | ||||||
| { | { | ||||||
|     const auto *bed_shape_opt = config->opt<ConfigOptionPoints>("bed_shape"); |     const auto *bed_shape_opt = config->opt<ConfigOptionPoints>("bed_shape"); | ||||||
|     const auto bed_shape = Slic3r::Polygon::new_scale(bed_shape_opt->values); |     const auto bed_shape = Slic3r::Polygon::new_scale(bed_shape_opt->values); | ||||||
|  | @ -732,7 +739,7 @@ Vec3crd to_3d(const Point &p, coord_t z) { return Vec3crd(p(0), p(1), z); } | ||||||
| 
 | 
 | ||||||
| std::vector<size_t>  Plater::priv::load_model_objects(const ModelObjectPtrs &model_objects) | std::vector<size_t>  Plater::priv::load_model_objects(const ModelObjectPtrs &model_objects) | ||||||
| { | { | ||||||
|     const BoundingBox bed_shape = bed_shape_bb(); |     const BoundingBoxf bed_shape = bed_shape_bb(); | ||||||
|     const Vec3d bed_center = to_3d(bed_shape.center().cast<double>(), 0.0); |     const Vec3d bed_center = to_3d(bed_shape.center().cast<double>(), 0.0); | ||||||
|     const Vec3d bed_size = to_3d(bed_shape.size().cast<double>(), 1.0); |     const Vec3d bed_size = to_3d(bed_shape.size().cast<double>(), 1.0); | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 Enrico Turri
						Enrico Turri