溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

unity3D與網(wǎng)頁的交互

發(fā)布時間:2020-08-02 11:41:19 來源:網(wǎng)絡(luò) 閱讀:272 作者:蓬萊仙羽 欄目:游戲開發(fā)

由于項目需要,要求用unity來展示三維場景,并在三維中能夠方便的查詢數(shù)據(jù)庫等。一開始嘗試在unity中直接連接數(shù)據(jù)庫,當時連的xml,然而每次發(fā)布成網(wǎng)頁后都會出現(xiàn)路徑找不到等問題,所以迫不得已采用了unity向網(wǎng)頁傳送數(shù)據(jù),網(wǎng)頁中處理數(shù)據(jù)(查詢數(shù)據(jù)庫),然后將處理過的數(shù)據(jù)再反傳送給unity,最終在unity中將其展示(在網(wǎng)頁中展示更為靈活)。

原理很簡單:

1、unity向網(wǎng)頁發(fā)送數(shù)據(jù)的函數(shù):Application.ExternalCall("SayHello",gameObject.name),這個函數(shù)將調(diào)用網(wǎng)頁中的SayHello函數(shù),gameObject.name為傳遞的參數(shù)。

2、網(wǎng)頁向unity發(fā)送數(shù)據(jù)的函數(shù):網(wǎng)頁中用GetUnity().SendMessage(message, "AcceptName",buildingname)函數(shù)來調(diào)用unity中的函數(shù),此函數(shù)的參數(shù)message為unity中的物體,AcceptName為物體上的函數(shù),buildingname為傳遞的參數(shù)。

網(wǎng)頁中的函數(shù)如下:

 1functionSayHello(message){//此函數(shù)來接收unity中發(fā)送出來的message值,并將處理后的數(shù)據(jù)再發(fā)送回unity
 2jQuery.post('../Unity/javascript/DBhelper.ashx',{id:message}, function(data)
 3        {
 4varmsg=JSON.parse(data);//json數(shù)據(jù)解析
 5varbuildingname = msg[0].Building_name;
 6varbuildingcategory=msg[0].Building_category;
 7varbuildingpic = msg[0].Building_pic;
 8GetUnity().SendMessage(message, "AcceptName",buildingname);//unity中的message物體上的MyFunction函數(shù)發(fā)送buildingname
 9GetUnity().SendMessage(message,"AcceptCategory", buildingcategory);
10
11GetUnity().SendMessage(message,"AcceptImg", buildingpic);
12       });   
13}

此函數(shù)將unity中發(fā)送的數(shù)據(jù)message傳到DBhelper.ashx中,在DBhelper.ashx中將傳遞過來的數(shù)據(jù)進行查詢等操作,然后再用GetUnity().SendMessage(message,"AcceptName", buildingname)將處理好的數(shù)據(jù)buildingname傳給unity中的AcceptName函數(shù)。

以下是unity中的腳本,可以實現(xiàn)中文,關(guān)于中文的實現(xiàn)由于文章有限,在此不再說明,只說明怎樣接收網(wǎng)頁中的數(shù)據(jù)。

 1varchineseSkin : GUISkin;//在此可以選擇字體,并設(shè)置為中文。建議編輯器設(shè)為uft-8。
 2
 3varbuildingname:String;//用來接收從網(wǎng)頁中傳遞過來的buildingname
 4varbuildingcategory:String;//用來接收從網(wǎng)頁中傳遞過來的buildingcategory
 5
 6var buildingpic:Texture2D;//用來接收從網(wǎng)頁中傳遞過來的buildingpic
 7var windowRect0 = Rect (20, 20, 250, 200);
 8varenable:boolean;
 9function Awake(){
10enable = false ;
11}

//鼠標按下去時觸發(fā)的事件
12functionOnMouseDown () {
13Application.ExternalCall("SayHello",gameObject.name);// 向網(wǎng)頁中的SayHello函數(shù)發(fā)送gameObject.name數(shù)據(jù)
14enable = true;
15}
16functionAcceptName(bdname){//用于接收網(wǎng)頁中發(fā)送回來的數(shù)據(jù)
17buildingname=bdname;
18}
19functionAcceptCategory(buildingType){//用于接收網(wǎng)頁中發(fā)送回來的數(shù)據(jù)
20buildingcategory=buildingType;
21}
22
23functionAcceptImg(img){

//讀取文件夾下的圖片文件
24var www :WWW = newWWW("http://localhost:1166/Unity/images/"+img+"");
25yield www;

//為buildingpic設(shè)置紋理
26buildingpic=www.texture;
27}

//繪制GUI元素時觸發(fā)的事件
28functionOnGUI(){
29GUI.skin=chineseSkin;
30if(enable)
31{

//繪制一個窗體,記住第三個參數(shù)是方法名字
32windowRect0 = GUI.Window (0, windowRect0,DoMyWindow, "屬性");
33}
34}

//繪制一個窗體,windID是不可缺少的元素,指向窗體的索引值
35functionDoMyWindow (windowID : int) {
36GUI.Label(Rect(10,50,80,30),"建筑物名字");
37GUI.TextField(Rect(100,50,100,30),buildingname);
38GUI.Label(Rect(10,100,80,30),"建筑物類型");
39GUI.TextField(Rect(100,100,100,30),buildingcategory);
40
41GUI.DrawTexture(Rect(10,150,200,50),buildingpic,ScaleMode.ScaleToFit,true,0);
42if(GUI.Button(Rect(190,20,50,30),"退出")){
43enable = false;
44}
45GUI.DragWindow (Rect (0,0,10000,10000));
46}

//鼠標在上面時觸發(fā)
47functionOnMouseOver(){
48transform.Rotate(0,Time.deltaTime*100,0,Space.World);
49}

//鼠標進入時觸發(fā)
50functionOnMouseEnter(){
51renderer.material.color = Color.blue;
52}

//鼠標離開時觸發(fā)
53functionOnMouseExit(){
54renderer.material.color =Color.yellow;   
55}

這是unity中的腳本,此腳本實現(xiàn)點擊物體,彈出物體的屬性。

向AI問一下細節(jié)

免責聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

un %d
AI