我的Uncharted 4開發雜記
我的Uncharted 4開發雜記

本文作者周明倫,在Naughty Dog擔任程式設計師,參與了最近上市的遊戲《秘境探險4:盜賊末路》開發工作。原文刊載於他的部落格「Ming-Lun "Allen" Chou」。《數位時代》經作者同意後編輯、刊登。

關於周明倫如何從一位小小電玩迷到加入Naughty Dog開發《秘境探險4:盜賊末路》的歷程,讀者可以閱讀這篇〈我的秘境之旅〉。

本文屬於My Career系列文,Here is the original English post. 本文之英文原文在此

Uncharted 4已經發售,終於可以分享我負責開發的部分了。我主要是負責單人模式的夥伴AI、多人模式的戰友AI、還有一些遊戲邏輯。沒有收錄到最終遊戲的部分和一些瑣碎的細工我就略過不提。

崗位系統

在本文開始前,我想要先談談我們用來指派NPC移動位置的崗位系統。這個系統的核心邏輯不是我負責的,我寫的是使用這個系統的客戶端程式。

崗位是可行走空間中的離散位置 大部分是用工具自動生成的,也有一些是設計師手動擺置的。

基於不同需求,我們設計不同的崗位平分系統(e.g. 潛行崗位、戰鬥崗位)。然後我們選擇評分最高的崗位,指派NPC移動過去。

圖說明

夥伴跟隨

夥伴跟隨系統是繼承自The Last of Us。基本概念就是,夥伴在玩家周圍找個跟隨點,這些可能的跟隨點從玩家位置扇狀分開,並且要滿足以下的路徑線段淨空條件:

  • 玩家到跟隨點
  • 跟隨點到前方投射點
  • 前方投設點到玩家

圖說明

攀爬是Uncharted 4的新功能,這是The Last of Us 沒有的。為了與現有的跟隨系統整合,我利用攀爬崗位讓夥伴可以跟著玩家一起攀爬。

圖說明

這個功能比我想像中的還要難搞。單純根據玩家的攀爬狀態來切換夥伴的攀爬狀態,結果不甚理想。只要玩家快速在攀爬與非攀爬的狀態之間切換,夥伴就會在兩個狀態間快速跳換。於是我加入了遲滯現象(hysteresis),只有在玩家切換了攀爬狀態,並且保持此狀態移動一定距離之後,夥伴才跟進。廣泛來說,遲滯現象是個解決行為跳換的好方法。

夥伴帶領

遊戲中的某些特定場景,我們要讓夥伴帶領玩家前進。我把The Last of Us的帶領系統移植過來,設計師使用spline曲線在關卡中標記他們想讓夥伴帶領玩家的大致路線。

圖說明

如果有多個帶領路線,設計師則會用腳本語言切換主要的帶領路線。

圖說明

玩家的位置投射到spline曲線上,再往前延伸設定為帶領參考點。當帶領參考點超越被標記為等待點的spline曲線控制點,夥伴會前往下個等待點。如果玩家走回頭路,夥伴只有在帶領參考點離此次推進至最遠的等待點一段距離,才會回頭。這也是利用遲滯現象來避免行為跳換。

我也把動態移動速度調整的功能整合進帶領系統。根據夥伴和玩家之間的距離,一些「速度平面」沿著spline曲線放置。

夥伴有三種移動模式:走路、跑步、衝刺。根據玩家撞到的速度平面,夥伴會選擇不同的移動模式。另外,夥伴的行進動畫速度也會基於玩家距離做微調,目的是避免切換移動模式的時後,有太突然的移動速度變化。

圖說明

夥伴掩體共用

在The Last of Us中,玩家和夥伴可以在各不離開掩體的狀況下重疊 我們稱這個為掩體共用。

圖說明

The Last of Us中的Joel伸手跨過Ellie和Tess按在掩體上
看起來很自然,因為夥伴的身型都比玩家嬌小,但是同樣的動作就不適合身型差不多的Nate、Sam、Sully、和Elena。而且Uncharted 4的遊戲節奏較快,讓Nate伸手去按掩體只會讓動作流暢性打折扣。
所以我們決定就單純讓夥伴靠緊掩體,玩家稍微繞彎避開夥伴。

