Game Planning | 類圖(Class diagram)的使用流程與步驟

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

前言

  這篇文章將會講述類圖的基本介紹,並且詳細敘述從零開始製作完整的類圖流程。

類圖

  類圖是企劃版本的程式設計,甚至有一群以 UML 為主的程式設計師,他們不負責撰寫程式,專門製作 UML 的各式圖形,我在之前有撰寫一篇文章介紹它的基本介紹及類圖的寫法,詳情可以參考:

一、視覺化程式邏輯

  在程式設計之前先繪製 UML 圖,能協助程式設計進行視覺化的幫助,程式有哪些變數、哪些函式,並且在開始撰寫之前用更低成的本與更高的效率進行程式的規劃。
  開學後,在新的專案中我嘗試使用 UML 的方式進行程式撰寫,效果雖然沒有到很好,因為我們是規劃完工能後就直接開始撰寫程式,不過有一個視覺化的紀錄效果依然很好。
  當我使用 UML 之後,我就能跟另一位程式用比較具體的方式去討論程式設計的內容,哪一個 class 有問題、哪一些函式說的不夠清楚,也能去判斷是否完成功能的實行。

二、功能需求的呈現

  在單純的 UML 中,就能看出一個類別的功用與職責,並且能妥善地呈現是否有達成物件導向的單一職責原則,是否疊加了許多不同的功能,還是良好的只執行一個單一功用。
  功能需求是我在撰寫這篇文章後想到的部分,因為我撰寫的時候習慣只列出公有函式而非私有函式,因為我以為給其他程式有關連的部分比較重要,。
  這時我想到,當初撰寫程式時,其實為了完成單一職責,把函式細分成很多種不同的函式,這應該可以在 UML 階段去規劃,這項功能可以拆分成多少私有的函式。

三、程式腳本的關聯

  如果有經歷過那種專案後期,應該有不少人體驗過太多程式碼纏繞,不知道這個程式腳本與哪一個式腳本有關聯,這個值是否會被其他值給改變,有哪些物件會控制這個程式腳本,這些資料都能一目了然。
  程式之間的關聯在前期並沒有太大的影響性,因為前期的程式碼並不會太過於複雜,然而在設計程式時,很有可能一再疊加程式碼上去,導致最終的程式碼過於複雜,用 UML 的輔助是很有幫助的方法。

五大流程

  我目前撰寫 UML 文檔,主要預計有五個步驟,雖然我目前應該只到第四個步驟而已,不過第五個步驟是我下一步預計要處理的內容,所以我依然寫進這篇文章了。

一、廣泛列舉可能需要的遊戲需求與功能

  首先,把遊戲中的「所有」功能與需求列出來,只要腦袋想到一種遊戲功能或遊戲需求,就先寫下來,哪怕重覆也沒有關係,重覆列出腦中飄過的思維,直到腦袋一片空白為止。
  基本上遊戲在這一塊會有很多可以處理的內容,包括遊戲管理員、玩家按鍵輸入、主角行動、敵人智能、場景控制等等,把腦中浮現出來了所有內容都列舉出來,並繼續撰寫其中的子功能。

二、分割程式功能,直到不可分割為止

  當我們列完所有功能,開始繼續分割,每一寫出來的功能,包括子項目,這個功能是否可以分為不同的單一職責:例如玩家移動,玩家按下按鍵、確定方向、給予推力等等,這一連串的過程初步就能分成三個基礎功能。
  這個動作要持續到不可分割為止,現在應該會有很多功能陳列,依照大致上的功能把類似的項目放在一起,以便於下一階段的進行。

三、合併相似的功能與需求

  現在我們有了一群以功能分類的項目,把那些相似的功能合在一起,例如玩家跳躍、玩家移動、玩家調查都會使用到 GetAxis 來取得玩家輸入,因此可以把他們之中關於玩家輸入的部分就會合併。
  當我們把所有相似功能合併之後,我們就能用這些功能去實現各種不同的功能;除此之外,也適合繼續製作出其他功能,以利維護與擴增,因為之後遇到類似功能的時候,只需要讀取這段資料即可。

四、開始製作 Class diagram

  此時就可以開始製作比較詳細的規劃,也就是製作 Class diagram,開始思考比較詳細的變數與函式安排,哪些是私有、公有的變數或函式,逐步規劃每一項前面確定好的功能。

五、排列並增加連接

  最後,把這些各自獨立的類圖連接起來,詳細可以參考我之前寫的文章或者網路上提供的教學,類圖的連接比較複雜,不過記得箭頭指向的是關聯對象,而非來源,應該會比較好理解。

後記

  這篇文章講述了我對於類圖的理解,裡面有很多項目都是最近的感悟,因此可能有些簡陋或潦草,不過都是屬於比較印象深刻的部分。

瓶裝雪

