功能预览

使用说明

1、把 DebugConsole.cs 放在 Standard Assets 目录下(重要)

2、如果你想修改 DebugConsole的一些参数,把DebugConsole.cs拖给一个GameObject,在属性面板修改属性。

属性解释

    • Debug GUI : Drag the guiText you created here if you wish to override the default.
    • defaultGuiPosition : A vector for the starting position of the first line of output. If you provide your own GUIText then it's position overrides this property.
    • defaultGuiScale : A vector for the scale of the individual lines. Again, this is overridden if you provide your own GUIText.
    • The three colors : are for normal, warning, and error. Set to whatever you like or leave alone.
    • Max messages : How many message lines we will put on the screen at once.
    • Line Spacing : A float for how far down we will move each new line.
    • Draggable : True means you can drag the output around with the mouse at runtime, false means position is locked from mouse input. To drag output at runtime, click once on the uppermost output line to connect it to the mouse, then move to where you want the output displayed and click the mouse again to release it.
    • Visible : The default setting for visibility of the debug output. If set to false (unchecked), you can send data but it wont show until you tell it to, if set to true (checked) it will show all debug output until you tell it not to.
    • PixelCorrect : If set to true and LineSpacing to be on-screen pixels or not, very much like the GUIText property of the same name. Default: false LineSpacing will be in screen coordinates (0.0 - 1.0)

类方法

Log (string message, string color)

  • Adds a message to the list. The color is a string either "normal", "warning" or "error". The color argument is optional and if omitted, the color will default to "normal".

Clear()

  • Clears all of the messages from the list and the screen.

To toggle the visibility use:isVisible (true, false)

  • The property to set the visiblility of the debug output. This property _not_ clear the message list, just hides it. You need to use the Clear() method to clear the list.

To toggle the mouse drag functionality use:isDraggable (true, false)

So for a simple example, to add hello world in warning color (yellow), we type: DebugConsole.Log("hello world", "warning");

To hide the output we type: DebugConsole.isVisible = false;

UseDebugConsole.cs

using UnityEngine;
using System.Collections; public class UseDebugConsole : MonoBehaviour
{ // Use this for initialization
void Start()
{
DebugConsole.Log("use debugconsole normal");
DebugConsole.Log("use debugconsole warning", "warning");
DebugConsole.Log("use debugconsole error", "error");
} void OnGUI()
{
//开始区域
GUILayout.BeginArea(new Rect(200,10,100,200));
if (GUILayout.Button("Clean"))
{
DebugConsole.Clear();
}
if (GUILayout.Button("My Print"))
{
DebugConsole.Log("My Print");
}
if (GUILayout.Button("isVisible"))
{
DebugConsole.isVisible = !DebugConsole.isVisible;
}
if (GUILayout.Button("isDraggable"))
{
DebugConsole.isDraggable = !DebugConsole.isDraggable;
}
GUILayout.EndArea();
}
}

DebugConsole.cs