圖說明

我用的邏輯很簡單,如果玩家位置往移動方向投射的點,落在夥伴掩體周圍的一個方框內,夥伴就會取消目前的掩體行為,並且快速靠緊掩體。

圖說明

救星戰友

我負責多人模式的戰友(sidekicks),而救星戰友是其中最特別的。單人模式中的NPC,沒有一個人的行為跟救星戰友一樣,他們會復甦被擊倒的同伴,也會複製玩家的掩蔽行為。

圖說明

救星戰友會嘗試複製玩家的掩蔽行為,並且盡量待在離玩家很近的地方
所以當玩家被擊倒的時候,他們就可以迅速跑過來復甦。如果玩家有裝備救星戰友的復甦包額外功能,他們會在採取復甦行動之前,朝被擊倒的復甦目標丟復甦包。復甦包丟擲基本上就是延用手榴彈的拋物線淨空測試和擲彈動作,只是我把手榴彈換成復甦包而已。

圖說明

隱蔽草叢

在隱蔽草叢中蹲行也是Uncharted 4才有的新功能,要實作這個功能,我們需要某種能夠標記場景的手段,遊戲邏輯才可以判斷玩家是否身處隱蔽草叢中。我們一開始是讓美術人員在Maya中標記背景模型的表面,但美術人員和設計師之間的溝通時間太長,很難頻繁改進關卡
於是我們決定用另外一種方法標記隱蔽草叢。

我在場景編輯器中的nav mesh增加了隱密草叢的額外tag,讓設計師可以直接在編輯器中精準標記隱蔽草叢。有了這個額外的標記,我們也可以用這個資訊來為隱蔽崗位評分。

圖說明

感知

Uncharted 4沒有像The Last of Us有聆聽模式,所以我們必須要找另外一種方法,讓玩家有辦法得知附近的敵人威脅,好讓玩家不會在未知的敵對環境中產生迷失感。

我利用敵人的感知資料,加入了威脅標示。當敵人開始注意(白色)、起疑(黃色)、和發現(橘色)玩家,這些標示會適時地提醒玩家。另外,我在威脅標示開始累積的同時播放背景雜音,以製造張力。當玩家被發現的時候,則播放大聲的提示音效,這些音效的安排和做用跟The Last of Us類似。

圖說明

調查

這是在我們送廠壓片前,我負責的最後一個功能。我平常在Naughty Dog是不參加正式會議的。不過在送廠壓片的前幾個月,我們每週至少開一次會,由Bruce StraleyNeil Druckmann主持,專注在遊戲的AI部分。幾乎每次開完會之後,調查系統都有需要更動的地方,前前後後總共經歷了好幾次大改。

會讓敵人起疑的因素有兩種:玩家和屍體。當敵人起疑了(起疑者),他會抓最近的同伴來一起調查,離起疑點較近的人會成為調查者,另外一個人則是看守者。起疑者可能會視調查者,也有可能是看守者。我們總共有兩組不同的對話,適用於兩種不同的情況(「那邊有異狀,我去看看」 vs. 「那邊有異狀,你去看看」)。

為了讓雙人調查看起來更自然,我使用了時域錯位的技巧,讓兩人的行動和威脅標示時間點錯開,否則兩個人的行為完全同步,看起來非常機械式、很不自然。

圖說明

如果調查者發現了屍體,他會通知全部的同伴開始搜索玩家,屍體也會被暫時標示,以讓玩家知道敵人為什麼進入警戒。

圖說明

在某些難度下,短時間內連續觸發調查,會讓敵人的感應力變敏銳。他們會更容易發現玩家,即使玩家躲在隱蔽草叢中也一樣。慘烈模式下,敵人永遠處於敏銳狀態。

對話動作

這也是我負責的最後幾個功能之一。對話動作系統負責操控角色,在對話的時候做出一些小動作 像是轉頭看其他人和肢體動作。

