■ このスレッドは過去ログ倉庫に格納されています
3Dゲームの作り方を教えてください
- 1 :SSS:02/03/02 21:38 ID:L+chEJVO.net
- 3Dのゲームを作ってみたいのですがどのようにすればよいか全く分かりません。
そこで皆さんにいろいろと教えてもらいたいのですが、、、、
ツールは一応そろっています。またジャンルは問いません。
さらに参考になるウェブサイト、著作を教えていただければ幸いです。
どうかひとつお願いします。
- 243 :名前は開発中のものです。:2015/01/09(金) 12:36:19.08 ID:cpDVhBN/.net
- 通常は、総当りで出来る。
当たり判定に使う、必要最低限のポリゴンなら少ない。
処理が重いのならば、それはポリゴンが多すぎる。
シームレスの巨大マップにしたければ、
部屋に分けてポリゴンをグループ分けする。
自分の所属する部屋の中だけのポリゴングループに対して処理する。
色々な最適化がある、方法はマップの条件によって異なる。
- 244 :名前は開発中のものです。:2015/01/10(土) 07:38:44.87 ID:nNPbjeZG.net
- データ構造が判らないとなんとも言えない
むしろ判定に都合の良いデータ構造にする。
MAPを格子状に区切ってその格子の順番にポリゴンを格納する。
@ポリゴンの範囲はは格子よりも小さくしておく(最大のポリゴンを元に格子のサイズを決め手も良い)
Aポリゴン座標の最小値で格納する格子を決定する。例えば(Ax,Ay)、(Bx,By)、(Cx,Cy)なら(Ax,Cy)になりうる。
B格子ごとに連続してポリゴンを格納してき、インデックスを保存しておく
これで判定対象のいる格子と、-x側の格子、-y側の格子、-x-y側の格子の4つを範囲にあるポリゴンを
インデックスを元に参照する。検証は任せたw
自分が実際にやったのは基本1km単位で
各頂点のxy値は1kmの範囲内でランダムになっているメッシュ上の地形データで、
隣接する格子を含めた9つの格子の計18ポリゴンでチェック。
そしてHITした頻度の高いポリゴンから判定するようにインデックスを入れ替える。
建物は各所にグリッド状に配置するので、その全体を判定してHITすれば判定すべき建物と判定。
って感じだったかな。うろ覚えだけどw
- 245 :名前は開発中のものです。:2015/01/10(土) 08:31:26.61 ID:Ryzdgy9l.net
- >>244
ポリゴンを格子で区切るということは、格子と格子の接合面にあたるポリゴンは
格子の枠に沿った形状でつなげてあるということ?
でかい3Dマップも、格子状に分割できるようにポリゴンをつないでいるということ?
格子をまたぐポリゴンはないということ?
- 246 :名前は開発中のものです。:2015/01/10(土) 13:16:00.91 ID:earh9GX8M
- それは、高さマップと同じだなぁ
- 247 :名前は開発中のものです。:2015/01/11(日) 06:37:53.00 ID:SeJYfhrW.net
- 「ポリゴンを格子で区切る」なんて書いたっけ?
> 格子と格子の接合面にあたるポリゴンは
> 格子の枠に沿った形状でつなげてあるということ?
格子の頂点とポリゴンの頂点が一致するデータ構造でいいなら、そうするのが良いと思う。
> でかい3Dマップも、格子状に分割できるようにポリゴンをつないでいるということ?
いくつもの格子を跨ぐポリゴンがあると、
ある格子に掛かるポリゴンがどれだけあるか判定が大変になる。
> 格子をまたぐポリゴンはないということ?
跨ぐ前提で話をしている。
ポリゴンは最大で格子と同じサイズまでにすれば
1つのポリゴンは1つの格子と隣接するプラス側の格子に掛かる可能性がある。
これを逆に考えると
1つの格子にはその格子と隣接するマイナス側の格子に登録されたポリゴンが掛かる可能性がある。
- 248 :名前は開発中のものです。:2015/01/12(月) 01:18:11.06 ID:HlhvcqEy.net
- >>244
インデックスを格納した格子の構造体がたくさん?
その地形をロードするたびインデックスの並べかえはリセット?
- 249 :名前は開発中のものです。:2015/01/12(月) 15:47:53.77 ID:aAhaXk+Z.net
- >>242
>衝突判定自体はわかってる
一応聞くけど、兄さん >>197 や >>202 と同一人物じゃないのかね。
親切に回答している方も、そろそろ「?」ばっかり連発してる質問者が
あなたに“全部答えさせようとしている”と気が付いた方がいいんじゃないかな。
- 250 :名前は開発中のものです。:2015/01/15(木) 21:42:30.77 ID:XCAGVc2R.net
- それどころかどうせ3Dゲームが完成しない事も想定済み。
- 251 :名前は開発中のものです。:2015/01/16(金) 03:24:54.08 ID:QCVnSEdw.net
- ピンポイントで質問が浮かぶような人→たいてい自分で解決出来る。
初心者→何から手を付けていいか分からないから漠然とした質問しか出来ない。
答える方も基礎を学べとしか言いようがない。
気位だけ高い→基礎を学べと言われて逆切れする。
サイコパス→全部答えさせようとする。
…うまく噛み合わないね。
- 252 :名前は開発中のものです。:2015/01/16(金) 14:55:25.37 ID:1Snv1/Ug.net
- 簡単な3Dのゲームを作るなら、DarkBasicが良いと思う。
3Dライブラリを使って、簡単に3Dを扱えるようになっている。
初心者向けで、入門として良い。
サンプルコード( .dbaがソースコードになる。テキストファイル。)
http://www1.axfc.net/uploader/so/3393214
ある程度の雰囲気や概要がわかってきたなら、
高度な3D数学や物理を学ぶのが良い。
いきなり、難しい事から始めると、確実に挫折する。
- 253 :名前は開発中のものです。:2015/01/16(金) 22:30:09.87 ID:BdLRVVjH.net
- そして、オリジナル3Dライブラリ自作している自分に気がつく。
- 254 :名前は開発中のものです。:2015/01/16(金) 23:13:16.38 ID:603gq/0h.net
- モデラーとかアニメーションも
- 255 :名前は開発中のものです。:2015/01/18(日) 01:31:18.84 ID:OEVWJWuh.net
- いきなり難しいことから始めたら挫折するというけど、
難しいことを後回しにしたら挫折も後回しになるだけ。
- 256 :名前は開発中のものです。:2015/01/18(日) 02:06:54.61 ID:3/9SdjT+.net
- 例えば、小学校1年生から6年生へいきなり飛び越えても無理、
算数のたし算を知らなくて掛け算や連立方程式を計算できるわけが無い。
3Dの場合は かなりね、専門用語の壁が厚いのです。
- 257 :名前は開発中のものです。:2015/01/18(日) 04:52:53.86 ID:LhlxXUHN.net
- 行列やらベクトルの演算やら数学嫌いには拷問だよな
- 258 :名前は開発中のものです。:2015/01/18(日) 06:00:56.92 ID:Q3Wdh6kS.net
- 代数幾何の教科書読み直して理解できるくらいじゃないなら、
3D処理は出来合いのものを使ったほうが良い。つか必ず使わなきゃダメ。
- 259 :名前は開発中のものです。:2015/01/18(日) 06:42:47.62 ID:n+Z+LZlo.net
- 教科書はよく選んだ方がいいよね。プログラミングのための線形代数、お勧め。
巻頭のグラフ見るだけでも大分イイ!
- 260 :名前は開発中のものです。:2015/01/19(月) 00:28:48.30 ID:h8qE+fk3.net
- 昔のアニメ専門学校の広告でよくあったなあ。
「一から教えるからあなたにも大丈夫!」みたいなノリ。
高い入学費払って半分は中途退学。たまに成功する人もいるんだけど、
じつはそういうのは最初から才能を持ってる。
小1から中3まで算数や数学を順を追ってきちんと学んでも、高校数学で行き詰る人間が約半分。
順を追って学べば全て分かるなら、全ての人間がフェルマーの大定理が解けなきゃおかしい。
本当に勉強したければ、自分が行き詰ったところ、もしくは学ぶ機会のなかったところからやればいい。
それこそ小1の足し算からやって「俺にもできるかも!?」なんて気分だけ味わうのは時間と金のムダ。
- 261 :名前は開発中のものです。:2015/01/19(月) 00:33:40.10 ID:h8qE+fk3.net
- よく「足し算だけ、掛け算だけを解かせるとちゃんとできるのに、
足し算の応用問題を掛け算して解こうとする子供がいる」って話を聞くだろ。
人に勉強を教えると分かるけど、行列やベクトルの演算が分からない人、
まして数学が拷問に思えたり、教科書読んで分からなかったりする人は、
「計算が出来ない」んじゃなくて、「数式の意味や使い方が分からない」んだ。
意味や使い方そのものが分からないのに、ライブラリで何をどうごまかせるんだ。
- 262 :名前は開発中のものです。:2015/01/19(月) 00:43:52.49 ID:rXZoEcs9.net
- 3Dモデルを回転させるのに、回転行列を使う。
それを、ライブラリならば、「回転しなさい」というコマンドを使う。
これだけのこと。 四則演算で出来る。 あまり難しく考えてはいけない。
- 263 :名前は開発中のものです。:2015/01/19(月) 04:07:34.69 ID:S9THw46U.net
- 数学が判っていれば、本来なら行列を使うところを
一部の計算だけで同じ結果になるケースを見極めて
計算コストを省けるんだけどな。
でもそんな工夫している間にCPUが早くなっているw
- 264 :名前は開発中のものです。:2015/01/19(月) 15:20:56.05 ID:ZvVYE33q.net
- >これだけのこと。 四則演算で出来る。 あまり難しく考えてはいけない。
株に手を出せない人に投資信託を勧めるのと同じ。
本当は複雑で難しいことを、素人でも分かる程度に簡略化して、分かった気にさせる。
「分かった気にさせて、手を出させる」のが狙い。
- 265 :名前は開発中のものです。:2015/01/19(月) 15:36:39.73 ID:ZvVYE33q.net
- もう一度言うけど、3Dプログラミングは高卒かそれ以上の線形代数そのもの。
もちろん、昔それに挫折した人や機会がなかった人でも、やる気さえあれば腰を据えてやればいい。
それでできなくても得るものはあるだろう。
でもそこで腰が引けて迂回しようとしても他に道はない。他に道がありますよと言うのは甘言。
同じところをぐるぐる回らされていたと思い知らされるだけ。
- 266 :名前は開発中のものです。:2015/01/20(火) 22:41:28.21 ID:XwYpBp6C.net
- GPUって3Dに特化しすぎじゃね?
vector3 とか matrix4 とか何で決め打ちなん!
もっと任意長のベクトルを流し込んで並列処理するような
汎用性のある枠組みにしたほうが分かりやすいのに。
それで3D特化はシェーダプログラムのほうでやればいい。
そうすればこまごました仕様が一掃されてシェーダが書きやすくなるのに。
シェーダでいろいろなアルゴリズムを試そうと思ったけど
ハードウェアの区別と制限がごちゃごちゃに思えて手を出せぬ
- 267 :名前は開発中のものです。:2015/01/20(火) 22:56:20.52 ID:XwYpBp6C.net
- 2008年の時点でこの記事があるな
http://www.atmarkit.co.jp/news/200803/06/cuda.html
現在ではどうなってるんだろう?
GPUで ray tracing の画像をリアルタイムで描けたりするんだろうか?
- 268 :名前は開発中のものです。:2015/01/20(火) 23:13:07.51 ID:XwYpBp6C.net
- DirectX11 にコンピュートシェーダーというのがあるのか!
これで汎用アルゴリズムが直に書けるのかな?!
テンション上がるわー
Unity3D でも使えるんね
でも DirectCompute はまだシェーダ言語の一部という感じだが
C++ AMP というのを使うと C 言語っぽく汎用的に組めるのかな?
- 269 :名前は開発中のものです。:2015/01/21(水) 02:16:00.24 ID:oMkFY+XG.net
- Unity3D でも使えるんね
- 270 :名前は開発中のものです。:2015/01/21(水) 02:16:36.14 ID:oMkFY+XG.net
- ↑
何なんだよ、その不自然な改行。
おまえらステマ業者って根本的に相手をバカにしてるだろ?
- 271 :267:2015/01/21(水) 10:22:34.70 ID:yekSsXFj.net
- ごめん。普段から言動が不自然と言われるけど
うにちのステマ業者じゃないよ
ちなみに C++ AMP は unity じゃ使えないのでは?
C++ だし。
- 272 :名前は開発中のものです。:2016/03/23(水) 00:01:43.29 ID:SpSehPDt.net
- 教えてあげないよん
- 273 :名前は開発中のものです。:2017/02/03(金) 02:22:20.30 ID:1Nz75uXE.net
- age
- 274 :名前は開発中のものです。:2017/02/13(月) 04:25:06.90 ID:KNIkvquG.net
- けちんぼしないで
- 275 :名前は開発中のものです。:2017/12/31(日) 22:10:44.11 ID:/rN76OKL.net
- 簡単にお金が稼げる方法興味ある人だけ見てください。
グーグル検索⇒『来島のモノノリウエ』
JBWBKFVSM6
総レス数 275
75 KB
掲示板に戻る
全部
前100
次100
最新50
read.cgi ver.24052200