GameDesign 板


LINE

一直以来都有个疑问 虽然物件导向教学都说继承与多型是OOP的特色 不过在游戏设计时常常需要制作很多同一个架构但不同功能的类别 比如说技能,部队这一类 我是应该遵照OOP的特色,为每一种技能实作一个类别呢? 还是应该写在同一个类别里,透过控制属性去产生不同效果呢? 又或是有其他更好的方法呢? 我目前是采用多类型的作法,但是类型一多又总觉得看起来很乱 因为我程式都是自学为主,所以想请问一下通用的作法是哪一种 麻烦各位先进提供一下意见 -- ██ ︵︵︵︵ ◢█◤ ちから /\||| ◢█◤ ひとりでは耐え切れぬ でもきっと、 │‵╯︶︶| ██◤ # ふたりなら大丈夫私は信じる!」 ╲ ) ∕█████ + + ╮ - │█◣ ◥◥█◣ 第四巻 27ページ… ▂▄▆│ │█◤* ◢████◣ 雷神の系谱    ψWix --



※ 发信站: 批踢踢实业坊(ptt.cc), 来自: 219.85.240.42
※ 文章网址: https://webptt.com/cn.aspx?n=bbs/GameDesign/M.1445651896.A.A0C.html ※ 编辑: wix3000 (219.85.240.42), 10/24/2015 09:59:37
1F:推 littleshan: 如果用不同的property就能达到效果,那一个类别就够了 10/24 10:02
2F:→ littleshan: 但如果程式码中充满switch case判断式,就应该用多型 10/24 10:05
3F:→ littleshan: 如果你不知道规则,就思考一下增加新技能时需要做什麽 10/24 10:07
4F:→ littleshan: 好的设计是你只需要添加程式码,不用修改既有程式码 10/24 10:08
5F:→ littleshan: 亦即所谓 open-close 的原则 10/24 10:08
6F:→ wix3000: open-close吗... 嗯嗯,我会多留意 谢谢 10/24 10:25
7F:推 cowbaying: 同楼上 用文档设定的方式来设计技能是比较经济的方式 10/24 10:53
8F:→ cowbaying: 但切记资料要加密阿... 10/24 10:54
9F:推 ddavid: 也可以参考版上Component-Based的那篇 10/24 10:55
10F:推 NDark: #1CVGwFfX (GameDesign) 10/24 10:58
11F:推 cjcat2266: 当下流行的架构是组件式,之後会不会有新的流行不一定 10/24 13:26
12F:→ cjcat2266: 也有人继承式和组件式混和用,像我们公司就是这样 10/24 13:27
13F:→ cjcat2266: 最基本的几种物件架构是以继承方式组成,专精的细功能 10/24 13:28
14F:→ cjcat2266: 则是用组件的方式组合起来 10/24 13:28
15F:推 holymars: Interface和Component混搭还蛮常见的 10/24 15:02
16F:推 holymars: 概念上是:先定义好你这堆需要多型的物件会有怎样的操作 10/24 15:04
17F:→ holymars: 介面,但实作上用delegation的方式转交给Component 10/24 15:07
18F:→ holymars: 这样你的物件就能轻巧灵活组合(component-based的优点) 10/24 15:09
19F:→ holymars: 但又能有共通的操作介面和型别(多型的优势) 10/24 15:09
20F:→ enthos: 通用的作法: 支援LUA script,方便做MOD. 10/24 15:56
21F:→ wix3000: 介面我还不太会用呢XD 不是很理解介面该用在什麽情况 10/24 17:58
22F:→ KanoLoa: 地方板上需要更多的组件式OOP资源 10/24 19:47
23F:→ KanoLoa: ←在unity写子弹常常会觉得我到底是要组件还是多型... 10/24 19:49
24F:→ wix3000: 组件导向似乎很适合游戏 但是组件要写得够抽象好像很难.. 10/24 20:01
25F:推 cjcat2266: 其实就是一个 obj.AddComponent(component) 介面 10/25 03:50
26F:→ cjcat2266: 剩下自由发挥 10/25 03:50
27F:推 cjcat2266: 还有,不要陷入"要写一个超完美引擎"的圈套里 10/25 03:52
28F:→ cjcat2266: 把游戏做出来比较重要,反覆产出游戏之後,自然就会对 10/25 03:53
29F:→ cjcat2266: 游戏引擎架构有比较好的概念 10/25 03:54
30F:→ cjcat2266: 人家Unreal也是副产品,他们不是一开始就以开发商业 10/25 03:54
31F:→ cjcat2266: 引擎为目的,而是不断产出游戏之後,一个可以拿来卖的 10/25 03:55
32F:→ cjcat2266: 引擎才慢慢成形 10/25 03:55
33F:→ cjcat2266: 老话一句 "Make games, not game engines." 10/25 03:55
34F:推 LayerZ: 引擎是以前写游戏的副产物,除非是要卖引擎才要写到完美 10/26 18:23
35F:推 FukadaKyoko: 靠要 这篇推文都是神 10/26 19:04
36F:推 LayerZ: 之前也有遇过同样的困扰,後来发现会困扰的原因是,不论是 10/26 19:06
37F:→ LayerZ: 类别还是参数控制都是对的,对底层运作而言不需要类别只 10/26 19:06
38F:→ LayerZ: 需要参数,对设计者自己控制而言把参数类别化控制就不用 10/26 19:07
39F:→ LayerZ: 烦恼细节,结论:混用就好.. 10/26 19:07
40F:推 chrisjeremy: 我的作法跟火星大一样 这麽做比较好用而且清楚 10/27 23:59
41F:→ chrisjeremy: 伤害计算跟演出最好分开一点 不要写在一起 10/28 00:01
42F:推 eulbos: 大推cjcat2266大大说的!! 豁然开朗 10/28 15:36







