89 lines
		
	
	
		
			3.5 KiB
		
	
	
	
		
			C#
		
	
	
	
	
	
		
		
			
		
	
	
			89 lines
		
	
	
		
			3.5 KiB
		
	
	
	
		
			C#
		
	
	
	
	
	
|   | // Copyright (c) Pixel Crushers. All rights reserved. | |||
|  | 
 | |||
|  | using UnityEngine; | |||
|  | 
 | |||
|  | namespace PixelCrushers.DialogueSystem | |||
|  | { | |||
|  | 
 | |||
|  |     /// <summary> | |||
|  |     /// When you attach this script to an actor, conversations involving that actor will be | |||
|  |     /// logged to the console. | |||
|  |     /// </summary> | |||
|  |     [AddComponentMenu("")] // Use wrapper. | |||
|  |     public class ConversationLogger : MonoBehaviour | |||
|  |     { | |||
|  | 
 | |||
|  |         [Tooltip("Log player lines in this color.")] | |||
|  |         public Color playerColor = Color.blue; | |||
|  | 
 | |||
|  |         [Tooltip("Log NPC lines in this color.")] | |||
|  |         public Color npcColor = Color.red; | |||
|  | 
 | |||
|  |         public void OnConversationStart(Transform actor) | |||
|  |         { | |||
|  |             Debug.Log(string.Format("{0}: Starting conversation with {1}", new object[] { name, GetActorName(actor) })); | |||
|  |         } | |||
|  | 
 | |||
|  |         public void OnConversationLine(Subtitle subtitle) | |||
|  |         { | |||
|  |             if (subtitle == null | subtitle.formattedText == null | string.IsNullOrEmpty(subtitle.formattedText.text)) return; | |||
|  |             string speakerName = (subtitle.speakerInfo != null && subtitle.speakerInfo.transform != null) ? subtitle.speakerInfo.transform.name : "(null speaker)"; | |||
|  |             Debug.Log(string.Format("<color={0}>{1}: {2}</color>", new object[] { GetActorColor(subtitle), speakerName, subtitle.formattedText.text })); | |||
|  |         } | |||
|  | 
 | |||
|  |         public void OnConversationEnd(Transform actor) | |||
|  |         { | |||
|  |             Debug.Log(string.Format("{0}: Ending conversation with {1}", name, GetActorName(actor))); | |||
|  |         } | |||
|  | 
 | |||
|  |         private string GetActorName(Transform actor) | |||
|  |         { | |||
|  |             return (actor != null) ? actor.name : "(null transform)"; | |||
|  |         } | |||
|  | 
 | |||
|  |         private string GetActorColor(Subtitle subtitle) | |||
|  |         { | |||
|  |             if (subtitle == null | subtitle.speakerInfo == null) return "white"; | |||
|  |             return Tools.ToWebColor(subtitle.speakerInfo.isPlayer ? playerColor : npcColor); | |||
|  |         } | |||
|  | 
 | |||
|  | 
 | |||
|  |         public void OnPrepareConversationLine(DialogueEntry entry) | |||
|  |         { | |||
|  |             if (entry == null) return; | |||
|  |             Debug.Log(string.Format("Preparing line {0}", entry.currentDialogueText)); | |||
|  |         } | |||
|  | 
 | |||
|  |         public void OnConversationLineCancelled(Subtitle subtitle) | |||
|  |         { | |||
|  |             if (subtitle == null | subtitle.formattedText == null | string.IsNullOrEmpty(subtitle.formattedText.text)) return; | |||
|  |             string speakerName = (subtitle.speakerInfo != null && subtitle.speakerInfo.transform != null) ? subtitle.speakerInfo.transform.name : "(null speaker)"; | |||
|  |             Debug.Log(string.Format("<color={0}>Line cancelled - {1}: {2}</color>", new object[] { GetActorColor(subtitle), speakerName, subtitle.formattedText.text })); | |||
|  |         } | |||
|  | 
 | |||
|  |         public void OnConversationLineEnd(Subtitle subtitle) | |||
|  |         { | |||
|  |             if (subtitle == null | subtitle.formattedText == null | string.IsNullOrEmpty(subtitle.formattedText.text)) return; | |||
|  |             string speakerName = (subtitle.speakerInfo != null && subtitle.speakerInfo.transform != null) ? subtitle.speakerInfo.transform.name : "(null speaker)"; | |||
|  |             Debug.Log(string.Format("<color={0}>Line ended - {1}: {2}</color>", new object[] { GetActorColor(subtitle), speakerName, subtitle.formattedText.text })); | |||
|  |         } | |||
|  | 
 | |||
|  |         public void OnConversationResponseMenu(Response[] responses) | |||
|  |         { | |||
|  |             Debug.Log("Showing conversation response menu."); | |||
|  |         } | |||
|  | 
 | |||
|  |         public void OnConversationTimeout() | |||
|  |         { | |||
|  |             Debug.Log("Conversation timed out."); | |||
|  |         } | |||
|  | 
 | |||
|  |         public void OnLinkedConversationStart(Transform actor) | |||
|  |         { | |||
|  |             Debug.Log("Starting linked conversation."); | |||
|  |         } | |||
|  | 
 | |||
|  |     } | |||
|  | 
 | |||
|  | } |