|  | @@ -1134,6 +1134,10 @@ void GIProbe::_find_meshes(Node *p_at_node, Baker *p_baker) {
 | 
	
		
			
				|  |  |  	}
 | 
	
		
			
				|  |  |  }
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  | +GIProbe::BakeBeginFunc GIProbe::bake_begin_function = NULL;
 | 
	
		
			
				|  |  | +GIProbe::BakeStepFunc GIProbe::bake_step_function = NULL;
 | 
	
		
			
				|  |  | +GIProbe::BakeEndFunc GIProbe::bake_end_function = NULL;
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  |  void GIProbe::bake(Node *p_from_node, bool p_create_visual_debug) {
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |  	Baker baker;
 | 
	
	
		
			
				|  | @@ -1177,14 +1181,25 @@ void GIProbe::bake(Node *p_from_node, bool p_create_visual_debug) {
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |  	_find_meshes(p_from_node ? p_from_node : get_parent(), &baker);
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  | +	if (bake_begin_function) {
 | 
	
		
			
				|  |  | +		bake_begin_function(baker.mesh_list.size() + 1);
 | 
	
		
			
				|  |  | +	}
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  |  	int pmc = 0;
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |  	for (List<Baker::PlotMesh>::Element *E = baker.mesh_list.front(); E; E = E->next()) {
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  | -		print_line("plotting mesh " + itos(pmc++) + "/" + itos(baker.mesh_list.size()));
 | 
	
		
			
				|  |  | +		if (bake_step_function) {
 | 
	
		
			
				|  |  | +			bake_step_function(pmc, RTR("Plotting Meshes") + " " + itos(pmc) + "/" + itos(baker.mesh_list.size()));
 | 
	
		
			
				|  |  | +		}
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +		pmc++;
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |  		_plot_mesh(E->get().local_xform, E->get().mesh, &baker, E->get().instance_materials, E->get().override_material);
 | 
	
		
			
				|  |  |  	}
 | 
	
		
			
				|  |  | +	if (bake_step_function) {
 | 
	
		
			
				|  |  | +		bake_step_function(pmc++, RTR("Finishing Plot"));
 | 
	
		
			
				|  |  | +	}
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |  	_fixup_plot(0, 0, 0, 0, 0, &baker);
 | 
	
		
			
				|  |  |  
 | 
	
	
		
			
				|  | @@ -1282,6 +1297,10 @@ void GIProbe::bake(Node *p_from_node, bool p_create_visual_debug) {
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |  		set_probe_data(probe_data);
 | 
	
		
			
				|  |  |  	}
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +	if (bake_end_function) {
 | 
	
		
			
				|  |  | +		bake_end_function();
 | 
	
		
			
				|  |  | +	}
 | 
	
		
			
				|  |  |  }
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |  void GIProbe::_debug_mesh(int p_idx, int p_level, const Rect3 &p_aabb, Ref<MultiMesh> &p_multimesh, int &idx, Baker *p_baker) {
 |