like.gif 您可能会有兴趣的文章
icon.png[问题/行为] 猫晚上进房间会不会有憋尿问题
icon.pngRe: [闲聊] 选了错误的女孩成为魔法少女 XDDDDDDDDDD
icon.png[正妹] 瑞典 一张
icon.png[心得] EMS高领长版毛衣.墨小楼MC1002
icon.png[分享] 丹龙隔热纸GE55+33+22
icon.png[问题] 清洗洗衣机
icon.png[寻物] 窗台下的空间
icon.png[闲聊] 双极の女神1 木魔爵
icon.png[售车] 新竹 1997 march 1297cc 白色 四门
icon.png[讨论] 能从照片感受到摄影者心情吗
icon.png[狂贺] 贺贺贺贺 贺!岛村卯月!总选举NO.1
icon.png[难过] 羡慕白皮肤的女生
icon.png阅读文章
icon.png[黑特]
icon.png[问题] SBK S1安装於安全帽位置
icon.png[分享] 旧woo100绝版开箱!!
icon.pngRe: [无言] 关於小包卫生纸
icon.png[开箱] E5-2683V3 RX480Strix 快睿C1 简单测试
icon.png[心得] 苍の海贼龙 地狱 执行者16PT
icon.png[售车] 1999年Virage iO 1.8EXi
icon.png[心得] 挑战33 LV10 狮子座pt solo
icon.png[闲聊] 手把手教你不被桶之新手主购教学
icon.png[分享] Civic Type R 量产版官方照无预警流出
icon.png[售车] Golf 4 2.0 银色 自排
icon.png[出售] Graco提篮汽座(有底座)2000元诚可议
icon.png[问题] 请问补牙材质掉了还能再补吗?(台中半年内
icon.png[问题] 44th 单曲 生写竟然都给重复的啊啊!
icon.png[心得] 华南红卡/icash 核卡
icon.png[问题] 拔牙矫正这样正常吗
icon.png[赠送] 老莫高业 初业 102年版
icon.png[情报] 三大行动支付 本季掀战火
icon.png[宝宝] 博客来Amos水蜡笔5/1特价五折
icon.pngRe: [心得] 新鲜人一些面试分享
icon.png[心得] 苍の海贼龙 地狱 麒麟25PT
icon.pngRe: [闲聊] (君の名は。雷慎入) 君名二创漫画翻译
icon.pngRe: [闲聊] OGN中场影片:失踪人口局 (英文字幕)
icon.png[问题] 台湾大哥大4G讯号差
icon.png[出售] [全国]全新千寻侘草LED灯, 水草

请输入看板名称,例如:WOW站内搜寻

TOP