/*==== DebugConsole.cs ====================================================
* Class for handling multi-line, multi-color debugging messages.
* Original Author: Jeremy Hollingsworth
* Based On: Version 1.2.1 Mar 02, 2006
*
* Modified: Simon Waite
* Date: 22 Feb 2007
*
* Modification to original script to allow pixel-correct line spacing
*
* Setting the boolean pixelCorrect changes the units in lineSpacing property
* to pixels, so you have a pixel correct gui font in your console.
*
* It also checks every frame if the screen is resized to make sure the
* line spacing is correct (To see this; drag and let go in the editor
* and the text spacing will snap back)
*
* USAGE:
* ::Drop in your standard assets folder (if you want to change any of the
* default settings in the inspector, create an empty GameObject and attach
* this script to it from you standard assets folder. That will provide
* access to the default settings in the inspector)
*
* ::To use, call DebugConsole.functionOrProperty() where
* functionOrProperty = one of the following:
*
* -Log(string message, string color) Adds "message" to the list with the
* "color" color. Color is optional and can be any of the following: "error",
* "warning", or "normal". Default is normal.
*
* Clear() Clears all messages
*
* isVisible (true,false) Toggles the visibility of the output. Does _not_
* clear the messages.
*
* isDraggable (true, false) Toggles mouse drag functionality
* =========================================================================*/ using UnityEngine;
using System.Collections; public class DebugConsole : MonoBehaviour
{
public GameObject DebugGui = null; // The GUI that will be duplicated
public Vector3 defaultGuiPosition = new Vector3(0.01F, 0.98F, 0F);
public Vector3 defaultGuiScale = new Vector3(0.5F, 0.5F, 1F);
public Color normal = Color.green;
public Color warning = Color.yellow;
public Color error = Color.red;
public int maxMessages = 30; // The max number of messages displayed
public float lineSpacing = 0.02F; // The amount of space between lines
public ArrayList messages = new ArrayList();
public ArrayList guis = new ArrayList();
public ArrayList colors = new ArrayList();
public bool draggable = true; // Can the output be dragged around at runtime by default?
public bool visible = true; // Does output show on screen by default or do we have to enable it with code?
public bool pixelCorrect = false; // set to be pixel Correct linespacing
public static bool isVisible
{
get
{
return DebugConsole.instance.visible;
} set
{
DebugConsole.instance.visible = value;
if (value == true)
{
DebugConsole.instance.Display();
}
else if (value == false)
{
DebugConsole.instance.ClearScreen();
}
}
} public static bool isDraggable
{
get
{
return DebugConsole.instance.draggable;
} set
{
DebugConsole.instance.draggable = value; }
} private static DebugConsole s_Instance = null; // Our instance to allow this script to be called without a direct connection.
public static DebugConsole instance
{
get
{
if (s_Instance == null)
{
s_Instance = FindObjectOfType(typeof(DebugConsole)) as DebugConsole;
if (s_Instance == null)
{
GameObject console = new GameObject();
console.AddComponent("DebugConsole");
console.name = "DebugConsoleController";
s_Instance = FindObjectOfType(typeof(DebugConsole)) as DebugConsole;
DebugConsole.instance.InitGuis();
} } return s_Instance;
}
} void Awake()
{
s_Instance = this;
InitGuis(); } protected bool guisCreated = false;
protected float screenHeight = -1;
public void InitGuis()
{
float usedLineSpacing = lineSpacing;
screenHeight = Screen.height;
if (pixelCorrect)
usedLineSpacing = 1.0F / screenHeight * usedLineSpacing; if (guisCreated == false)
{
if (DebugGui == null) // If an external GUIText is not set, provide the default GUIText
{
DebugGui = new GameObject();
DebugGui.AddComponent("GUIText");
DebugGui.name = "DebugGUI(0)";
DebugGui.transform.position = defaultGuiPosition;
DebugGui.transform.localScale = defaultGuiScale;
} // Create our GUI objects to our maxMessages count
Vector3 position = DebugGui.transform.position;
guis.Add(DebugGui);
int x = 1; while (x < maxMessages)
{
position.y -= usedLineSpacing;
GameObject clone = null;
clone = (GameObject)Instantiate(DebugGui, position, transform.rotation);
clone.name = string.Format("DebugGUI({0})", x);
guis.Add(clone);
position = clone.transform.position;
x += 1;
} x = 0;
while (x < guis.Count)
{
GameObject temp = (GameObject)guis[x];
temp.transform.parent = DebugGui.transform;
x++;
}
guisCreated = true;
}
else
{
// we're called on a screensize change, so fiddle with sizes
Vector3 position = DebugGui.transform.position;
for (int x = 0; x < guis.Count; x++)
{
position.y -= usedLineSpacing;
GameObject temp = (GameObject)guis[x];
temp.transform.position = position;
}
}
} bool connectedToMouse = false;
void Update()
{
// If we are visible and the screenHeight has changed, reset linespacing
if (visible == true && screenHeight != Screen.height)
{
InitGuis();
}
if (draggable == true)
{
if (Input.GetMouseButtonDown(0))
{
if (connectedToMouse == false && DebugGui.guiText.HitTest((Vector3)Input.mousePosition) == true)
{
connectedToMouse = true;
}
else if (connectedToMouse == true)
{
connectedToMouse = false;
} } if (connectedToMouse == true)
{
float posX = DebugGui.transform.position.x;
float posY = DebugGui.transform.position.y;
posX = Input.mousePosition.x / Screen.width;
posY = Input.mousePosition.y / Screen.height;
DebugGui.transform.position = new Vector3(posX, posY, 0F);
}
} }
//+++++++++ INTERFACE FUNCTIONS ++++++++++++++++++++++++++++++++
public static void Log(string message, string color)
{
DebugConsole.instance.AddMessage(message, color); }
//++++ OVERLOAD ++++
public static void Log(string message)
{
DebugConsole.instance.AddMessage(message);
} public static void Clear()
{
DebugConsole.instance.ClearMessages();
}
//++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ //---------- void AddMesage(string message, string color) ------
//Adds a mesage to the list
//-------------------------------------------------------------- public void AddMessage(string message, string color)
{
messages.Add(message);
colors.Add(color);
Display();
}
//++++++++++ OVERLOAD for AddMessage ++++++++++++++++++++++++++++
// Overloads AddMessage to only require one argument(message)
//+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
public void AddMessage(string message)
{
messages.Add(message);
colors.Add("normal");
Display();
} //----------- void ClearMessages() ------------------------------
// Clears the messages from the screen and the lists
//---------------------------------------------------------------
public void ClearMessages()
{
messages.Clear();
colors.Clear();
ClearScreen();
} //-------- void ClearScreen() ----------------------------------
// Clears all output from all GUI objects
//--------------------------------------------------------------
void ClearScreen()
{
if (guis.Count < maxMessages)
{
//do nothing as we haven't created our guis yet
}
else
{
int x = 0;
while (x < guis.Count)
{
GameObject gui = (GameObject)guis[x];
gui.guiText.text = "";
//increment and loop
x += 1;
}
}
} //---------- void Prune() ---------------------------------------
// Prunes the array to fit within the maxMessages limit
//---------------------------------------------------------------
void Prune()
{
int diff;
if (messages.Count > maxMessages)
{
if (messages.Count <= 0)
{
diff = 0;
}
else
{
diff = messages.Count - maxMessages;
}
messages.RemoveRange(0, (int)diff);
colors.RemoveRange(0, (int)diff);
} } //---------- void Display() -------------------------------------
// Displays the list and handles coloring
//---------------------------------------------------------------
void Display()
{
//check if we are set to display
if (visible == false)
{
ClearScreen();
}
else if (visible == true)
{ if (messages.Count > maxMessages)
{
Prune();
} // Carry on with display
int x = 0;
if (guis.Count < maxMessages)
{
//do nothing as we havent created our guis yet
}
else
{
while (x < messages.Count)
{
GameObject gui = (GameObject)guis[x]; //set our color
switch ((string)colors[x])
{
case "normal": gui.guiText.material.color = normal;
break;
case "warning": gui.guiText.material.color = warning;
break;
case "error": gui.guiText.material.color = error;
break;
} //now set the text for this element
gui.guiText.text = (string)messages[x]; //increment and loop
x += 1;
}
} }
} }// End DebugConsole Class

