Unity C# | 射線檢測與改變物體顏色之應用

更新於 發佈於 閱讀時間約 6 分鐘

一、前言

  這篇文章將會從基本概述到射線偵測應用的詳細步驟,講述運用射線改變特定圖層中,射線命中的物件顏色。

二、射線檢測概述

  射線是初學者在學習控制非特定目標的做法之一,另外一種是藉由碰撞體去偵測碰撞單位,射線是其中相對困難的做法,本篇文章會使用到射線與輔助線的內容,有興趣可以參考之前的兩篇文章。

1. 創建射線

  我們會需要在遊戲物件創建一道射線,往遊戲場景中的某個方向發射,取得特定圖層的遊戲物件,這條射線會命中所有圖層的遊戲物件,只要對方有碰撞體組件,但只有在命中特定圖層才會通過判斷。

2. 改變命中物體顏色

  通過判斷後,我們要可視的改變,也可以使用 Debug.Log 去測試,我們會抓取命中物件的渲染組件,並改變渲染組件 Material 欄位的顏色。

三、射線應用流程

  那接下來會簡單講述射線的流程。

1. 創建測試用方塊(Cube)

  創建三個測試方塊:
第一個方塊座標位於(0,0,0),並命名為「origion」。
第二個方塊座標位於(0,0,3),並命名為「Target_A」。
第三個方塊座標位於(0,0,6),並命名為「Target_B」。

2. 創建程式腳本(Script)並添加至物件

  創建一個程式腳本,並添加到物件origion,可以拖曳程式腳本到此物件,也可以直接在此物件點擊 Add Component。

3. 宣告顯示變數

  這一次我們的射線起點為物件本身位置,並且往正前方打出一條射線,因此射線的起點與方向固定,我們將額外添加兩個參數,分別為距離與圖層:
[SerializeField] private float MaxDistance;
[SerializeField] private LayerMask mask;
程式腳本自己可以抓取起點與方向,其宣告方式如下:
private Vector3 m_position;
private Vector3 direction;
程式腳本自己可以抓取渲染組件,其宣告方式如下:
private Renderer render;

4. 函式-取得玩家位置

private void GetDirection()
{
m_position = transform.position;
direction = transform.forward;
}
  我們要指定玩家的位置跟方向,封裝成一個函式的習慣,除了可以維護程式的可讀性,也能讓程式設計的過程清晰,此函式可以放在開始函式(Start()),如果其座標會持續變動的話,也可以放在更新函式(Update())。

5. 函式-雷射判斷

private void RayCastHitTest()
{
Ray ray = new Ray(m_position, direction);
RaycastHit hit;
if (Physics.Raycast(ray, out hit, MaxDistance, mask))
{
ChangeRenderColor(hit);
}
}
  函式自行宣告了兩個暫時變數,第一個是雷射,其起點為物件的座標,方向為物件的正前方;第二個是射線命中,可以抓取命中目標的資料,包含遊戲目標與命中點等訊息。
  創建一個判斷式,並在其中創建一個物理射線的判斷函式,我們選擇四個參數的判斷函式,包含雷射、射線命中訊息、最大距離、圖層,此函式會回傳一個布林值,若命中且圖層為指定圖層,則回傳 True。

6. 函式-改變物件顏色

private void ChangeRenderColor(RaycastHit hit)
{
render = hit.transform.GetComponent<Renderer>();
render.material.color = Color.red;
}
  我們把改變命中目標顏色的程式碼抓取出來變成一個函式,這個習慣一方面能協助此文章的章節分類,也能協助程式碼的維護,若射線偵測同時用 Hit 進行很多的操作,那這個習慣能準確的分類命中功能。
  第一行程式碼,我們抓取命中目標的渲染組件;第二行程式碼,我們改變渲染組件中材質的顏色,並改成紅色。

7. 輔助線-在 Sence 中看見射線

private void OnDrawGizmos()
{
Gizmos.color = Color.blue;
Gizmos.DrawRay(transform.position, transform.forward * MaxDistance);
}
  我們使用官方內建函式 OnDrawGizmos,它會創造一個此程式的Gizmos屬性,並由上往下執行,首先我們改變此函式的顏色,改成藍色,並且繪製一條雷射,起點為自己,終點為方向乘上距離。

8. 測試

  最後,我們可以按下 Play 進行測試,此時程式碼沒有效果,因為此時的射線距離為默認值。點擊 origion ,把 Max Distance 改為10,你會發現在 Sence 中出現一條藍色射線,往前打出,但是程式碼還是沒有效果。
  點擊Mask,我們改變它的圖層為 Default,這樣一來只要命中 Default 圖層時,此物件的顏色就會變成紅色。

四、後記

  這篇文章是我研究射線順便寫的文章,主要是分享射線的實際使用,沒想到也花了我不少的時間。

































