using UnityEngine;
using System.Collections;
using System;
public class CharacterGenerator : MonoBehaviour {
private PlayerCharacter _toon;
private const int START_POINTS = 350;
private const int MIN_STARTING_ATTRIBUTE_VALUE = 10;
private const int STARTING_VALUE = 50;
private int pointsLeft;
private const int OFFSET = 5;
private const int LINE_HEIGHT = 20;
private const int STAT_LABEL_WIDTH = 100;
private const int BASEVALUE_LABEL_WIDTH = 30;
private const int BUTTON_WIDTH = 20;
private const int BUTTON_HEIGHT = 20;
private const int statStartingPos = 40;
public GUISkin mySkin;
public GameObject playerPrefab;
// Use this for initialization
void Start () {
GameObject pc = Instantiate(playerPrefab, Vector3.zero, Quaternion.identity) as GameObject;
pc.name = "pc";
//_toon = new PlayerCharacter();
//_toon.Awake();
_toon = pc.GetComponent<PlayerCharacter>() as PlayerCharacter;
// Set default value to character's basic attribute
pointsLeft = START_POINTS;
for (int cnt = 0; cnt < Enum.GetValues(typeof(AttributeName)).Length; cnt++) {
_toon.GetPrimaryAttribute(cnt).BaseValue = STARTING_VALUE;
pointsLeft -= (STARTING_VALUE - MIN_STARTING_ATTRIBUTE_VALUE);
}
_toon.StatUpdate();
}
// Update is called once per frame
void Update () {
}
// Below is a menu which adjust values of character
void OnGUI () {
GUI.skin = mySkin;
DisplayName();
DisplayPointsLeft();
DisplayAttributes();
DisplayVitals();
DisplaySkills();
if (_toon.Name == "" || pointsLeft > 0)
DisplayCreateLabel();
else
DisplayCreateButton();
}
private void DisplayName () {
GUI.Label(new Rect(10, 10, 50, 25), "Name:");
_toon.Name = GUI.TextField(new Rect(65, 10, 100, 25), _toon.Name);
}
private void DisplayAttributes () {
for (int cnt = 0; cnt < Enum.GetValues(typeof(AttributeName)).Length; cnt++) {
GUI.Label(new Rect( OFFSET, // x
LINE_HEIGHT * cnt + statStartingPos, // y
STAT_LABEL_WIDTH, // width
LINE_HEIGHT // height
), ((AttributeName)cnt).ToString());
GUI.Label(new Rect( STAT_LABEL_WIDTH + OFFSET, // x
LINE_HEIGHT * cnt + statStartingPos, // y
BASEVALUE_LABEL_WIDTH, // width
LINE_HEIGHT // height
), _toon.GetPrimaryAttribute(cnt).AdjustedBaseValue.ToString());
if (GUI.Button(new Rect( STAT_LABEL_WIDTH + OFFSET + BASEVALUE_LABEL_WIDTH, // x
BUTTON_HEIGHT * cnt + statStartingPos, // y
BUTTON_WIDTH, // width
BUTTON_HEIGHT // height
), "-")) {
if (_toon.GetPrimaryAttribute(cnt).BaseValue > MIN_STARTING_ATTRIBUTE_VALUE) {
_toon.GetPrimaryAttribute(cnt).BaseValue--;
pointsLeft++;
_toon.StatUpdate();
}
}
if (GUI.Button(new Rect( STAT_LABEL_WIDTH + OFFSET + BASEVALUE_LABEL_WIDTH + BUTTON_WIDTH, // x
BUTTON_HEIGHT * cnt + statStartingPos, // y
BUTTON_WIDTH, // width
BUTTON_HEIGHT // height
), "+")) {
if (pointsLeft > 0) {
_toon.GetPrimaryAttribute(cnt).BaseValue++;
pointsLeft--;
_toon.StatUpdate();
}
}
}
}
private void DisplayVitals () {
for (int cnt = 0; cnt < Enum.GetValues(typeof(VitalName)).Length; cnt++) {
GUI.Label(new Rect( OFFSET, // x
LINE_HEIGHT * (cnt + 7) + statStartingPos, // y
STAT_LABEL_WIDTH, // width
LINE_HEIGHT // height
), ((VitalName)cnt).ToString());
GUI.Label(new Rect( STAT_LABEL_WIDTH + OFFSET, // x
LINE_HEIGHT * (cnt + 7) + statStartingPos, // y
BASEVALUE_LABEL_WIDTH, // width
LINE_HEIGHT // height
), _toon.GetVital(cnt).AdjustedBaseValue.ToString());
}
}
private void DisplaySkills () {
for (int cnt = 0; cnt < Enum.GetValues(typeof(SkillName)).Length; cnt++) {
GUI.Label(new Rect( STAT_LABEL_WIDTH + OFFSET + BASEVALUE_LABEL_WIDTH + BUTTON_WIDTH * 2 + OFFSET * 2, // x
LINE_HEIGHT * cnt + statStartingPos, // y
STAT_LABEL_WIDTH, // width
LINE_HEIGHT // height
), ((SkillName)cnt).ToString());
GUI.Label(new Rect( STAT_LABEL_WIDTH + OFFSET + BASEVALUE_LABEL_WIDTH + BUTTON_WIDTH * 2 + OFFSET * 2 + STAT_LABEL_WIDTH, // x
LINE_HEIGHT * cnt + statStartingPos, // y
BASEVALUE_LABEL_WIDTH, // width
LINE_HEIGHT // height
), _toon.GetSkill(cnt).AdjustedBaseValue.ToString());
}
}
private void DisplayPointsLeft () {
GUI.Label(new Rect(250, 10, 100, 25), "Points Left: " + pointsLeft.ToString());
}
private void DisplayCreateLabel () {
GUI.Label(new Rect( Screen.width / 2 - 50, // x
LINE_HEIGHT * 10 + statStartingPos, // y
100, // width
LINE_HEIGHT // height
), "Creating...", "Button");
}
private void DisplayCreateButton () {
if (GUI.Button(new Rect( Screen.width / 2 - 50, // x
LINE_HEIGHT * 10 + statStartingPos, // y
100, // width
LINE_HEIGHT // height
), "Create")) {
// Change the cur value of the vitals to the max modified value of that vital
UpdateCurVitalValues();
// Save the character data
GameObject.Find("__GameSettings").GetComponent<GameSettings>().SaveCharacterData();
Application.LoadLevel("Level1"); // "complete-10" is "Targetting Example" in video
}
}
private void UpdateCurVitalValues () {
for (int cnt = 0; cnt < Enum.GetValues(typeof(VitalName)).Length; cnt++) {
_toon.GetVital(cnt).CurValue = _toon.GetVital(cnt).AdjustedBaseValue;
}
}
}
分享到:
相关推荐
角色生成器 这个项目是一个实验,测试了建立框架以进行全面索引和比较扩展的3.5 D&D类(包括所有资料集)的复杂性。 该框架最终将变得相对简单,但是文本数据的输入将需要手动且大量地完成。 可以判断,完成此项目...
19. chargen(CharacterGenerator):是一种字符发生器服务,用于生成随机字符。 20. ftp-data(FileTransfer[DefaultData]):是一种文件传输协议(默认数据口),用于传输文件数据。 21. ftp(FileTransfer...
Eos Chargen 荷兰科幻小说角色生成器,编辑和工作表。 该项目已于2018年1月17日开始,目的是创建一个数字化,易于阅读,易于填写的字符表。 在线镜像: (!不同步到git!...原始待办事项选择并设置技能的表格。...
摇滚乐D&D角色生成器该字符表生成器旨在简化构建第一个龙与地下城角色的过程。 它会将《手册》中的大量信息缩小为关键要素,从而使您在第1级起步并开始工作。 经验丰富的玩家也可以使用此工具来建立一个单发角色,...
- 关闭7.9端口:这涉及到SimpleTCP/IPService,该服务支持CharacterGenerator、Daytime、Discard、Echo和QuoteoftheDay等TCP/IP服务。 - 关闭80端口:需要停止"WorldWideWebPublishingService",这将禁用Web服务。...
8. **19=CharacterGenerator**:字符生成器,连续发送ASCII字符,主要用于测试和调试网络设备。 9. **20=FTP(Data)**、**21=FTP(Control)**:FTP(文件传输协议)的数据和控制端口,分别用于实际数据传输和命令控制...
- **服务**:CharacterGenerator - **说明**:chargen服务用于发送随机字符流。通过UDP版本的chargen服务,接收到UDP包后会返回含有随机字符的数据包;通过TCP版本的chargen服务,则会持续发送随机字符直至连接关闭...
* 关闭 7.9 等端口:关闭 Simple TCP/IP Service,支持以下 TCP/IP 服务:CharacterGenerator, Daytime, Discard, Echo, 以及 Quote of the Day。 * 关闭 80 端口:关掉 WWW 服务。在“服务”中显示名称为“World ...
- **服务**:CharacterGenerator - **说明**:端口19用于提供chargen服务,该服务主要负责生成连续的ASCII字符流。对于TCP版本的chargen服务,会在收到TCP包后返回含有随机字符的响应;对于UDP版本,它则会不断地...
CharacterGenerator服务主要用于生成连续的字符流,本意是网络测试和诊断工具,但其UDP版本可能被黑客用于发起DoS攻击,通过伪造chargen服务器间的UDP包,造成网络拥塞或资源耗尽。 #### 端口21:FTP FTP(文件...
#### 端口19 - CharacterGenerator (chargen) chargen服务主要用于生成连续的字符流,TCP版本会在收到数据包后返回包含随机字符的响应,而UDP版本则持续发送直到连接终止。黑客可以利用此端口发起DoS攻击或Fraggle...