2016. 2. 22. 05:40

간단하게 할수 있습니다.



1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
using UnityEngine;
using System.Collections;
using System;
using System.Net;
using System.Net.Mail;
using System.Net.Security;
using System.Security.Cryptography.X509Certificates;
 
public class mono_gmail : MonoBehaviour
{
        void Main ()
        {
            MailMessage mail = new MailMessage();
             
            mail.From = new MailAddress("youraddress@gmail.com");
            mail.To.Add("youraddress@gmail.com");
            mail.Subject = "Test Mail";
            mail.Body = "This is for testing SMTP mail from GMAIL";
            SmtpClient smtpServer = new SmtpClient("smtp.gmail.com");      
            smtpServer.Port = 587;
            smtpServer.Credentials = new System.Net.NetworkCredential("youraddress@gmail.com""yourpassword"as ICredentialsByHost;
            smtpServer.EnableSsl = true;
            ServicePointManager.ServerCertificateValidationCallback = delegate(object s, X509Certificate certificate, X509Chain chain, SslPolicyErrors sslPolicyErrors) 
            {
             return true
            };
            smtpServer.Send(mail); 
            Debug.Log("success");   
       }
}
 
 
cs



또한 파일을 첨부해서 보낸다면


1
2
3
4
5
 
                System.Net.Mail.Attachment attachment;  
                attachment = new System.Net.Mail.Attachment("D:\\temp\\file.txt");  
                  