之前在The Last of Us,開發人員花好幾個月的時間,把整個遊戲所有的對話腳本手動加註上對話動作,我們可不想再做一次這種苦工。在這個開發階段,已經有部分對話腳本被手動加註好對話動作了,我們需要一個泛用型系統,可以幫沒有加註對話動作的腳本自動產生對話動作。

而我就是負責製作這個對話動作系統,動畫師可以調整參數,改變轉頭速度、轉頭角度、注視時間、反覆時間等。

圖說明

維持吉普車動量

開發初期遇到的問題之一,就是馬達加斯加的吉普車駕駛關卡 當玩家開車撞到牆或者敵人的載具,玩家的車就會旋轉失速以致脫離車隊而關卡失敗。

我使用的解決方法是,當玩家的車撞到牆或者敵方載具的時候,短暫地限制吉普車的最高角速度和線性速度的方向變量。這個簡單的方法相當有效,從此玩家就比較不容易旋轉失速而導致關卡失敗了。

圖說明

載具死亡

可駕駛的載具是首次在Uncharted 4登場,在這之前,所有的載具都是NPC駕駛、沿著固定軌道行進。

我負責載具死亡的部分,摧毀載具有幾種方式:解決駕駛、開槍射車、開車撞飛敵方機車、開車撞敵方吉普車導致旋轉失速。

基於不同的死法,載具死亡系統會選擇載具和乘客的死亡動畫來播放
死亡動畫會漸漸混入物理引擎控制的ragdoll系統,所以死亡動畫會不著痕跡地轉換成物理模擬的翻車。

圖說明

當玩家開吉普車撞飛敵方機車的時候,我使用機車在XZ平面上投影的bounding box和碰撞點,來判斷要使用四個撞飛死亡動畫中的哪一個。

圖說明

至於衝撞使得敵方吉普車旋轉失速,我是拿敵方吉普車與預設行進方向之間的旋轉量差來比較旋轉失速判定閾值。

圖說明

載具播放死亡動畫的時候,有機會穿透牆壁。我使用球體投射,從預設位置投射向載具實際位置。如果投射結果是與牆壁碰撞,則把載具稍微往牆壁的法向量移動。不一次完全修正誤差,是為了避免太過劇烈的位移。

圖說明

我另外實作了一種特別的載具死亡類型,叫做載具死亡提示。這些死亡提示是動畫師和設計師在場景中擺置好的客製化死亡動畫。每個死亡提示在載具行進軌道上都有個進入範圍。當一個載具在死亡提示進入範圍中死亡,則會開始播放死亡提示的特殊死亡動畫。之所以開發這功能,一開始是為了2015年E3展的超帥氣吉普車死亡動畫。

混色用的貝爾矩陣

我們想要消除攝影機切入看穿物體的瑕疵,特別是遊戲中的各種植物。於是我們決定要讓靠近攝影機的像素淡出。使用半透明像素並不是個好主意,因為非常消耗效能。我們使用的技巧,是所謂的混色dithering:[https://en.wikipedia.org/wiki/Dither](https://en.wikipedia.org/wiki/Dither)

使用混色技巧搭配貝爾矩陣(Bayer matrix)。利用一個預先決定的點陣模板來決定哪些像素可以捨棄而不渲染:https://en.wikipedia.org/wiki/Ordered_dithering

結果就是產生半透明的錯覺

圖說明

一開始使用的貝爾矩陣是個8×8矩陣,取自上述的Wikipedia頁面。我認為這個矩陣太小,會造成不美觀的帶狀瑕疵。我想要使用16×16的貝爾矩陣,但是網路上都找不到相關資料,於是我試著用逆向工程找出8×8貝爾矩陣的遞迴特性。

光用目測法,我想我應該可以直接解出16×16貝爾矩陣,但是我想要讓過程更有趣一點。我寫了一個工具,可以生成二的任何次方大小的貝爾矩陣。

換到16×16貝爾具陣之後,可以明顯看到帶狀瑕疵的改善。

圖說明

爆炸聲延遲

這個部份我其實沒有什麼大貢獻,但是我還是覺得值得一提。

在2015年E3展示中,Nate和Sully同時接收到高塔傳過來的爆炸聲和爆炸畫面,這是不合理的,因為高塔距離非常遠,爆炸聲應該會晚一點才被接收到,我在開展前幾週指出這點,美術團隊後來就在爆炸聲之前加上一小段延遲了。

繁體中文在地化

直到送廠壓片前幾週我才開始在遊戲中改用繁體中文字幕,而我找到了許多錯誤。大部分的錯誤都是英文直譯中文,而變成四不像的用語。我認為我沒有足夠的時間可以單槍匹馬全破一次遊戲又同時抓出翻譯錯誤,於是我請幾個QA部門的人分章節、用繁體中文模式遊玩,然後我陸續瀏覽他們的遊玩錄製影片。結果這個方法相當有效率,我成功地把我找到的翻譯錯誤建檔,而在地化小組也有足夠的時間修正翻譯。

結束

以上就是我對Uncharted 4開發上值得一提的貢獻,希望大家讀得愉快 :)

