|  | @@ -49,6 +49,9 @@ void SpriteFramesEditor::_notification(int p_what) {
 | 
	
		
			
				|  |  |  	if (p_what==NOTIFICATION_ENTER_TREE) {
 | 
	
		
			
				|  |  |  		load->set_icon( get_icon("Folder","EditorIcons") );
 | 
	
		
			
				|  |  |  		_delete->set_icon( get_icon("Del","EditorIcons") );
 | 
	
		
			
				|  |  | +		new_anim->set_icon( get_icon("New","EditorIcons") );
 | 
	
		
			
				|  |  | +		remove_anim->set_icon( get_icon("Del","EditorIcons") );
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  |  	}
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |  	if (p_what==NOTIFICATION_READY) {
 | 
	
	
		
			
				|  | @@ -61,8 +64,9 @@ void SpriteFramesEditor::_notification(int p_what) {
 | 
	
		
			
				|  |  |  	}
 | 
	
		
			
				|  |  |  }
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  | -void SpriteFramesEditor::_file_load_request(const DVector<String>& p_path) {
 | 
	
		
			
				|  |  | +void SpriteFramesEditor::_file_load_request(const DVector<String>& p_path,int p_at_pos) {
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  | +	ERR_FAIL_COND(!frames->has_animation(edited_anim));
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |  	List< Ref<Texture> > resources;
 | 
	
		
			
				|  |  |  
 | 
	
	
		
			
				|  | @@ -85,28 +89,32 @@ void SpriteFramesEditor::_file_load_request(const DVector<String>& p_path) {
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |  	if (resources.empty()) {
 | 
	
		
			
				|  |  | -		print_line("added frames!");
 | 
	
		
			
				|  |  | +		//print_line("added frames!");
 | 
	
		
			
				|  |  |  		return;
 | 
	
		
			
				|  |  |  	}
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |  	undo_redo->create_action(TTR("Add Frame"));
 | 
	
		
			
				|  |  | -	int fc=frames->get_frame_count();
 | 
	
		
			
				|  |  | +	int fc=frames->get_frame_count(edited_anim);
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +	int count=0;
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |  	for(List< Ref<Texture> >::Element *E=resources.front();E;E=E->next() ) {
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  | -		undo_redo->add_do_method(frames,"add_frame",E->get());
 | 
	
		
			
				|  |  | -		undo_redo->add_undo_method(frames,"remove_frame",fc++);
 | 
	
		
			
				|  |  | +		undo_redo->add_do_method(frames,"add_frame",edited_anim,E->get(),p_at_pos==-1?-1:p_at_pos+count);
 | 
	
		
			
				|  |  | +		undo_redo->add_undo_method(frames,"remove_frame",edited_anim,p_at_pos==-1?fc:p_at_pos);
 | 
	
		
			
				|  |  | +		count++;
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |  	}
 | 
	
		
			
				|  |  |  	undo_redo->add_do_method(this,"_update_library");
 | 
	
		
			
				|  |  |  	undo_redo->add_undo_method(this,"_update_library");
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |  	undo_redo->commit_action();
 | 
	
		
			
				|  |  | -	print_line("added frames!");
 | 
	
		
			
				|  |  | +	//print_line("added frames!");
 | 
	
		
			
				|  |  |  }
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |  void SpriteFramesEditor::_load_pressed() {
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  | +	ERR_FAIL_COND(!frames->has_animation(edited_anim));
 | 
	
		
			
				|  |  |  	loading_scene=false;
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |  	file->clear_filters();
 | 
	
	
		
			
				|  | @@ -160,19 +168,21 @@ void SpriteFramesEditor::_item_edited() {
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |  void SpriteFramesEditor::_delete_confirm_pressed() {
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  | -	if (!tree->get_selected())
 | 
	
		
			
				|  |  | +	ERR_FAIL_COND(!frames->has_animation(edited_anim));
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +	if (tree->get_current()<0)
 | 
	
		
			
				|  |  |  		return;
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |  	sel-=1;
 | 
	
		
			
				|  |  | -	if (sel<0 && frames->get_frame_count())
 | 
	
		
			
				|  |  | +	if (sel<0 && frames->get_frame_count(edited_anim))
 | 
	
		
			
				|  |  |  		sel=0;
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  | -	int to_remove = tree->get_selected()->get_metadata(0);
 | 
	
		
			
				|  |  | +	int to_remove = tree->get_current();
 | 
	
		
			
				|  |  |  	sel=to_remove;
 | 
	
		
			
				|  |  | -	Ref<Texture> r = frames->get_frame(to_remove);
 | 
	
		
			
				|  |  | +	Ref<Texture> r = frames->get_frame(edited_anim,to_remove);
 | 
	
		
			
				|  |  |  	undo_redo->create_action(TTR("Delete Resource"));
 | 
	
		
			
				|  |  | -	undo_redo->add_do_method(frames,"remove_frame",to_remove);
 | 
	
		
			
				|  |  | -	undo_redo->add_undo_method(frames,"add_frame",r,to_remove);
 | 
	
		
			
				|  |  | +	undo_redo->add_do_method(frames,"remove_frame",edited_anim,to_remove);
 | 
	
		
			
				|  |  | +	undo_redo->add_undo_method(frames,"add_frame",edited_anim,r,to_remove);
 | 
	
		
			
				|  |  |  	undo_redo->add_do_method(this,"_update_library");
 | 
	
		
			
				|  |  |  	undo_redo->add_undo_method(this,"_update_library");
 | 
	
		
			
				|  |  |  	undo_redo->commit_action();
 | 
	
	
		
			
				|  | @@ -182,6 +192,8 @@ void SpriteFramesEditor::_delete_confirm_pressed() {
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |  void SpriteFramesEditor::_paste_pressed() {
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  | +	ERR_FAIL_COND(!frames->has_animation(edited_anim));
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  |  	Ref<Texture> r=EditorSettings::get_singleton()->get_resource_clipboard();
 | 
	
		
			
				|  |  |  	if (!r.is_valid()) {
 | 
	
		
			
				|  |  |  		dialog->set_text(TTR("Resource clipboard is empty or not a texture!"));
 | 
	
	
		
			
				|  | @@ -194,8 +206,8 @@ void SpriteFramesEditor::_paste_pressed() {
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |  	undo_redo->create_action(TTR("Paste Frame"));
 | 
	
		
			
				|  |  | -	undo_redo->add_do_method(frames,"add_frame",r);
 | 
	
		
			
				|  |  | -	undo_redo->add_undo_method(frames,"remove_frame",frames->get_frame_count());
 | 
	
		
			
				|  |  | +	undo_redo->add_do_method(frames,"add_frame",edited_anim,r);
 | 
	
		
			
				|  |  | +	undo_redo->add_undo_method(frames,"remove_frame",edited_anim,frames->get_frame_count(edited_anim));
 | 
	
		
			
				|  |  |  	undo_redo->add_do_method(this,"_update_library");
 | 
	
		
			
				|  |  |  	undo_redo->add_undo_method(this,"_update_library");
 | 
	
		
			
				|  |  |  	undo_redo->commit_action();
 | 
	
	
		
			
				|  | @@ -204,16 +216,17 @@ void SpriteFramesEditor::_paste_pressed() {
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |  void SpriteFramesEditor::_empty_pressed() {
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  | +	ERR_FAIL_COND(!frames->has_animation(edited_anim));
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |  	int from=-1;
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  | -	if (tree->get_selected()) {
 | 
	
		
			
				|  |  | +	if (tree->get_current()>=0) {
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  | -		from = tree->get_selected()->get_metadata(0);
 | 
	
		
			
				|  |  | +		from = tree->get_current();
 | 
	
		
			
				|  |  |  		sel=from;
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |  	} else {
 | 
	
		
			
				|  |  | -		from=frames->get_frame_count();
 | 
	
		
			
				|  |  | +		from=frames->get_frame_count(edited_anim);
 | 
	
		
			
				|  |  |  	}
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |  
 | 
	
	
		
			
				|  | @@ -221,8 +234,8 @@ void SpriteFramesEditor::_empty_pressed() {
 | 
	
		
			
				|  |  |  	Ref<Texture> r;
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |  	undo_redo->create_action(TTR("Add Empty"));
 | 
	
		
			
				|  |  | -	undo_redo->add_do_method(frames,"add_frame",r,from);
 | 
	
		
			
				|  |  | -	undo_redo->add_undo_method(frames,"remove_frame",from);
 | 
	
		
			
				|  |  | +	undo_redo->add_do_method(frames,"add_frame",edited_anim,r,from);
 | 
	
		
			
				|  |  | +	undo_redo->add_undo_method(frames,"remove_frame",edited_anim,from);
 | 
	
		
			
				|  |  |  	undo_redo->add_do_method(this,"_update_library");
 | 
	
		
			
				|  |  |  	undo_redo->add_undo_method(this,"_update_library");
 | 
	
		
			
				|  |  |  	undo_redo->commit_action();
 | 
	
	
		
			
				|  | @@ -231,16 +244,17 @@ void SpriteFramesEditor::_empty_pressed() {
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |  void SpriteFramesEditor::_empty2_pressed() {
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  | +	ERR_FAIL_COND(!frames->has_animation(edited_anim));
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |  	int from=-1;
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  | -	if (tree->get_selected()) {
 | 
	
		
			
				|  |  | +	if (tree->get_current()>=0) {
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  | -		from = tree->get_selected()->get_metadata(0);
 | 
	
		
			
				|  |  | +		from = tree->get_current();
 | 
	
		
			
				|  |  |  		sel=from;
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |  	} else {
 | 
	
		
			
				|  |  | -		from=frames->get_frame_count();
 | 
	
		
			
				|  |  | +		from=frames->get_frame_count(edited_anim);
 | 
	
		
			
				|  |  |  	}
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |  
 | 
	
	
		
			
				|  | @@ -248,8 +262,8 @@ void SpriteFramesEditor::_empty2_pressed() {
 | 
	
		
			
				|  |  |  	Ref<Texture> r;
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |  	undo_redo->create_action(TTR("Add Empty"));
 | 
	
		
			
				|  |  | -	undo_redo->add_do_method(frames,"add_frame",r,from+1);
 | 
	
		
			
				|  |  | -	undo_redo->add_undo_method(frames,"remove_frame",from+1);
 | 
	
		
			
				|  |  | +	undo_redo->add_do_method(frames,"add_frame",edited_anim,r,from+1);
 | 
	
		
			
				|  |  | +	undo_redo->add_undo_method(frames,"remove_frame",edited_anim,from+1);
 | 
	
		
			
				|  |  |  	undo_redo->add_do_method(this,"_update_library");
 | 
	
		
			
				|  |  |  	undo_redo->add_undo_method(this,"_update_library");
 | 
	
		
			
				|  |  |  	undo_redo->commit_action();
 | 
	
	
		
			
				|  | @@ -258,21 +272,24 @@ void SpriteFramesEditor::_empty2_pressed() {
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |  void SpriteFramesEditor::_up_pressed() {
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  | -	if (!tree->get_selected())
 | 
	
		
			
				|  |  | +	ERR_FAIL_COND(!frames->has_animation(edited_anim));
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +	if (tree->get_current()<0)
 | 
	
		
			
				|  |  |  		return;
 | 
	
		
			
				|  |  | -	int to_move = tree->get_selected()->get_metadata(0);
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +	int to_move = tree->get_current();
 | 
	
		
			
				|  |  |  	if (to_move<1)
 | 
	
		
			
				|  |  |  		return;
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |  	sel=to_move;
 | 
	
		
			
				|  |  |  	sel-=1;
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  | -	Ref<Texture> r = frames->get_frame(to_move);
 | 
	
		
			
				|  |  | +	Ref<Texture> r = frames->get_frame(edited_anim,to_move);
 | 
	
		
			
				|  |  |  	undo_redo->create_action(TTR("Delete Resource"));
 | 
	
		
			
				|  |  | -	undo_redo->add_do_method(frames,"set_frame",to_move,frames->get_frame(to_move-1));
 | 
	
		
			
				|  |  | -	undo_redo->add_do_method(frames,"set_frame",to_move-1,frames->get_frame(to_move));
 | 
	
		
			
				|  |  | -	undo_redo->add_undo_method(frames,"set_frame",to_move,frames->get_frame(to_move));
 | 
	
		
			
				|  |  | -	undo_redo->add_undo_method(frames,"set_frame",to_move-1,frames->get_frame(to_move-1));
 | 
	
		
			
				|  |  | +	undo_redo->add_do_method(frames,"set_frame",edited_anim,to_move,frames->get_frame(edited_anim,to_move-1));
 | 
	
		
			
				|  |  | +	undo_redo->add_do_method(frames,"set_frame",edited_anim,to_move-1,frames->get_frame(edited_anim,to_move));
 | 
	
		
			
				|  |  | +	undo_redo->add_undo_method(frames,"set_frame",edited_anim,to_move,frames->get_frame(edited_anim,to_move));
 | 
	
		
			
				|  |  | +	undo_redo->add_undo_method(frames,"set_frame",edited_anim,to_move-1,frames->get_frame(edited_anim,to_move-1));
 | 
	
		
			
				|  |  |  	undo_redo->add_do_method(this,"_update_library");
 | 
	
		
			
				|  |  |  	undo_redo->add_undo_method(this,"_update_library");
 | 
	
		
			
				|  |  |  	undo_redo->commit_action();
 | 
	
	
		
			
				|  | @@ -281,21 +298,24 @@ void SpriteFramesEditor::_up_pressed() {
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |  void SpriteFramesEditor::_down_pressed() {
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  | -	if (!tree->get_selected())
 | 
	
		
			
				|  |  | +	ERR_FAIL_COND(!frames->has_animation(edited_anim));
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +	if (tree->get_current()<0)
 | 
	
		
			
				|  |  |  		return;
 | 
	
		
			
				|  |  | -	int to_move = tree->get_selected()->get_metadata(0);
 | 
	
		
			
				|  |  | -	if (to_move<0 || to_move>=frames->get_frame_count()-1)
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +	int to_move = tree->get_current();
 | 
	
		
			
				|  |  | +	if (to_move<0 || to_move>=frames->get_frame_count(edited_anim)-1)
 | 
	
		
			
				|  |  |  		return;
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |  	sel=to_move;
 | 
	
		
			
				|  |  |  	sel+=1;
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  | -	Ref<Texture> r = frames->get_frame(to_move);
 | 
	
		
			
				|  |  | +	Ref<Texture> r = frames->get_frame(edited_anim,to_move);
 | 
	
		
			
				|  |  |  	undo_redo->create_action(TTR("Delete Resource"));
 | 
	
		
			
				|  |  | -	undo_redo->add_do_method(frames,"set_frame",to_move,frames->get_frame(to_move+1));
 | 
	
		
			
				|  |  | -	undo_redo->add_do_method(frames,"set_frame",to_move+1,frames->get_frame(to_move));
 | 
	
		
			
				|  |  | -	undo_redo->add_undo_method(frames,"set_frame",to_move,frames->get_frame(to_move));
 | 
	
		
			
				|  |  | -	undo_redo->add_undo_method(frames,"set_frame",to_move+1,frames->get_frame(to_move+1));
 | 
	
		
			
				|  |  | +	undo_redo->add_do_method(frames,"set_frame",edited_anim,to_move,frames->get_frame(edited_anim,to_move+1));
 | 
	
		
			
				|  |  | +	undo_redo->add_do_method(frames,"set_frame",edited_anim,to_move+1,frames->get_frame(edited_anim,to_move));
 | 
	
		
			
				|  |  | +	undo_redo->add_undo_method(frames,"set_frame",edited_anim,to_move,frames->get_frame(edited_anim,to_move));
 | 
	
		
			
				|  |  | +	undo_redo->add_undo_method(frames,"set_frame",edited_anim,to_move+1,frames->get_frame(edited_anim,to_move+1));
 | 
	
		
			
				|  |  |  	undo_redo->add_do_method(this,"_update_library");
 | 
	
		
			
				|  |  |  	undo_redo->add_undo_method(this,"_update_library");
 | 
	
		
			
				|  |  |  	undo_redo->commit_action();
 | 
	
	
		
			
				|  | @@ -308,7 +328,7 @@ void SpriteFramesEditor::_down_pressed() {
 | 
	
		
			
				|  |  |  void SpriteFramesEditor::_delete_pressed() {
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  | -	if (!tree->get_selected())
 | 
	
		
			
				|  |  | +	if (tree->get_current()<0)
 | 
	
		
			
				|  |  |  		return;
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |  	_delete_confirm_pressed(); //it has undo.. why bother with a dialog..
 | 
	
	
		
			
				|  | @@ -323,39 +343,211 @@ void SpriteFramesEditor::_delete_pressed() {
 | 
	
		
			
				|  |  |  }
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  | -void SpriteFramesEditor::_update_library() {
 | 
	
		
			
				|  |  | +void SpriteFramesEditor::_animation_select() {
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +	if (updating)
 | 
	
		
			
				|  |  | +		return;
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +	TreeItem *selected = animations->get_selected();
 | 
	
		
			
				|  |  | +	ERR_FAIL_COND(!selected);
 | 
	
		
			
				|  |  | +	edited_anim=selected->get_text(0);
 | 
	
		
			
				|  |  | +	_update_library(true);
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +}
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +void SpriteFramesEditor::_animation_name_edited(){
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +	if (updating)
 | 
	
		
			
				|  |  | +		return;
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +	if (!frames->has_animation(edited_anim))
 | 
	
		
			
				|  |  | +		return;
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +	TreeItem *edited = animations->get_edited();
 | 
	
		
			
				|  |  | +	if (!edited)
 | 
	
		
			
				|  |  | +		return;
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +	String new_name = edited->get_text(0);
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +	if (new_name==String(edited_anim))
 | 
	
		
			
				|  |  | +		return;
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +	new_name=new_name.replace("/","_").replace(","," ");
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +	String name=new_name;
 | 
	
		
			
				|  |  | +	int counter=0;
 | 
	
		
			
				|  |  | +	while(frames->has_animation(name)) {
 | 
	
		
			
				|  |  | +		counter++;
 | 
	
		
			
				|  |  | +		name=new_name+" "+itos(counter);
 | 
	
		
			
				|  |  | +	}
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +	undo_redo->create_action(TTR("Rename Animation"));
 | 
	
		
			
				|  |  | +	undo_redo->add_do_method(frames,"rename_animation",edited_anim,name);
 | 
	
		
			
				|  |  | +	undo_redo->add_undo_method(frames,"rename_animation",name,edited_anim);
 | 
	
		
			
				|  |  | +	undo_redo->add_do_method(this,"_update_library");
 | 
	
		
			
				|  |  | +	undo_redo->add_undo_method(this,"_update_library");
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +	edited_anim=new_name;
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +	undo_redo->commit_action();
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +}
 | 
	
		
			
				|  |  | +void SpriteFramesEditor::_animation_add(){
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +	String new_name = "New Anim";
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +	String name=new_name;
 | 
	
		
			
				|  |  | +	int counter=0;
 | 
	
		
			
				|  |  | +	while(frames->has_animation(name)) {
 | 
	
		
			
				|  |  | +		counter++;
 | 
	
		
			
				|  |  | +		name=new_name+" "+itos(counter);
 | 
	
		
			
				|  |  | +	}
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +	undo_redo->create_action(TTR("Add Animation"));
 | 
	
		
			
				|  |  | +	undo_redo->add_do_method(frames,"add_animation",name);
 | 
	
		
			
				|  |  | +	undo_redo->add_undo_method(frames,"remove_animation",name);
 | 
	
		
			
				|  |  | +	undo_redo->add_do_method(this,"_update_library");
 | 
	
		
			
				|  |  | +	undo_redo->add_undo_method(this,"_update_library");
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +	edited_anim=new_name;
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +	undo_redo->commit_action();
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +}
 | 
	
		
			
				|  |  | +void SpriteFramesEditor::_animation_remove(){
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +	//fuck everything
 | 
	
		
			
				|  |  | +	if (updating)
 | 
	
		
			
				|  |  | +		return;
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +	if (!frames->has_animation(edited_anim))
 | 
	
		
			
				|  |  | +		return;
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +	undo_redo->create_action(TTR("Remove Animation"));
 | 
	
		
			
				|  |  | +	undo_redo->add_do_method(frames,"remove_animation",edited_anim);
 | 
	
		
			
				|  |  | +	undo_redo->add_undo_method(frames,"add_animation",edited_anim);
 | 
	
		
			
				|  |  | +	undo_redo->add_undo_method(frames,"set_animation_speed",edited_anim,frames->get_animation_speed(edited_anim));
 | 
	
		
			
				|  |  | +	undo_redo->add_undo_method(frames,"set_animation_loop",edited_anim,frames->get_animation_loop(edited_anim));
 | 
	
		
			
				|  |  | +	int fc = frames->get_frame_count(edited_anim);
 | 
	
		
			
				|  |  | +	for(int i=0;i<fc;i++) {
 | 
	
		
			
				|  |  | +		Ref<Texture> frame = frames->get_frame(edited_anim,i);
 | 
	
		
			
				|  |  | +		undo_redo->add_undo_method(frames,"add_frame",edited_anim,frame);
 | 
	
		
			
				|  |  | +	}
 | 
	
		
			
				|  |  | +	undo_redo->add_do_method(this,"_update_library");
 | 
	
		
			
				|  |  | +	undo_redo->add_undo_method(this,"_update_library");
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +	undo_redo->commit_action();
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +}
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +void SpriteFramesEditor::_animation_loop_changed() {
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +	if (updating)
 | 
	
		
			
				|  |  | +		return;
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +	undo_redo->create_action(TTR("Change Animation Loop"));
 | 
	
		
			
				|  |  | +	undo_redo->add_do_method(frames,"set_animation_loop",edited_anim,anim_loop->is_pressed());
 | 
	
		
			
				|  |  | +	undo_redo->add_undo_method(frames,"set_animation_loop",edited_anim,frames->get_animation_loop(edited_anim));
 | 
	
		
			
				|  |  | +	undo_redo->add_do_method(this,"_update_library",true);
 | 
	
		
			
				|  |  | +	undo_redo->add_undo_method(this,"_update_library",true);
 | 
	
		
			
				|  |  | +	undo_redo->commit_action();
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +}
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +void SpriteFramesEditor::_animation_fps_changed(double p_value) {
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +	if (updating)
 | 
	
		
			
				|  |  | +		return;
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +	undo_redo->create_action(TTR("Change Animation FPS"),true);
 | 
	
		
			
				|  |  | +	undo_redo->add_do_method(frames,"set_animation_speed",edited_anim,p_value);
 | 
	
		
			
				|  |  | +	undo_redo->add_undo_method(frames,"set_animation_speed",edited_anim,frames->get_animation_speed(edited_anim));
 | 
	
		
			
				|  |  | +	undo_redo->add_do_method(this,"_update_library",true);
 | 
	
		
			
				|  |  | +	undo_redo->add_undo_method(this,"_update_library",true);
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +	undo_redo->commit_action();
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +}
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +void SpriteFramesEditor::_update_library(bool p_skip_selector) {
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +	updating=true;
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +	if (!p_skip_selector) {
 | 
	
		
			
				|  |  | +		animations->clear();
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +		TreeItem *anim_root=animations->create_item();
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +		List<StringName> anim_names;
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +		anim_names.sort_custom<StringName::AlphCompare>();
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +		frames->get_animation_list(&anim_names);
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +		anim_names.sort_custom<StringName::AlphCompare>();
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +		for(List<StringName>::Element *E=anim_names.front();E;E=E->next()) {
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +			String name = E->get();
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +			TreeItem *it = animations->create_item(anim_root);
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +			it->set_metadata(0,name);
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +				it->set_text(0,name);
 | 
	
		
			
				|  |  | +			it->set_editable(0,true);
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +			if (E->get()==edited_anim) {
 | 
	
		
			
				|  |  | +				it->select(0);
 | 
	
		
			
				|  |  | +			}
 | 
	
		
			
				|  |  | +		}
 | 
	
		
			
				|  |  | +	}
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |  	tree->clear();
 | 
	
		
			
				|  |  | -	tree->set_hide_root(true);
 | 
	
		
			
				|  |  | -	TreeItem *root = tree->create_item(NULL);
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  | -	if (sel>=frames->get_frame_count())
 | 
	
		
			
				|  |  | -		sel=frames->get_frame_count()-1;
 | 
	
		
			
				|  |  | -	else if (sel<0 && frames->get_frame_count())
 | 
	
		
			
				|  |  | +	if (!frames->has_animation(edited_anim)) {
 | 
	
		
			
				|  |  | +		updating=false;
 | 
	
		
			
				|  |  | +		return;
 | 
	
		
			
				|  |  | +	}
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +	if (sel>=frames->get_frame_count(edited_anim))
 | 
	
		
			
				|  |  | +		sel=frames->get_frame_count(edited_anim)-1;
 | 
	
		
			
				|  |  | +	else if (sel<0 && frames->get_frame_count(edited_anim))
 | 
	
		
			
				|  |  |  		sel=0;
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  | -	for(int i=0;i<frames->get_frame_count();i++) {
 | 
	
		
			
				|  |  | +	for(int i=0;i<frames->get_frame_count(edited_anim);i++) {
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +		String name;
 | 
	
		
			
				|  |  | +		Ref<Texture> icon;
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  | -		TreeItem *ti = tree->create_item(root);
 | 
	
		
			
				|  |  | -		ti->set_cell_mode(0,TreeItem::CELL_MODE_STRING);
 | 
	
		
			
				|  |  | -		ti->set_selectable(0,true);
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  | -		if (frames->get_frame(i).is_null()) {
 | 
	
		
			
				|  |  | +		if (frames->get_frame(edited_anim,i).is_null()) {
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  | -			ti->set_text(0,TTR("Frame ")+itos(i)+" (empty)");
 | 
	
		
			
				|  |  | +			name=itos(i)+TTR(": (empty)");
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |  		} else {
 | 
	
		
			
				|  |  | -			ti->set_text(0,TTR("Frame ")+itos(i)+" ("+frames->get_frame(i)->get_name()+")");
 | 
	
		
			
				|  |  | -			ti->set_icon(0,frames->get_frame(i));
 | 
	
		
			
				|  |  | +			name=itos(i)+": "+frames->get_frame(edited_anim,i)->get_name();
 | 
	
		
			
				|  |  | +			icon=frames->get_frame(edited_anim,i);
 | 
	
		
			
				|  |  |  		}
 | 
	
		
			
				|  |  | -		if (frames->get_frame(i).is_valid())
 | 
	
		
			
				|  |  | -			ti->set_tooltip(0,frames->get_frame(i)->get_path());
 | 
	
		
			
				|  |  | -		ti->set_metadata(0,i);
 | 
	
		
			
				|  |  | -		ti->set_icon_max_width(0,96);
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +		tree->add_item(name,icon);
 | 
	
		
			
				|  |  | +		if (frames->get_frame(edited_anim,i).is_valid())
 | 
	
		
			
				|  |  | +			tree->set_item_tooltip(tree->get_item_count()-1,frames->get_frame(edited_anim,i)->get_path());
 | 
	
		
			
				|  |  |  		if (sel==i)
 | 
	
		
			
				|  |  | -			ti->select(0);
 | 
	
		
			
				|  |  | +			tree->select(tree->get_item_count()-1);
 | 
	
		
			
				|  |  |  	}
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  | +	anim_speed->set_val(frames->get_animation_speed(edited_anim));
 | 
	
		
			
				|  |  | +	anim_loop->set_pressed(frames->get_animation_loop(edited_anim));
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +	updating=false;
 | 
	
		
			
				|  |  |  	//player->add_resource("default",resource);
 | 
	
		
			
				|  |  |  }
 | 
	
		
			
				|  |  |  
 | 
	
	
		
			
				|  | @@ -363,10 +555,27 @@ void SpriteFramesEditor::_update_library() {
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |  void SpriteFramesEditor::edit(SpriteFrames* p_frames) {
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  | +	if (frames==p_frames)
 | 
	
		
			
				|  |  | +		return;
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  |  	frames=p_frames;
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |  	if (p_frames) {
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +		if (!p_frames->has_animation(edited_anim)) {
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +			List<StringName> anim_names;
 | 
	
		
			
				|  |  | +			frames->get_animation_list(&anim_names);
 | 
	
		
			
				|  |  | +			anim_names.sort_custom<StringName::AlphCompare>();
 | 
	
		
			
				|  |  | +			if (anim_names.size()) {
 | 
	
		
			
				|  |  | +				edited_anim=anim_names.front()->get();
 | 
	
		
			
				|  |  | +			} else {
 | 
	
		
			
				|  |  | +				edited_anim=StringName();
 | 
	
		
			
				|  |  | +			}
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +		}
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  |  		_update_library();
 | 
	
		
			
				|  |  |  	} else {
 | 
	
		
			
				|  |  |  
 | 
	
	
		
			
				|  | @@ -377,6 +586,110 @@ void SpriteFramesEditor::edit(SpriteFrames* p_frames) {
 | 
	
		
			
				|  |  |  }
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  | +Variant SpriteFramesEditor::get_drag_data_fw(const Point2& p_point,Control* p_from) {
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +	if (!frames->has_animation(edited_anim))
 | 
	
		
			
				|  |  | +		return false;
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +	int idx = tree->get_item_at_pos(p_point,true);
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +	if (idx<0 || idx>=frames->get_frame_count(edited_anim))
 | 
	
		
			
				|  |  | +		return Variant();
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +	RES frame = frames->get_frame(edited_anim,idx);
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +	if (frame.is_null())
 | 
	
		
			
				|  |  | +		return Variant();
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +	return EditorNode::get_singleton()->drag_resource(frame,p_from);
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +}
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +bool SpriteFramesEditor::can_drop_data_fw(const Point2& p_point,const Variant& p_data,Control* p_from) const{
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +	Dictionary d = p_data;
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +	if (!d.has("type"))
 | 
	
		
			
				|  |  | +		return false;
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +	if (d.has("from") && (Object*)(d["from"])==tree)
 | 
	
		
			
				|  |  | +		return false;
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +	if (String(d["type"])=="resource" && d.has("resource")) {
 | 
	
		
			
				|  |  | +		RES r=d["resource"];
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +		Ref<Texture> texture = r;
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +		if (texture.is_valid()) {
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +			return true;
 | 
	
		
			
				|  |  | +		}
 | 
	
		
			
				|  |  | +	}
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +	if (String(d["type"])=="files") {
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +		Vector<String> files = d["files"];
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +		if (files.size()==0)
 | 
	
		
			
				|  |  | +			return false;
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +		for(int i=0;i<files.size();i++) {
 | 
	
		
			
				|  |  | +			String file = files[0];
 | 
	
		
			
				|  |  | +			String ftype = EditorFileSystem::get_singleton()->get_file_type(file);
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +			if (!ObjectTypeDB::is_type(ftype,"Texture")) {
 | 
	
		
			
				|  |  | +				return false;
 | 
	
		
			
				|  |  | +			}
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +		}
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +		return true;
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +	}
 | 
	
		
			
				|  |  | +	return false;
 | 
	
		
			
				|  |  | +}
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +void SpriteFramesEditor::drop_data_fw(const Point2& p_point,const Variant& p_data,Control* p_from){
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +	if (!can_drop_data_fw(p_point,p_data,p_from))
 | 
	
		
			
				|  |  | +		return;
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +	Dictionary d = p_data;
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +	if (!d.has("type"))
 | 
	
		
			
				|  |  | +		return;
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +	int at_pos = tree->get_item_at_pos(p_point,true);
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +	if (String(d["type"])=="resource" && d.has("resource")) {
 | 
	
		
			
				|  |  | +		RES r=d["resource"];
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +		Ref<Texture> texture = r;
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +		if (texture.is_valid()) {
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +			undo_redo->create_action(TTR("Add Frame"));
 | 
	
		
			
				|  |  | +			undo_redo->add_do_method(frames,"add_frame",edited_anim,texture,at_pos==-1?-1:at_pos);
 | 
	
		
			
				|  |  | +			undo_redo->add_undo_method(frames,"remove_frame",edited_anim,at_pos==-1?frames->get_frame_count(edited_anim):at_pos);
 | 
	
		
			
				|  |  | +			undo_redo->add_do_method(this,"_update_library");
 | 
	
		
			
				|  |  | +			undo_redo->add_undo_method(this,"_update_library");
 | 
	
		
			
				|  |  | +			undo_redo->commit_action();
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +		}
 | 
	
		
			
				|  |  | +	}
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +	if (String(d["type"])=="files") {
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +		DVector<String> files = d["files"];
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +		_file_load_request(files,at_pos);
 | 
	
		
			
				|  |  | +	}
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +}
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |  void SpriteFramesEditor::_bind_methods() {
 | 
	
		
			
				|  |  |  
 | 
	
	
		
			
				|  | @@ -388,29 +701,94 @@ void SpriteFramesEditor::_bind_methods() {
 | 
	
		
			
				|  |  |  	ObjectTypeDB::bind_method(_MD("_delete_pressed"),&SpriteFramesEditor::_delete_pressed);
 | 
	
		
			
				|  |  |  	ObjectTypeDB::bind_method(_MD("_paste_pressed"),&SpriteFramesEditor::_paste_pressed);
 | 
	
		
			
				|  |  |  	ObjectTypeDB::bind_method(_MD("_delete_confirm_pressed"),&SpriteFramesEditor::_delete_confirm_pressed);
 | 
	
		
			
				|  |  | -	ObjectTypeDB::bind_method(_MD("_file_load_request"),&SpriteFramesEditor::_file_load_request);
 | 
	
		
			
				|  |  | -	ObjectTypeDB::bind_method(_MD("_update_library"),&SpriteFramesEditor::_update_library);
 | 
	
		
			
				|  |  | +	ObjectTypeDB::bind_method(_MD("_file_load_request","files","atpos"),&SpriteFramesEditor::_file_load_request,DEFVAL(-1));
 | 
	
		
			
				|  |  | +	ObjectTypeDB::bind_method(_MD("_update_library","skipsel"),&SpriteFramesEditor::_update_library,DEFVAL(false));
 | 
	
		
			
				|  |  |  	ObjectTypeDB::bind_method(_MD("_up_pressed"),&SpriteFramesEditor::_up_pressed);
 | 
	
		
			
				|  |  |  	ObjectTypeDB::bind_method(_MD("_down_pressed"),&SpriteFramesEditor::_down_pressed);
 | 
	
		
			
				|  |  | +	ObjectTypeDB::bind_method(_MD("_animation_select"),&SpriteFramesEditor::_animation_select);
 | 
	
		
			
				|  |  | +	ObjectTypeDB::bind_method(_MD("_animation_name_edited"),&SpriteFramesEditor::_animation_name_edited);
 | 
	
		
			
				|  |  | +	ObjectTypeDB::bind_method(_MD("_animation_add"),&SpriteFramesEditor::_animation_add);
 | 
	
		
			
				|  |  | +	ObjectTypeDB::bind_method(_MD("_animation_remove"),&SpriteFramesEditor::_animation_remove);
 | 
	
		
			
				|  |  | +	ObjectTypeDB::bind_method(_MD("_animation_loop_changed"),&SpriteFramesEditor::_animation_loop_changed);
 | 
	
		
			
				|  |  | +	ObjectTypeDB::bind_method(_MD("_animation_fps_changed"),&SpriteFramesEditor::_animation_fps_changed);
 | 
	
		
			
				|  |  | +	ObjectTypeDB::bind_method(_MD("get_drag_data_fw"), &SpriteFramesEditor::get_drag_data_fw);
 | 
	
		
			
				|  |  | +	ObjectTypeDB::bind_method(_MD("can_drop_data_fw"), &SpriteFramesEditor::can_drop_data_fw);
 | 
	
		
			
				|  |  | +	ObjectTypeDB::bind_method(_MD("drop_data_fw"), &SpriteFramesEditor::drop_data_fw);
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  |  }
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  |  SpriteFramesEditor::SpriteFramesEditor() {
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |  	//add_style_override("panel", get_stylebox("panel","Panel"));
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  | +	split = memnew( HSplitContainer );
 | 
	
		
			
				|  |  | +	add_child(split);
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +	VBoxContainer *vbc_animlist = memnew( VBoxContainer );
 | 
	
		
			
				|  |  | +	split->add_child(vbc_animlist);
 | 
	
		
			
				|  |  | +	vbc_animlist->set_custom_minimum_size(Size2(150,0));
 | 
	
		
			
				|  |  | +	//vbc_animlist->set_v_size_flags(SIZE_EXPAND_FILL);
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +	VBoxContainer *sub_vb = memnew( VBoxContainer );
 | 
	
		
			
				|  |  | +	vbc_animlist->add_margin_child(TTR("Animations"),sub_vb,true);
 | 
	
		
			
				|  |  | +	sub_vb->set_v_size_flags(SIZE_EXPAND_FILL);
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +	HBoxContainer *hbc_animlist = memnew( HBoxContainer );
 | 
	
		
			
				|  |  | +	sub_vb->add_child(hbc_animlist);
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +	new_anim = memnew( Button );
 | 
	
		
			
				|  |  | +	hbc_animlist->add_child(new_anim);
 | 
	
		
			
				|  |  | +	new_anim->connect("pressed",this,"_animation_add");
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +	hbc_animlist->add_spacer();
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +	remove_anim = memnew( Button );
 | 
	
		
			
				|  |  | +	hbc_animlist->add_child(remove_anim);
 | 
	
		
			
				|  |  | +	remove_anim->connect("pressed",this,"_animation_remove");
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +	animations = memnew( Tree );
 | 
	
		
			
				|  |  | +	sub_vb->add_child(animations);
 | 
	
		
			
				|  |  | +	animations->set_v_size_flags(SIZE_EXPAND_FILL);
 | 
	
		
			
				|  |  | +	animations->set_hide_root(true);
 | 
	
		
			
				|  |  | +	animations->connect("cell_selected",this,"_animation_select");
 | 
	
		
			
				|  |  | +	animations->connect("item_edited",this,"_animation_name_edited");
 | 
	
		
			
				|  |  | +	animations->set_single_select_cell_editing_only_when_already_selected(true);
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +	anim_speed = memnew( SpinBox);
 | 
	
		
			
				|  |  | +	vbc_animlist->add_margin_child(TTR("Speed (FPS):"),anim_speed);
 | 
	
		
			
				|  |  | +	anim_speed->set_min(0);
 | 
	
		
			
				|  |  | +	anim_speed->set_max(100);
 | 
	
		
			
				|  |  | +	anim_speed->set_step(0.01);
 | 
	
		
			
				|  |  | +	anim_speed->connect("value_changed",this,"_animation_fps_changed");
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +	anim_loop = memnew( CheckButton );
 | 
	
		
			
				|  |  | +	anim_loop->set_text(TTR("Loop"));
 | 
	
		
			
				|  |  | +	vbc_animlist->add_child(anim_loop);
 | 
	
		
			
				|  |  | +	anim_loop->connect("pressed",this,"_animation_loop_changed");
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  |  	VBoxContainer *vbc = memnew( VBoxContainer );
 | 
	
		
			
				|  |  | -	add_child(vbc);
 | 
	
		
			
				|  |  | +	split->add_child(vbc);
 | 
	
		
			
				|  |  | +	vbc->set_h_size_flags(SIZE_EXPAND_FILL);
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +	sub_vb = memnew( VBoxContainer );
 | 
	
		
			
				|  |  | +	vbc->add_margin_child(TTR("Animation Frames"),sub_vb,true);
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |  	HBoxContainer *hbc = memnew( HBoxContainer );
 | 
	
		
			
				|  |  | -	vbc->add_child(hbc);
 | 
	
		
			
				|  |  | +	sub_vb->add_child(hbc);
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +	//animations = memnew( ItemList );
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |  	load = memnew( Button );
 | 
	
		
			
				|  |  |  	load->set_tooltip(TTR("Load Resource"));
 | 
	
		
			
				|  |  |  	hbc->add_child(load);
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  | -
 | 
	
		
			
				|  |  | -
 | 
	
		
			
				|  |  | -
 | 
	
		
			
				|  |  |  	paste = memnew( Button );
 | 
	
		
			
				|  |  |  	paste->set_text(TTR("Paste"));
 | 
	
		
			
				|  |  |  	hbc->add_child(paste);
 | 
	
	
		
			
				|  | @@ -438,15 +816,22 @@ SpriteFramesEditor::SpriteFramesEditor() {
 | 
	
		
			
				|  |  |  	add_child(file);
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  | -	tree = memnew( Tree );
 | 
	
		
			
				|  |  | -	tree->set_columns(2);
 | 
	
		
			
				|  |  | -	tree->set_column_min_width(0,3);
 | 
	
		
			
				|  |  | -	tree->set_column_min_width(1,1);
 | 
	
		
			
				|  |  | -	tree->set_column_expand(0,true);
 | 
	
		
			
				|  |  | -	tree->set_column_expand(1,true);
 | 
	
		
			
				|  |  | +	tree = memnew( ItemList );
 | 
	
		
			
				|  |  |  	tree->set_v_size_flags(SIZE_EXPAND_FILL);
 | 
	
		
			
				|  |  | +	tree->set_icon_mode(ItemList::ICON_MODE_TOP);
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +	int thumbnail_size = 96;
 | 
	
		
			
				|  |  | +	tree->set_max_columns(0);
 | 
	
		
			
				|  |  | +	tree->set_icon_mode(ItemList::ICON_MODE_TOP);
 | 
	
		
			
				|  |  | +	tree->set_fixed_column_width(thumbnail_size*3/2);
 | 
	
		
			
				|  |  | +	tree->set_max_text_lines(2);
 | 
	
		
			
				|  |  | +	tree->set_max_icon_size(Size2(thumbnail_size,thumbnail_size));
 | 
	
		
			
				|  |  | +	//tree->set_min_icon_size(Size2(thumbnail_size,thumbnail_size));
 | 
	
		
			
				|  |  | +	tree->set_drag_forwarding(this);
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  | -	vbc->add_child(tree);
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +	sub_vb->add_child(tree);
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |  	dialog = memnew( AcceptDialog );
 | 
	
		
			
				|  |  |  	add_child( dialog );
 | 
	
	
		
			
				|  | @@ -460,10 +845,14 @@ SpriteFramesEditor::SpriteFramesEditor() {
 | 
	
		
			
				|  |  |  	move_down->connect("pressed", this,"_down_pressed");
 | 
	
		
			
				|  |  |  	file->connect("files_selected", this,"_file_load_request");
 | 
	
		
			
				|  |  |  	//dialog->connect("confirmed", this,"_delete_confirm_pressed");
 | 
	
		
			
				|  |  | -	tree->connect("item_edited", this,"_item_edited");
 | 
	
		
			
				|  |  | +	//tree->connect("item_selected", this,"_item_edited");
 | 
	
		
			
				|  |  |  	loading_scene=false;
 | 
	
		
			
				|  |  |  	sel=-1;
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  | +	updating=false;
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +	edited_anim="default";
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  |  }
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |  
 |