                mail.Attachments.Add(attachment);
cs

위와

위와같은 코드를 추가하면 됩니다.


Posted by 시리시안

댓글을 달아 주세요

2016. 2. 22. 05:36

참고 링크 https://en.wikipedia.org/wiki/STL_(file_format)


ASCII STL[edit]

An ASCII STL file begins with the line

solid name

where name is an optional string (though if name is omitted there must still be a space after solid). The file continues with any number of triangles, each represented as follows:

facet normal ni nj nk    outer loop        vertex v1<sub style="line-height: 1; font-size: 11.2px;">x</sub> v1<sub style="line-height: 1; font-size: 11.2px;">y</sub> v1<sub style="line-height: 1; font-size: 11.2px;">z</sub>        vertex v2<sub style="line-height: 1; font-size: 11.2px;">x</sub> v2<sub style="line-height: 1; font-size: 11.2px;">y</sub> v2<sub style="line-height: 1; font-size: 11.2px;">z</sub>        vertex v3<sub style="line-height: 1; font-size: 11.2px;">x</sub> v3<sub style="line-height: 1; font-size: 11.2px;">y</sub> v3<sub style="line-height: 1; font-size: 11.2px;">z</sub>    endloopendfacet

where each n or v is a floating-point number in sign-mantissa-"e"-sign-exponent format, e.g., "2.648000e-002" (noting that each v must be non-negative). The file concludes with

endsolid name

The structure of the format suggests that other possibilities exist (e.g., facets with more than one "loop", or loops with more than three vertices). In practice, however, all facets are simple triangles.

White space (spaces, tabs, newlines) may be used anywhere in the file except within numbers or words. The spaces between "facet" and "normal" and between "outer" and "loop" are required.[6]

 

위와 같이 아스키코드로 제작 하였습니다.



1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
public void ModelSaveToSTL()
    {
        List<Vector3> _Vertex = new List<Vector3>();
        List<Vector3> _Nomal = new List<Vector3>();
        StreamWriter sw = new StreamWriter(pathForDocumentsFile("sample.stl"));
        List<GameObject> _ObjectList = GameObject.FindGameObjectWithTag("Manager").GetComponent<ObjectManager>().Objects;
        sw.WriteLine("solid ModelSTL");     //Model Name
 
        int index = 0;
        foreach (GameObject G in _ObjectList)
        {
            foreach (int _tri in G.GetComponent<MeshFilter>().mesh.triangles)
            {
                _Vertex.Add(G.GetComponent<MeshFilter>().mesh.vertices[_tri] + G.transform.position);
                _Nomal.Add(G.GetComponent<MeshFilter>().mesh.normals[_tri]);
            }
            index += G.GetComponent<MeshFilter>().mesh.triangles.Length/3;
        }
        sw.WriteLine(index.ToString());
        int Nomalcount = 0;
        int Vertexcount = 0;
        for (int i = 0; i < index; i++)
        {
            Vector3 Vt = ((_Nomal[Nomalcount+++ _Nomal[Nomalcount+++ _Nomal[Nomalcount++]) / 3.0f);
            sw.WriteLine("facet normal "+
                Vt.x.ToString() + " " +
                Vt.y.ToString() + " " +
                Vt.z.ToString()
                );  // Nomal
            sw.WriteLine("outer loop"); 
            sw.WriteLine("vertex " +
                _Vertex[Vertexcount].x.ToString() + " " +
                _Vertex[Vertexcount].y.ToString() + " " +
                _Vertex[Vertexcount].z.ToString()
                );  //Vertex01
            Vertexcount++;
            sw.WriteLine("vertex " +
                _Vertex[Vertexcount].x.ToString() + " " +
                _Vertex[Vertexcount].y.ToString() + " " +
                _Vertex[Vertexcount].z.ToString()
                ); //Vertex02
            Vertexcount++;
            sw.WriteLine("vertex " +
                _Vertex[Vertexcount].x.ToString() + " " +
                _Vertex[Vertexcount].y.ToString() + " " +
                _Vertex[Vertexcount].z.ToString()
                ); //Vertex03
            Vertexcount++;
            sw.WriteLine("endloop"); 
            sw.WriteLine("endfacet"); 
        }
        sw.WriteLine("endsolid ModelSTL"); 
        sw.Flush(); 
        sw.Close();
        Debug.Log("저장 완료");
    }
 
cs


직접 저장해보고 STL 뷰어로 확인하니 이상없었습니다.

Posted by 시리시안

댓글을 달아 주세요

2016. 2. 22. 05:34
1
2
3
4
5
6
7
8
    Transform CameraTransform = Camera.main.transform;
      Vector3 forwardVector3 = CameraTransform.forward;
        forwardVector3.y = 0//y를 0으로
        forwardVector3.Normalize();
        //노말라이즈된 Forward 벡터를 구한다.
 
        //-X값과 Z값을 바꿔서 오른쪽 벡터를 구한다.
        Vector3 RightVector3 = new Vector3(forwardVector3.z, 0-forwardVector3.x);
cs


Posted by 시리시안

댓글을 달아 주세요

2016. 2. 22. 05:34

Editor
- Application.dataPath /*project*/Assets


Web Player

 System.IO.Path.GetFullPath(".")

 %Project%

 Application.dataPath

 %Project%/Assets

 Application.persistentDataPath

 %userprofile%\AppData\LocalLow/%Company%/%Product%

 Application.streamingAssetsPath

 %Project%/Assets/StreamingAssets

 Application.temporaryCachePath

 %LocalAppData%/Local/Temp/Temp/%Company%/%Product%



Android

 System.IO.Path.GetFullPath(".")

 /

 Application.dataPath

 /data/app/%BundleIdentifier%.apk

 Application.persistentDataPath

 /data/data/%BundleIdentifier%/files

 Application.streamingAssetsPath

 jar:file:///data/app/%BundleIdentifier%.apk/!/assets

 Application.temporaryCachePath

 /data/data/%BundleIdentifier%/cache


Android sdcard

 Application.persistentDataPath

 /mnt/sdcard/Android/data/%BundleIdentifier%/files

 Application.streamingAssetsPath

 jar:file:///data/app/%BundleIdentifier%.apk/!/assets

 Application.temporaryCachePathz

 /mnt/sdcard/Android/data/%BundleIdentifier%/cache


iOS

 System.IO.Path.GetFullPath(".")

 /

 Application.dataPath

 %ProvisioningProfile%/%BundleIdentifier%.app/Data

 Application.persistentDataPath

 %ProvisioningProfile%/Documents

 Application.streamingAssetsPath

 %ProvisioningProfile%/%BundleIdentifier%.app/Data/Raw

 Application.temporaryCachePath

 %ProvisioningProfile%/Library/Caches


// ** iPhone device
- Application.dataPath /var/mobile/Applications/XXXXXXXX-XXXX-XXXX-XXXX-XXXXXXXXXXXX/Assets
- Application.persistentDataPath : /var/mobile/Applications/XXXXXXXX-XXXX-XXXX-XXXX-XXXXXXXXXXXX/Documents
- Application.temporaryCachePath : /var/mobile/Applications/XXXXXXXX-XXXX-XXXX-XXXX-XXXXXXXXXXXX/Library/Caches
- iPhpone Simulator Path : /Users/<Name>/Library/Application Support/iPhone Simulator/4.1/Applications/<GUID>/
 
// ** Android
- Application.dataPath /mnt/asec/com.xxx.xxx/pkg.apk
- Application.persistentDataPath /data/data/com.xxx.xxx/files/
- Application.temporaryCachePath /data/data/com.xxx.xxx/cache/
* sdcard 사용시.
- Application.persistentDataPath /mnt/sdcard/Android/data/com.xxx.xxx/files/
- Application.temporaryCachePath /mnt/sdcard/Android/data/com.xxx.xxx/cache/



출처 : 

ttp://topgames.tistory.com/entry/%EC%9C%A0%EB%8B%88%ED%8B%B0-%ED%94%8C%EB%9E%AB%ED%8F%BC%EB%B3%84-%EA%B2%BD%EB%A1%9C%EB%93%A4

Posted by 시리시안

댓글을 달아 주세요

2016. 2. 22. 05:32

파일 입출력 기본 방법


StreamWriter 클래스의 WriteLine 함수를 사용하여 파일에 데이터를 쓸 수 있습니다.

StreamReader 클래스의 ReadLine 함수를 사용하여 파일로부터 데이터를 읽어올 수 있습니다.


1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
 using System.IO; // 파일 입출력 함수를 사용하기 위해 스크립트에 포함시킨다.
 
// 파일에 쓰기
void WriteFile( String filepathIncludingFileName )
{
    StreamWriter sw = new StreamWriter( filepathIncludingFileName );
    sw.WriteLine("Line to write"); // 줄단위로 파일에 입력
    sw.WriteLine("Another Line");
    sw.Flush(); // 파일 쓰기 반드시 해준다.
    sw.Close(); // 파일 쓰기 반드시 해준다.
}
 
 
// 파일로 부터 읽기
void ReadFile( String filepathIncludingFileName)
{
    StreamReader sr = new File.OpenText(filepathIncludingFileName);
 
    input = "";
    // 파일을 줄단위로 읽는다.
    while (true)
        {
        input = sr.ReadLine();
        if (input == null) { break; }
        Debug.Log("line="+input);
    }
    sr.Close(); // 파일 읽기후 반드시 해준다.
}
cs


Posted by 시리시안

댓글을 달아 주세요

2016. 2. 22. 05:30

this post shows asimple tutorial to do some basic operations with xml file on Unity3D using C#.

How to load?

Put an XML file on Resources folder and load itwith Resources class from Unity3D
xml sample:

<achievement>

 <uniqueid>0</uniqueid>

 <referencename>MyAchievement</referencename>

 <goal>Solve until 10seconds</goal>

 <points>10</points>

</achievement>

 

using UnityEngine;

using System.Collections;

using System.Xml;

 

 

public class XMLEditor : MonoBehaviour

{

 

   void Awake()

    {

       //Load

       TextAsset textXML = (TextAsset)Resources.Load("myxml.xml",typeof(TextAsset));

       XmlDocument xml = new XmlDocument();

       xml.LoadXml(textXML.text);

    }

}

Yeah! Using a TextAsset you can make it very simply!

How to read?

Pretty simple! Use .NET framework, XmlDocumentwill turn you live more easy.

using UnityEngine;

using System.Collections;

using System.Xml;

 

 

public class XMLEditor : MonoBehaviour

{

   void Awake()

    {

       //Load

       TextAsset textXML = (TextAsset)Resources.Load("myxml.xml",typeof(TextAsset));

       XmlDocument xml = new XmlDocument();

       xml.LoadXml(textXML.text);

 

       //Read

       XmlNode root = xml.FirstChild;

       foreach(XmlNode node in root.ChildNodes)

       {

           if (node.FirstChild.NodeType == XmlNodeType.Text)

                Debug.Log(node.InnerText);

       }

    }

}


Ok, but if there are multiplehierarchies you will must implement your own ReadMethod to do that bynavigating for all nodes.

How to save?

using UnityEngine;

using System.Collections;

using System.Xml;

 

 

public class XMLEditor : MonoBehaviour

{

   void Awake()

    {

       //Load

       TextAsset textXML = (TextAsset)Resources.Load("myxml.xml",typeof(TextAsset));

       XmlDocument xml = new XmlDocument();

       xml.LoadXml(textXML.text);

 

       //Read

       XmlNode root = xml.FirstChild;

        foreach(XmlNode node in root.ChildNodes)

       {

           if (node.FirstChild.NodeType == XmlNodeType.Text)

                node.InnerText ="none";

       }

 

       //Simple Save

       xml.Save(AssetDatabase.GetAssetPath(textXML));

    }

}

The easy way! :)



출처 : http://fernandogamedev-en.blogspot.kr/2012/09/how-to-load-read-and-save-xml-on-unity3d.html

Posted by 시리시안

댓글을 달아 주세요

2016. 2. 22. 05:29
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
 
void MultiTouch()
{
    //현재 터치 개수를 받아온다 
    int touchCount = Input.touchCount; 
    //터치 Begin에서 터치 개수가 2개면 두 점의 거리를 계산한다. 
    if( touchCount == 2 ) 
       m_OldTouchDistance = Vector2.Distance( Input.touches[0].position, Input.touches[1].position ); 
    
    //계속 거리를 계산해서 거리가 짧아지면 줌인, 거리가 멀어지면 줌아웃 한다. 이전 거리 갱신한다. 
    m_NowTouchDistance= Vector2.Distance( Input.touches[0].position, Input.touches[1].position ); 
    if( m_NowTouchDistance > m_OldTouchDistance ) 
        ZoomOut(); 
    else if( m_NowTouchDistance < m_OldTouchDistance ) 
        ZoomIn(); 
    m_OldTouchDistance = m_NowTouchDistance;     
}
// 이곳에서 줌인 줌아웃을 구현합니다.
void ZoomOut() 
void ZoomIn() 
 
cs


Posted by 시리시안

댓글을 달아 주세요

2016. 2. 22. 05:18

플랫폼 의존 컴파일

Unity는 “플랫폼 의존 컴파일”이라는 기능이 있습니다. 여기에는 몇 가지 전 처리기 지시문이 포함되어, 스크립트를 ’파티션화’하여 코드의 일부 섹션을 지원하는 하나의 플랫폼 독점적으로 실행할 수 있게 됩니다.

또한 코드를 에디터 내에서 실행할 수 있기 때문에, 코드를 모바일/콘솔에 대해 컴파일 한 후 에디터에서 테스트할 수 있습니다.

플랫폼 매크로 정의

Unity 스크립트에서 지원하는 플랫폼 매크로 정의 :

프로퍼티:기능:
UNITY_EDITORUnity 스크립트에서 지원하는 플랫폼 매크로 정의 :
UNITY_EDITOR_WINWindows에서의 플랫폼 정의 에디터 코드.
UNITY_EDITOR_OSXMac OSX에서의 플랫폼 정의 에디터 코드.
UNITY_STANDALONE_OSXMac OS (Univeral, PPC 및 Intel 아키텍처 포함) 의 코드 컴파일 / 실행을 위한 플랫폼 매크로 정의.
UNITY_STANDALONE_WINWindows 독립 실행형 응용 프로그램 코드를 컴파일 / 실행하고 싶을 때 사용합니다.
UNITY_STANDALONE_LINUXLinux 독립 실행형 응용 프로그램 코드를 컴파일 / 실행하고 싶을 때 사용합니다.
UNITY_STANDALONE모든 독립 실행형 응용 프로그램(Mac, Windows 또는 Linux)의 코드를 컴파일 / 실행하고 싶을 때 사용합니다.
UNITY_WEBPLAYERWeb Player 콘텐츠(Windows 및 Mac Web Player 실행 파일을 포함합니다) 플랫폼 매크로 정의.
UNITY_WIIWii 콘솔 코드 컴파일 / 실행을 위한 플랫폼 매크로 정의.
UNITY_IOSiOS 플랫폼에서 코드 컴파일/실행을 위한 플랫폼 매크로 정의
UNITY_IPHONEDeprecated. Use UNITY_IOS instead.
UNITY_ANDROIDAndroid 플랫폼의 플랫폼 매크로 정의.
UNITY_PS3PlayStation 3에서 코드 컴파일 / 실행을 위한 플랫폼 매크로 정의.
UNITY_PS4PlayStation 4에서 코드 컴파일 / 실행을 위한 플랫폼 매크로 정의.
UNITY_XBOX360XBox 360 코드의 컴파일 / 실행을 위한 플랫폼 매크로 정의.
UNITY_XBOXONEXBox One 코드의 컴파일 / 실행을 위한 플랫폼 매크로 정의.
UNITY_BLACKBERRYBlackberry10 장치를 위한 플랫폼 매크로 정의.
UNITY_TIZENAndroid 플랫폼의 플랫폼 매크로 정의.
UNITY_WP8Windows Phone 8 플랫폼 매크로 정의.
UNITY_WP8_1Windows Phone 8.1 플랫폼 매크로 정의.
UNITY_WSAPlatform define for Windows Store Apps (additionally NETFX_CORE is defined when compiling C# files against .NET Core).
UNITY_WSA_8_0SDK 8.0을 타케팅했을 때의 Windows Store Apps 플랫폼 매크로 정의.
UNITY_WSA_8_1SDK 8.1을 타케팅했을 때의 Windows Store Apps 플랫폼 매크로 정의.
UNITY_WSA_10_0Platform define for Windows Store Apps when targeting Universal Windows 10 Apps (additionally WINDOWS_UWP and NETFX_CORE is defined when compiling C# files against .NET Core).
UNITY_WINRTEquivalent to UNITY_WP8 | UNITY_WSA.
UNITY_WINRT_8_0Equivalent to UNITY_WP8 | UNITY_WSA_8_0.
UNITY_WINRT_8_1Equivalent to UNITY_WP_8_1 | UNITY_WSA_8_1. It’s also defined when compiling against Universal SDK 8.1.
UNITY_WINRT_10_0Same as UNITY_WSA_10_0
UNITY_WEBGLWebGL 플랫폼 매크로 정의.
UNITY_ANALYTICSUnity 스크립트에서 지원하는 플랫폼 매크로 정의 :

또한 작업을 하고 있는 Unity 엔진 버전에 따라 코드를 선택적으로 컴파일할 수 있습니다. 현재 지원되고 있는 것은 :

UNITY_2_6Unity 2.6 버전의 플랫폼 매크로 정의.
UNITY_2_6_1Unity 2.6.1 버전의 플랫폼 매크로 정의.
UNITY_3_0Unity 3.0 버전의 플랫폼 매크로 정의.
UNITY_3_0_0Unity 3.0.0 버전의 플랫폼 매크로 정의.
UNITY_3_1Unity 3.1 버전의 플랫폼 매크로 정의.
UNITY_3_2Unity 3.2 버전의 플랫폼 매크로 정의.
UNITY_3_3Unity 3.3 버전의 플랫폼 매크로 정의.
UNITY_3_4Unity 3.4 버전의 플랫폼 매크로 정의.
UNITY_3_5Unity 3.5 버전의 플랫폼 매크로 정의.
UNITY_4_0Unity 4.0 버전의 플랫폼 매크로 정의.
UNITY_4_0_1Unity 4.0.1 버전의 플랫폼 매크로 정의.
UNITY_4_1Unity 4.1 버전의 플랫폼 매크로 정의.
UNITY_4_2Unity 4.2 버전의 플랫폼 매크로 정의.
UNITY_4_3Unity 4.3 버전의 플랫폼 매크로 정의.
UNITY_4_5Unity 4.5 버전의 플랫폼 매크로 정의.
UNITY_4_6Unity 4.6 버전의 플랫폼 매크로 정의.
UNITY_5_0Unity 5.0 버전의 플랫폼 매크로 정의.

참고 : 2.6.0에서 처음 도입된 기능이기 때문에, 2.6.0 이전 버전에는 플랫폼 매크로 정의가 없습니다.



출처 : http://docs.unity3d.com/kr/current/Manual/PlatformDependentCompilation.html

Posted by 시리시안

댓글을 달아 주세요

2016. 2. 19. 15:55

Save and Load Info to XML

This script will allow you to save and load data about an object into an XML file. To use, add an empty game object to the scene and attache the script to the object. Change the Player on that game object property to the item you wish to save properties about. When you start the scene, you will see a save and load button, these allow you to save and load the information from the xml file. The guts of what you save is located in the UserData class, change this as you see fit to allow you to save what you want. You will also need to update the save method to store the information that you are looking to store. At the moment, the code is only setup to store the postition of the object in world space.


===========================================================================

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
using UnityEngine;
using System.Collections; 
using System.Xml; 
using System.Xml.Serialization; 
using System.IO; 
using System.Text; 
 
public class
_GameSaveLoad: MonoBehaviour { 
 
// An example where the encoding can be found is at   
//http://www.eggheadcafe.com/articles/system.xml.xmlserialization.asp   
// We will just use the KISS method and cheat a little and use 
// the examples from the web page since they are fully described 
// This is our local
private members 
  
Rect _Save, _Load, _SaveMSG, _LoadMSG;  
bool _ShouldSave, _ShouldLoad,_SwitchSave,_SwitchLoad;   
string _FileLocation,_FileName; 
public GameObject _Player; 
UserData myData; 
string _PlayerName; 
string _data;  
Vector3 VPosition; 
// When the EGO is
instansiated the Start will trigger 
// so we setup our
initial values for our local members 
void Start () { 
// We setup our
rectangles for our messages 
_Save=new Rect(10,80,100,20); 
_Load=new Rect(10,100,100,20);    
_SaveMSG=new Rect(10,120,400,40); 
_LoadMSG=new Rect(10,140,400,40);       
// Where we want to save and load to and from 
_FileLocation=Application.dataPath;      
_FileName="SaveData.xml";       
// for now, lets just set the name to Joe Schmoe      
_PlayerName = "Joe Schmoe"
// we need soemthing to store the information into 
myData=new UserData();  
 
void Update () {}    
void OnGUI()   
{      
//***************************************************  
// Loading The Player...   
//
**************************************************       
 if (GUI.Button(_Load,"Load")) {       
GUI.Label(_LoadMSG,"Loading from: "+_FileLocation); 
 
// Load our UserData into myData      
LoadXML();      
if(_data.ToString() != "")  
{        
// notice how I use a reference to type (UserData) here, you need this        
// so that the returned object is converted into the correct type        
myData = (UserData)DeserializeObject(_data);  
// set the players
position to the data we loaded        
VPosition=new Vector3(myData._iUser.x,myData._iUser.y,myData._iUser.z);              
_Player.transform.position=VPosition;       
// just a way to show that we loaded in ok        
Debug.Log(myData._iUser.name);      
}   
}   
//***************************************************   
// Saving The Player...   
//
**************************************************      
if (GUI.Button(_Save,"Save")) {     
GUI.Label(_SaveMSG,"Saving to: "+_FileLocation);   
myData._iUser.x=_Player.transform.position.x;     
myData._iUser.y=_Player.transform.position.y;     
myData._iUser.z=_Player.transform.position.z;     
myData._iUser.name=_PlayerName;       
// Time to creat our XML! 
     _data = SerializeObject(myData); 
     // This is the final resulting XML from the serialization process 
     CreateXML();      
     Debug.Log(_data);
   }      } 
 
 
   /* The following
metods came from the referenced URL */ 
   string UTF8ByteArrayToString(byte[] characters) 
   {      
      UTF8Encoding encoding = new UTF8Encoding(); 
      string constructedString = encoding.GetString(characters); 
      return (constructedString); 
   } 
   byte[] StringToUTF8ByteArray( string pXmlString) 
   { 
      UTF8Encoding encoding = new UTF8Encoding(); 
      byte[] byteArray = encoding.GetBytes(pXmlString); 
      return byteArray; 
   }  
   // Here we serialize our UserData object of myData 
   string SerializeObject(object pObject) 
   { 
      string XmlizedString = null
      MemoryStream memoryStream = new MemoryStream(); 
      XmlSerializer xs = new XmlSerializer(typeof(UserData)); 
      XmlTextWriter xmlTextWriter = new XmlTextWriter(memoryStream, Encoding.UTF8); 
      xs.Serialize(xmlTextWriter,pObject); 
      memoryStream = (MemoryStream)xmlTextWriter.BaseStream; 
      XmlizedString = UTF8ByteArrayToString(memoryStream.ToArray()); 
      return XmlizedString; 
   }  
   // Here we deserialize it back into its original form 
   object DeserializeObject(string pXmlizedString) 
   { 
      XmlSerializer xs = new XmlSerializer(typeof(UserData)); 
      MemoryStream memoryStream = new MemoryStream(StringToUTF8ByteArray(pXmlizedString)); 
      XmlTextWriter xmlTextWriter = new XmlTextWriter(memoryStream, Encoding.UTF8); 
      return xs.Deserialize(memoryStream); 
   }  
   // Finally our save and load methods for the file itself 
   void CreateXML() 
   { 
      StreamWriter writer; 
      FileInfo t = new FileInfo(_FileLocation+"\\"+ _FileName); 
      if(!t.Exists) 
      { 
         writer = t.CreateText(); 
      } 
      else 
      { 
         t.Delete(); 
         writer = t.CreateText(); 
      } 
      writer.Write(_data); 
      writer.Close(); 
      Debug.Log("File written."); 
   }  
   void LoadXML() 
   { 
      StreamReader r = File.OpenText(_FileLocation+"\\"+ _FileName); 
      string _info = r.ReadToEnd(); 
      r.Close(); 
      _data=_info; 
      Debug.Log("File Read"); 
   } 
// UserData is our custom class that holds our defined objects we want to store in XML format 
 public class UserData 
 { 
    // We have to define a default instance of the structure 
   public DemoData _iUser; 
    // Default constructor doesn't really do anything at the moment 
   public UserData() { } 
   // Anything we want to store in the XML file, we define it here 
 
   public struct DemoData 
   { 
      public float x; 
      public float y; 
      public float z; 
      public string name; 
   } 
}
 
 
 
 
cs
출처

http://wiki.unity3d.com/index.php?title=Save_and_Load_from_XML


Posted by 시리시안

댓글을 달아 주세요

2016. 2. 19. 13:58





AddComponentMenu : 유니티 메뉴 추가.

1
2
3
4
5
// C# example:
[AddComponentMenu("Transform/Follow Transform")]
public class FollowTransform : MonoBehaviour
{
}
s

ContextMenu : 우클릭 메뉴 추가.

1
2
3
4
5
6
7
8
9
10
11
12
// C# example:
public class ContextTesting : MonoBehaviour 
{    
    /// Add a context menu named "Do Something" in the inspector    
    /// of the attached script.    
    [ContextMenu ("Do Something")]    
    void DoSomething () 
    {        
        Debug.Log ("Perform operation");    
    }
}
 
cs


ExecuteInEditMode : 에디트 모드에서 스크립트 실행.

1
2
3
4
5
6
7
8
9
10
11
12
13
 
using UnityEngine;
using System.Collections;
 [ExecuteInEditMode]
public class example : MonoBehaviour 
{
    public Transform target;
    void Update() 
    {        
        if (target)            
        transform.LookAt(target);
    }
}
cs

 

HideInInspector : 인스펙터에서 속성 감추기, 이전 세팅값은 유지.

1
2
3
4
5
6
7
using UnityEngine;
using System.Collections;
public class example : MonoBehaviour 
{    
    [HideInInspector]    
    public int p = 5;
}
cs

NonSerialized : 인스펙터에서 속성 감추기, 이전 세팅값은 무시.

1
2
3
4
5
6
// C# Example
class Test {    
    // p will not be shown in the inspector or serialized    
    [System.NonSerialized]    
    public int p = 5;
}
cs

RPC : 원격지 호출 함수로 지정, 보내는 쪽과 받는 쪽 모두 다 존재해야 함.

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
using UnityEngine;
using System.Collections; 
public class example : MonoBehaviour {
    public Transform cubePrefab;
    void OnGUI() {
        if(GUILayout.Button("SpawnBox")) {      
        NetworkViewID viewID = Network.AllocateViewID();           
        networkView.RPC("SpawnBox", RPCMode.AllBuffered, viewID,transform.position);
        }
    }
    [RPC]
    void SpawnBox(NetworkViewID viewID,Vector3 location) 
    {        
        Transform clone;
        clone = Instantiate(cubePrefab, location, Quaternion.identity) as Transform as Transform;
        NetworkView nView;
        nView = clone.GetComponent<NetworkView>();
        nView.viewID = viewID;
    }
}
cs

 

RequireComponent : 컴포넌트 자동 추가.

1
2
3
4
5
6
7
[RequireComponent (typeof (Rigidbody))]
public class PlayerScript : MonoBehaviour {
 
    void FixedUpdate()  {     
        rigidbody.AddForce(Vector3.up);
    }
}

cs

Serializable : 인스펙터에 인스턴스의 하위 속성 노출.

1
2
3
4
5
6
7
8
9
10
11
12
// C# Example
[System.Serializable]
class Test
{
    public int p = 5;
    public Color c = Color.white;
}
 
class Sample : MonoBehaviour
{
    public Test serializableObj; // 인스펙터에 p, c가 노출된다.
}
cs

SerializeField : 인스펙터에 비공개 멤버 노출.

1
2
3
4
5
6
7
8
9
10
11
12
13
14
//C# example
using UnityEngine;
public class SomePerson : MonoBehaviour {
    //This field gets serialized because it is public.
    public string name = "John";
    //This field does not get serialized because it is private.
    private int age = 40;
    //This field gets serialized even though it is private
    //because it has the SerializeField attribute applied.
    [SerializeField]
    private bool hasHealthPotion = true;
    void Update () {
    }
}
cs





Posted by 시리시안

댓글을 달아 주세요