wiki地址

http://wiki.unity3d.com/index.php/DebugConsole

最新文章

  1. CSS:CSS样式表及选择器优先级总结
  2. 终于解决各种动画问题了,感谢雨松MOMO
  3. Linux 配置只安装 64 位软件包
  4. HTML5 &lt;meta&gt; 标签属性,所有meta用法都在这里了
  5. 什么是ajax,ajax原理是什么 ,优缺点是什么
  6. Daily Scrum 11.6
  7. Java基础知识强化之IO流笔记54:IO流练习之 LineNumberReader的特有的功能使用
  8. 【Android - 框架】之MVP模式的使用
  9. jquery数字验证大小比较
  10. DICOM医学图像处理:开源库mDCM与DCMTK的比較分析(一),JPEG无损压缩DCM图像
  11. 大约cocos2d-X 3.x使用引擎版本自带的物理引擎Physics
  12. Plotting trees from Random Forest models with ggraph
  13. DDD理论学习系列(4)-- 领域模型
  14. 关于百度DNS的解析过程
  15. 需求分析&amp;原型设计
  16. Docker最全教程——数据库容器化(十)
  17. 调整Eclipse中代码字体字号
  18. Immuable详解以及在React中的实战
  19. java之httpClient 3.x、AsyncHttpClient1.9.x使用总结
  20. react 使用 redux 的时候 用 ref获取子组件的state

热门文章

  1. Android Xutils 框架(转)
  2. SharePoint 2013 创建搜索中心及搜索设置
  3. How to Use Telnet to Test SMTP Communication
  4. This task is currently locked by a running workflow and cannot be edited
  5. Android WelcomeActivity 启动画更换网络图片
  6. IOS 网络浅析-(三 NSURLConnection代理)
  7. 饭团(1):用NABCD大法为项目奠基
  8. 我已看过的TVB剧集目录(陆续更新)
  9. Openstack python api 学习文档 api创建虚拟机
  10. java使用this关键字调用本类重载构造器