即將進入廣告,捲動後可繼續閱讀
為什麼會看到廣告
avatar-img
106會員
247內容數
對設計師如何成長為設計師好奇嗎? 2020年九月,我進入大學學習當一位設計師,從開始到沉寂,再到重燃熱忱,我將在方格子紀錄我的成長歷程、理念、心情,分享我在這段旅程中所經歷的故事。
留言0
查看全部
avatar-img
發表第一個留言支持創作者!
瓶裝雪的沙龍 的其他內容
這篇文章將會講述平滑的旋轉與單次旋轉的差異,並介紹旋轉的兩種體系與其使用效果,並提供參考的示範影片。
這篇文章將會講述常見的座標(Transform)旋轉方式,適合初學者到進階程式員複習。
這篇文章將會講述設計模式中的狀態模式,其資料源自於書籍、網路、個人理解,從簡介→架構→撰寫→測試的整個流程進行介紹與分享。
這篇文章將會介紹建構式(Constructor),這是一個隱藏在程式腳本中的重要知識,我們極常使用建構式,但新手程式員幾乎不會知道它。
這篇文章將會講述 Unity Visual Effect Graph 的系統簡介,並且簡單介紹這項系統主線上的四個核心組件。
這篇文章將會講述子彈射擊與命中的思路,不包含實際程式設計。
這篇文章將會講述平滑的旋轉與單次旋轉的差異,並介紹旋轉的兩種體系與其使用效果,並提供參考的示範影片。
這篇文章將會講述常見的座標(Transform)旋轉方式,適合初學者到進階程式員複習。
這篇文章將會講述設計模式中的狀態模式,其資料源自於書籍、網路、個人理解,從簡介→架構→撰寫→測試的整個流程進行介紹與分享。
這篇文章將會介紹建構式(Constructor),這是一個隱藏在程式腳本中的重要知識,我們極常使用建構式,但新手程式員幾乎不會知道它。
這篇文章將會講述 Unity Visual Effect Graph 的系統簡介,並且簡單介紹這項系統主線上的四個核心組件。
這篇文章將會講述子彈射擊與命中的思路,不包含實際程式設計。
你可能也想看
Google News 追蹤
Thumbnail
嘿,大家新年快樂~ 新年大家都在做什麼呢? 跨年夜的我趕工製作某個外包設計案,在工作告一段落時趕上倒數。 然後和兩個小孩過了一個忙亂的元旦。在深夜時刻,看到朋友傳來的解籤網站,興致勃勃熬夜體驗了一下,覺得非常好玩,或許有人玩過了,但還是想寫上來分享紀錄一下~
Thumbnail
這篇內容,將會用一個簡單的範例,來解釋物件(Object)和實體(Instance)的差別。包括Instance的簡介、ID、物件改變會影響實體。
介紹以物件導向的方式,以向量來實作物體運動的模擬程式。
Thumbnail
是種射線是種光 穿透一億種表情如何變成一種 穿透時間如何切割成年輕、年老, 切割成24小時、8小時, 切割成上班、加班 而不是想像、發呆、作夢、覓食 一朵鮮花在沙漠的歷程 是種磁波是種光 看透星辰風格如何變成一個字 看透地表如何區隔成出國、回國, 區隔成家裏、公司, 區隔成
Thumbnail
上一篇提到利用cv2.inRangex,建立遮罩來過濾出紅球。這次我們稍微更動一下程式碼,將紅球變顏色。 [OpenCV][Python]利用cv2.inRange搭配cv2.bitwise_and過濾紅球 結果圖 將紅球改變顏色成藍球
Thumbnail
首先我們先用小畫家,創建一個簡單的十字箭頭圖,在用高斯模糊將圖用模糊來模擬圖片糊掉的狀況。 如何檢測呢? 先假設在圖像清晰的狀況下,取邊緣的話線條應該是很明顯的吧,模糊的情況下,邊緣線條應該就會變多? 看下圖,由左看到右,在圖片清晰的狀況下,線條是相當明顯的 那有什麼方法將其量化成數字?
Thumbnail
其他特殊材質調整 Particles Q:大家有沒有發現剛剛葉子是一面有顏色一面透明? A:Unity的渲染只有單面,超奇怪ㄉ啦,他軟體預設就是單面,要改成雙面也行,但會造成電腦負擔,所以只需在想要雙面渲染的物體上賦予即可,不用整個專案都給它。 單面渲染的情形 材質球著色器定義 Sh
Thumbnail
剛剛調了第一層Rendering Mode渲染模式的參數 進入第二層#Opaque渲染參數介紹 搭配教材一起做好ㄌ,先下載檔案樹葉葉葉🌿🌿🌿 解壓縮後把他拖移進去ASSET裡面 點開剛剛LeafPack,找到Mesh>選擇FBX>找到後拖曳到遊戲編輯畫面 部份模型( Fbx&
Thumbnail
材質和貼圖在遊戲開發中扮演著極為重要的角色,其決定了遊戲物件的外觀和表現。 材質(Material)在Unity中定義物體外觀和視覺特性的屬性集合。 包含了物體的顏色、光澤度、透明度、反射率等信息,可以透過調整這些屬性來改變物體在遊戲中的表現形式。舉例來說,可以創建金屬、塑料、木材等不同材質類型
Thumbnail
完成了Debug.log()的測試,接著還是要跟各位簡單講一下C#的一些規則,之後看程式會(比較)看得懂。 又講到變數? 在Unity中,變數是重要的工具,用來儲存和管理資料。讓開發者能夠靈活調整遊戲的行為和性能,減少代碼的重複性,使得遊戲開發更加高效和簡潔。透過使用變數,開發者可以輕鬆修改資料
Thumbnail
建立幾個變數如下,最上面兩個變數值為清單值 接下來分別設定球1位置到左上角落、設定球2位置到右上角落、設定球3位置到左下角落、設定球4位置到右下角落 當螢幕初始化的時候,設定玩家球的X、Y座標和大小,並將玩家球的初始顏色,設定成(變數_顏色清單)中.....
Thumbnail
嘿,大家新年快樂~ 新年大家都在做什麼呢? 跨年夜的我趕工製作某個外包設計案,在工作告一段落時趕上倒數。 然後和兩個小孩過了一個忙亂的元旦。在深夜時刻,看到朋友傳來的解籤網站,興致勃勃熬夜體驗了一下,覺得非常好玩,或許有人玩過了,但還是想寫上來分享紀錄一下~
Thumbnail
這篇內容,將會用一個簡單的範例,來解釋物件(Object)和實體(Instance)的差別。包括Instance的簡介、ID、物件改變會影響實體。
介紹以物件導向的方式,以向量來實作物體運動的模擬程式。
Thumbnail
是種射線是種光 穿透一億種表情如何變成一種 穿透時間如何切割成年輕、年老, 切割成24小時、8小時, 切割成上班、加班 而不是想像、發呆、作夢、覓食 一朵鮮花在沙漠的歷程 是種磁波是種光 看透星辰風格如何變成一個字 看透地表如何區隔成出國、回國, 區隔成家裏、公司, 區隔成
Thumbnail
上一篇提到利用cv2.inRangex,建立遮罩來過濾出紅球。這次我們稍微更動一下程式碼,將紅球變顏色。 [OpenCV][Python]利用cv2.inRange搭配cv2.bitwise_and過濾紅球 結果圖 將紅球改變顏色成藍球
Thumbnail
首先我們先用小畫家,創建一個簡單的十字箭頭圖,在用高斯模糊將圖用模糊來模擬圖片糊掉的狀況。 如何檢測呢? 先假設在圖像清晰的狀況下,取邊緣的話線條應該是很明顯的吧,模糊的情況下,邊緣線條應該就會變多? 看下圖,由左看到右,在圖片清晰的狀況下,線條是相當明顯的 那有什麼方法將其量化成數字?
Thumbnail
其他特殊材質調整 Particles Q:大家有沒有發現剛剛葉子是一面有顏色一面透明? A:Unity的渲染只有單面,超奇怪ㄉ啦,他軟體預設就是單面,要改成雙面也行,但會造成電腦負擔,所以只需在想要雙面渲染的物體上賦予即可,不用整個專案都給它。 單面渲染的情形 材質球著色器定義 Sh
Thumbnail
剛剛調了第一層Rendering Mode渲染模式的參數 進入第二層#Opaque渲染參數介紹 搭配教材一起做好ㄌ,先下載檔案樹葉葉葉🌿🌿🌿 解壓縮後把他拖移進去ASSET裡面 點開剛剛LeafPack,找到Mesh>選擇FBX>找到後拖曳到遊戲編輯畫面 部份模型( Fbx&
Thumbnail
材質和貼圖在遊戲開發中扮演著極為重要的角色,其決定了遊戲物件的外觀和表現。 材質(Material)在Unity中定義物體外觀和視覺特性的屬性集合。 包含了物體的顏色、光澤度、透明度、反射率等信息,可以透過調整這些屬性來改變物體在遊戲中的表現形式。舉例來說,可以創建金屬、塑料、木材等不同材質類型
Thumbnail
完成了Debug.log()的測試,接著還是要跟各位簡單講一下C#的一些規則,之後看程式會(比較)看得懂。 又講到變數? 在Unity中,變數是重要的工具,用來儲存和管理資料。讓開發者能夠靈活調整遊戲的行為和性能,減少代碼的重複性,使得遊戲開發更加高效和簡潔。透過使用變數,開發者可以輕鬆修改資料
Thumbnail
建立幾個變數如下,最上面兩個變數值為清單值 接下來分別設定球1位置到左上角落、設定球2位置到右上角落、設定球3位置到左下角落、設定球4位置到右下角落 當螢幕初始化的時候,設定玩家球的X、Y座標和大小,並將玩家球的初始顏色,設定成(變數_顏色清單)中.....