延伸閱讀:我的秘境之旅

往下滑看下一篇文章
大巨蛋經濟商機無限 : 如何提升台灣運動娛樂產業?緯來董座李鐘培:先整合生態圈
大巨蛋經濟商機無限 : 如何提升台灣運動娛樂產業?緯來董座李鐘培:先整合生態圈

臺北大巨蛋啟用,也為台灣運動產業帶來更多新機會。緯來電視網董事長李鐘培在 NMEA 新媒體暨影視音發展協會舉辦的「2025 亞洲新媒體高峰會」上登台演講,從賽事現場談到產業鏈,梳理運動產業的挑戰與機會。

他指出,在大巨蛋完工前,各球團每年大約虧損新臺幣 2 至 3 億元;但場館啟用後,職棒生態因為有了更大的舞台而出現新契機。以觀賽人數為例,啟用前每年約 180 萬人次,啟用後成長至 373 萬人次。「中華職棒自 1989 年成立,走過 35 年,如今終於有了能夠凝聚全民認同的『Team Taiwan』!」在他看來,大巨蛋帶來的不只是硬體升級,更讓外界重新看見:運動賽事具備連結城市、串起家庭與驅動產業的可能性;只是熱度能否延續,考驗才正要開始。

號召各界投入運動經濟

「運動賽事是團結社會、凝聚向心力的重要催化劑。」李鐘培說。但催化劑要發揮作用,前提是舞台與參與能形成規模;否則再高的熱度,也可能在分散中迅速消退。

他以職籃為例,回顧「合」與「分」對賽事影響的落差。如 SBL 白館全盛時期,觀眾甚至站在冷氣機上觀賽;後來聯盟分裂,觀眾分散、收視也分散,整體聲量隨之下滑。「只要聯盟之間能夠有效整合,整體產業就有機會出現跳躍式成長。」他強調的不是單一聯盟的成敗,而是當賽事要走向更大規模,整合始終是繞不過的門檻。

NMEA
圖/ 數位時代

當整合成為前提,制度與資源如何接棒,也就成為下一個關鍵。隨著體育署升格為運動部,且由具運動員背景的部長領軍,也振奮了運動界。其中,運動部成立「運動贊助媒合平台」,提供多達 74 種賽事,讓企業與個人贊助者得以依條件參與投入,並爭取企業減稅比例提升至 175%、減稅實施期間拉長至 10 年;此外,為表彰長期投入者,自民國 98 年起也持續辦理「體育推手獎」。

對此,李鐘培也特別感謝贊助體育的數百家企業。他認為,每一塊獎牌的背後,都有贊助單位的支持與祝福;而支持若能更穩定地進入制度與市場循環,選手與賽事才更有機會被看見,也走得更遠。

四大策略,助攻運動娛樂經濟

不過,產業要長出可持續的動能,還得回到「誰把賽事留在場上、留在螢幕上」。李鐘培直言,電視媒體願意轉播體育賽事,其實背負的是連年的虧損。在沒人看得到的地方,他坦言:「基層賽事沒人要播、國際賽事成本極高。緯來體育台成立 28 年,就有 27 年都在虧錢,已經虧損 24 億。」