即將進入廣告,捲動後可繼續閱讀
為什麼會看到廣告
avatar-img
106會員
247內容數
對設計師如何成長為設計師好奇嗎? 2020年九月,我進入大學學習當一位設計師,從開始到沉寂,再到重燃熱忱,我將在方格子紀錄我的成長歷程、理念、心情,分享我在這段旅程中所經歷的故事。
留言0
查看全部
avatar-img
發表第一個留言支持創作者!
瓶裝雪的沙龍 的其他內容
這篇文章將會介紹函式(Function)及其回傳值(retrun)的定義及介紹。
這篇文章將會講述 Inspector 的簡易優化小技巧,並介紹系列文章。
這篇文章將會講述陣列泛型 List<T>的介紹及使用。
這篇文章將會講述子彈時間、暫停時間相關的時間規模。
這篇文章將會介紹函式(Function)及其回傳值(retrun)的定義及介紹。
這篇文章將會講述 Inspector 的簡易優化小技巧,並介紹系列文章。
這篇文章將會講述陣列泛型 List<T>的介紹及使用。
這篇文章將會講述子彈時間、暫停時間相關的時間規模。
你可能也想看
Google News 追蹤
Thumbnail
隨著理財資訊的普及,越來越多台灣人不再將資產侷限於台股,而是將視野拓展到國際市場。特別是美國市場,其豐富的理財選擇,讓不少人開始思考將資金配置於海外市場的可能性。 然而,要參與美國市場並不只是盲目跟隨標的這麼簡單,而是需要策略和方式,尤其對新手而言,除了選股以外還會遇到語言、開戶流程、Ap
Thumbnail
嘿,大家新年快樂~ 新年大家都在做什麼呢? 跨年夜的我趕工製作某個外包設計案,在工作告一段落時趕上倒數。 然後和兩個小孩過了一個忙亂的元旦。在深夜時刻,看到朋友傳來的解籤網站,興致勃勃熬夜體驗了一下,覺得非常好玩,或許有人玩過了,但還是想寫上來分享紀錄一下~
Thumbnail
這篇內容,將會講解什麼是腳本函式,以及與腳本函式相關的知識。包括腳本的簡介、使用函式(或全域變數)的注意事項、定義全域變數、定義函式、什麼是宣告、局部變數的應用。
Thumbnail
這篇內容,介紹了知識傳遞的三種型態,以及GameMaker教學的分類方式。閱讀本篇指南,能夠理解GameMaker教學的整體規劃和知識結構。
Thumbnail
這個章節主要介紹了Swift程式語言中物件導向程式設計的基本概念,包括類別、建構子、公開、私有、受保護等等的概念。同時,也介紹了繼承、多型、封裝、介面、抽象類別、靜態類別、列舉、委派、Lambda表達式、泛型和反射等進階特性。
Thumbnail
本章節是一個初級的 TypeScript 教學,主要介紹了 TypeScript 中物件導向程式設計的各種核心概念,包括類別、建構子、存取修飾子、繼承、多型、封裝、介面、抽象類別、靜態類別、列舉、委派、Lambda 表達式、泛型和反射等。每個概念都通過詳細的解釋和實例代碼來進行深入的介紹。
Thumbnail
在設計有四年快五年的時間,大部分都是從實戰經驗中去不斷摸索產品開發的流程。從視覺傳達的背景出來,在用戶體驗的經驗都是在實際開發中去摸索出來的。不是理論派,只是根據我本人的經驗摸索出來的設計方法,也不會用太多高深的詞彙說明。 以前搜尋怎麼做產品設計?究竟是要從什麼步驟開始的這件事情,大部分看到的
Thumbnail
在物件導向程式設計的進階階段,學生將學習繼承、介面、抽象類別等核心概念。繼承允許類別共享屬性和方法,介面確保實現類別提供特定的方法實現,而抽象類別定義了基本結構供子類別擴展。這些知識點有助於提升程式碼的重用性、擴展性和維護性。
Thumbnail
UI設計是一個令人著迷的過程,它將設計概念轉化為最終的產品界面。本文將帶您深入瞭解UI設計的六個階段,包括Sketching、Wireframing、Component Design、使用者流程、模型設計和原型製作,以幫助您更好地理解每個階段的作用和重要性。
Thumbnail
列出一套完整的程式 程式設計有許多種方法,不過通常會先列出清單的再逐一執行,這樣會加快程式設計的速度。設計通常會採取順推的辦法。所以順推的程式設計方式就是經歷觀念溝通、系統分析、資料統合、權限管理、頻率與時間、後台管理、畫面設計等等階段後,將框架設計完了以後,先列出一套完整的程式,將所有使用者都確
Thumbnail
系統的分析與規劃 在談到程式設計時,首要的是進行系統的分析與規劃。程式設計的起點通常是系統分析與規劃,這涉及到如何分析和設計系統的大原則和方向。為了達到預期效果,重要的是擁有對產業的清晰邏輯認識和深入了解。 進行深入了解 若要進行系統分析,必須對企業的設計和程式設計的對象進行深入了解,以充分理
Thumbnail
替產業做設計 有人要我談程式設計,那我就稍微談一下。我從事的大都是產業的工作,所以我們也從如何替產業做設計來談起。基本上,每個產業都會有自己的作業流程,大同小異。但是基礎來做都是一樣的,都會有客戶、物料、產品、供應商、員工等資料。不同的是,由於企業型態的不同,他們每個人有不同的作業流程。這個作業流
Thumbnail
隨著理財資訊的普及,越來越多台灣人不再將資產侷限於台股,而是將視野拓展到國際市場。特別是美國市場,其豐富的理財選擇,讓不少人開始思考將資金配置於海外市場的可能性。 然而,要參與美國市場並不只是盲目跟隨標的這麼簡單,而是需要策略和方式,尤其對新手而言,除了選股以外還會遇到語言、開戶流程、Ap
Thumbnail
嘿,大家新年快樂~ 新年大家都在做什麼呢? 跨年夜的我趕工製作某個外包設計案,在工作告一段落時趕上倒數。 然後和兩個小孩過了一個忙亂的元旦。在深夜時刻,看到朋友傳來的解籤網站,興致勃勃熬夜體驗了一下,覺得非常好玩,或許有人玩過了,但還是想寫上來分享紀錄一下~
Thumbnail
這篇內容,將會講解什麼是腳本函式,以及與腳本函式相關的知識。包括腳本的簡介、使用函式(或全域變數)的注意事項、定義全域變數、定義函式、什麼是宣告、局部變數的應用。
Thumbnail
這篇內容,介紹了知識傳遞的三種型態,以及GameMaker教學的分類方式。閱讀本篇指南,能夠理解GameMaker教學的整體規劃和知識結構。
Thumbnail
這個章節主要介紹了Swift程式語言中物件導向程式設計的基本概念,包括類別、建構子、公開、私有、受保護等等的概念。同時,也介紹了繼承、多型、封裝、介面、抽象類別、靜態類別、列舉、委派、Lambda表達式、泛型和反射等進階特性。
Thumbnail
本章節是一個初級的 TypeScript 教學,主要介紹了 TypeScript 中物件導向程式設計的各種核心概念,包括類別、建構子、存取修飾子、繼承、多型、封裝、介面、抽象類別、靜態類別、列舉、委派、Lambda 表達式、泛型和反射等。每個概念都通過詳細的解釋和實例代碼來進行深入的介紹。
Thumbnail
在設計有四年快五年的時間,大部分都是從實戰經驗中去不斷摸索產品開發的流程。從視覺傳達的背景出來,在用戶體驗的經驗都是在實際開發中去摸索出來的。不是理論派,只是根據我本人的經驗摸索出來的設計方法,也不會用太多高深的詞彙說明。 以前搜尋怎麼做產品設計?究竟是要從什麼步驟開始的這件事情,大部分看到的
Thumbnail
在物件導向程式設計的進階階段,學生將學習繼承、介面、抽象類別等核心概念。繼承允許類別共享屬性和方法,介面確保實現類別提供特定的方法實現,而抽象類別定義了基本結構供子類別擴展。這些知識點有助於提升程式碼的重用性、擴展性和維護性。
Thumbnail
UI設計是一個令人著迷的過程,它將設計概念轉化為最終的產品界面。本文將帶您深入瞭解UI設計的六個階段,包括Sketching、Wireframing、Component Design、使用者流程、模型設計和原型製作,以幫助您更好地理解每個階段的作用和重要性。
Thumbnail
列出一套完整的程式 程式設計有許多種方法,不過通常會先列出清單的再逐一執行,這樣會加快程式設計的速度。設計通常會採取順推的辦法。所以順推的程式設計方式就是經歷觀念溝通、系統分析、資料統合、權限管理、頻率與時間、後台管理、畫面設計等等階段後,將框架設計完了以後,先列出一套完整的程式,將所有使用者都確
Thumbnail
系統的分析與規劃 在談到程式設計時,首要的是進行系統的分析與規劃。程式設計的起點通常是系統分析與規劃,這涉及到如何分析和設計系統的大原則和方向。為了達到預期效果,重要的是擁有對產業的清晰邏輯認識和深入了解。 進行深入了解 若要進行系統分析,必須對企業的設計和程式設計的對象進行深入了解,以充分理
Thumbnail
替產業做設計 有人要我談程式設計,那我就稍微談一下。我從事的大都是產業的工作,所以我們也從如何替產業做設計來談起。基本上,每個產業都會有自己的作業流程,大同小異。但是基礎來做都是一樣的,都會有客戶、物料、產品、供應商、員工等資料。不同的是,由於企業型態的不同,他們每個人有不同的作業流程。這個作業流