但要讓體育走得更遠,光靠單一電視台苦撐不是辦法。因此,李鐘培主張產業必須合作,共同打造賽事、娛樂、觀光的國際生態圈,「將餅做大、共榮共好。」他以他山之石提出四大策略方向:科技導入、在地深耕、城市品牌、跨界合作。

例如:美國快艇隊新主場 Intuit Dome,透過科技化建置、轉播技術升級、球場智能化,優化整體觀賽體驗;在地深耕則關乎球隊如何成為城市文化的一部分,如 LeBron James 的街頭彩繪壁畫「洛杉磯之王(The King of LA)」,即以球星形塑城市識別;跨界合作則可結合知名 IP 與社群經營,如 MLB 美國職棒大聯盟與日本超人氣動畫《鬼滅之刃》的聯動,都是擴大參與的做法。以及,新加坡封街舉辦 F1 賽事,打造「賽事+娛樂+觀光」的國際生態圈和體驗,帶動完整產業鏈發展。

回望台灣,他認為運動產業有無限可能,但需要各界共襄盛舉。他拋出一個具體想像:「若 U18 等基層賽事票房不佳,是否可由公部門購票,邀請國中小棒球隊孩子進場觀賽,讓選手與觀眾共同感受國際賽事氛圍?」同時,企業也可支持基層運動與偏鄉體育,作為 ESG 中「S(社會)」的重要實踐:如緯來體育台在上屆亞運承諾協助選手圓夢,包含支持運動團體、年邁教練與偏鄉運動設備等。

NMEA
圖/ 數位時代

整合,讓台灣運動再次偉大

談到更長遠的發展,李鐘培再把視野從運動賽事拉高,綜觀台灣在更大產業版圖中的位置。以規模來看,臺灣 2024 年運動產業產值約 257 億美元,與美國約 5,200 億美元、日本 775 億美元、韓國 552 億美元相比,仍有相當大差距。

同時,儘管台灣出口總額已超越日韓,但其中約 80% 集中於半導體與高科技;相較之下,影音內容的國際化仍有巨大潛力。目前臺灣內容出口僅佔總出口約 0.2%,日本約 1.99%,韓國約 1.96%。

日本《鬼滅之刃》劇場版創下影史紀錄、全球票房達 6.4 億美元;韓國 BTS 則為韓國帶來約 46.5 億美元經濟貢獻。若臺灣內容產業能達到 2% 的出口占比,規模將達 128 億美元,仍有約 8.6 倍的成長空間。

而要走到那一步、讓內容走出去,媒體端也必須面對收視生態的結構變化。李鐘培指出,收視從無線三台時代,走到有線電視百家爭鳴,再到數位串流時代,關鍵不在頻道競爭,而在觀眾收視習慣與載具轉移。媒體必須自省內容是否具跨世代吸引力;廣告上則需整合電視的品牌效果與網路的轉換導購,協助客戶達標,同時避免過度置入影響觀眾體驗。

演講最後,李鐘培仍把焦點放回「整合」:號召各界持續共襄盛舉,成為運動員與運動產業最穩定的後盾。在大巨蛋啟用之後,賽事與內容的下一局如何開展,關鍵不只在一場比賽的熱度,而在於是否能成功整合資源,讓台灣運動、內容及娛樂經濟能乘勝而起,衝出更好的成績。

登入數位時代會員

開啟專屬自己的主題內容,

每日推播重點文章

閱讀會員專屬文章

請先登入數位時代會員

看更多獨享內容

請先登入數位時代會員

開啟收藏文章功能,

請先登入數位時代會員

開啟訂閱文章分類功能,

請先登入數位時代會員

我還不是會員, 註冊去!
追蹤我們
進擊的機器人
© 2026 Business Next Media Corp. All Rights Reserved. 本網站內容未經允許,不得轉載。
106 台北市大安區光復南路102號9樓