出し惜しみせずに3Dの技術を誰かが答えます
■ このスレッドは過去ログ倉庫に格納されています
00011
01/11/15 21:43ID:EsRJgfGr誰かが答えます。
じゃんじゃんネタ振ってくれ。
俺も業界で飯食ってるが知ってる事は出し惜しみせずに
答えるよ。みんなでレベルアップしようぜ。
とりあえずBBXとBio120%の過去ログは見とけ。
0074名無しさん@お腹いっぱい。
01/11/20 14:31ID:WD3W2AjAわかんねー
0076名無しさん@お腹いっぱい。
01/11/20 15:51ID:???2chなのでななしさんですますことにする。
つーか、解からない事ありすぎるから教えろや、ゴルァ!!
0077名無しさん@お腹いっぱい。
01/11/20 15:59ID:???一時期の洋ゲー方式ですね。
OpenGL対応ボードが普及したのもQuakeのおかげみたいなもんだしヽ( ´ー`)ノ
0078_
01/11/20 16:21ID:t2UWc/yC0079(・∀・)つ∴ニクコプーンクエ!!
01/11/20 16:54ID:???この頃は、春になるとスギ花パーティクルによる結膜炎で悩みます。
パーティクル超嫌いです。
悩みをブチマケたらスッキリしました。
008051
01/11/20 17:54ID:???いただいたアドバイスどおりに実装しようとして
マップデータのローダーを観てて気付いたのですが、
「Stripしてる三角形の扱いはどぎゃんすればよかですか!?」と。
独立した三角形としてプログラム内で扱って…というのは
手としてアリなんでしょうか?そのためのプリミティブの保存領域や
コマンドの転送が余計に必要になりますよね?
0081名無しさん@お腹いっぱい。
01/11/20 20:20ID:???表示モデルとあたり判定を取らないほうがいいよ。
もっとローモデルにしたものを独立三角形データで
用意してバウンディングボックスデータを
事前に生成しておく。
008251
01/11/20 21:00ID:???>>マップデータのローダーを観てて気付いたのですが、
↓
「マップデータのローダーを書くために、
モデルデータを観てて気付いたのですが、」
>81
狼狽しててわかりにくい日本語で書いたにも関わらず
回答ありがとうございます。
つーことは、描画・表示用のプリミティブデータと
当たり判定用のローモデルデータを別に用意した方が
ベターって理解でいいでしょうか?
んで、バンウンディングボックスなんですが、
その格子の中に頂点を持っている三角形であれば対象にしても
構わないんですよね?
008344
01/11/20 21:05ID:???コラム一通り見たけどテクスチャ自体の作成は無いと
思うが。
IF氏あたりがコラム書いてくれねーかなぁ。
動的スフィアで屈折&反射マッピング。
0084名無しさん@お腹いっぱい。
01/11/20 21:58ID:???>当たり判定用のローモデルデータを別に用意した方が
>ベターって理解でいいでしょうか?
そうしないとバウンディングボックス用のデータ作成に
時間がかかるじゃん。
>その格子の中に頂点を持っている三角形であれば対象にしても
>構わないんですよね?
それも当然対象になるけどボックス内に頂点が無くても
三角形がボックスと交差している事はある。
ボックスの12個の辺が三角形と交差していないか
面と直線の判定で調べる必要がある。
0085名無しさん@お腹いっぱい。
01/11/20 21:59ID:???0086名無しさん@お腹いっぱい。
01/11/20 22:22ID:???0087名無しさん@お腹いっぱい。
01/11/20 22:35ID:???0088名無しサソ
01/11/20 23:03ID:???分かりにくい解説かなぁ・・・。
要するにスフィアマップを特殊な座標変換で直接作成する
お話なんだけど。
0089名無しサソ
01/11/20 23:08ID:???>83
場所を間違っていると行けないので一応。
bioのBBSに話題が出ているから、たどってみよう。
それでも分からない事があれば質問をどうぞ。
009083
01/11/21 00:54ID:???>お話なんだけど。
結局それが必要なのは解っているんだけど仕組みが
イメージ出来てないおれ。
フレームバッファに背景描いてからテクスチャにコピー
した後に特殊な変換掛けるって感じなの?
でもそれだと前面以外の横や上下分もレンダリング
してやらないとダメなような。
360度って事だと結局6方向要るだろうし。
なんか物凄い勘違いしているとは思っているが。
もしかしてモデルの頂点トランスフォームを自前で
全てやって単位化した円のなかに納まるように変換して
トランスフォーム済み頂点で描画して作成するとか。
んな恐ろしい事するわけないか。
0091名無しさん@お腹いっぱい。
01/11/21 01:06ID:xQAW9/lm0092名無しサソ
01/11/21 01:16ID:???その「もしかして」が正解(笑)
DirectX7からだと、直接テクスチャサーフィスに描画できるから、
フレームバッファに書かなくても大丈夫だよ。で、描画先にSphereMap
用に確保したサーフィスを指定して、自前の変換で円の中にがりがり
書いていく。その座標変換の方法を紹介してあるんだけど。
ただ、色々欠点があるので、Dual-Paraboroidの方を詳しく勉強
した方がいいかも。
009390
01/11/21 01:31ID:???ななななっなにゅ〜!!悪夢のようだ。
んじゃ頂点シェーダー使わないと速度的に無理じゃん。
しかも全方位のモデルを描画だからクリッピングも
クソもオクールジョンカリングも無い。
グランツーの様なゲームで動的環境マップしようと
したら背景ポリゴン多すぎて不可能じゃないの?
そのへんはDual-Paraboroidとやらも同じでっか?
0094名無しサソ
01/11/21 01:55ID:???映り込むオブジェクトを上手く取捨選択するのなら、そこまで
無理ではないよ。自前変換にかかるコストは比較的高いけど、
死ぬほどではない。問題は破綻をどう防ぐか。通常のクリッピング
とは全然勝手が違うからね。
具体的な解決策としては、簡略化した背景をいくつかのブロック
に分けて置いて、距離的に離れたオブジェクトは最初から描かない、
とかね。一度に描くのが2000ポリゴン前後位だったら、CPU側の処理
でもまだ現実的だと思う(Pentium!!!クラスのPC、TNT2以上のビデオ
カード前提で)。もちろん出来る限りの高速化の工夫は必要になりそう
だけど、何とか実用にならないかなぁ。
ちなみに、Dual-Paraboroidもやっていることは基本的に一緒。ただ、
話を聞いた限りでは、180度の映り込みを2枚描いて、それを切り抜いて
かつ歪ませてSphereMapを作るとか。某氏は座標変換をVertexShader、
画像処理をPixelShaderに任せているという話。
0095名無しさん@お腹いっぱい。
01/11/21 13:20ID:???横入りスマソ。おれもちょうどその辺やってるんで。
円の中に収まるように描いていくってとこだけど、
画角を180度とかに広げて描画したらそれっぽくならないですか?
あと、この話題で出てくるHPのアドレス教えてくださいナリ
009695
01/11/21 13:24ID:???カメラ方向に向いた視点をセットして周りの背景とかを描画するんでOK?
複数オブジェクトに環境マップしたいときは・・・コストかかりまくり。鬱
0097名無しさん@お腹いっぱい。
01/11/21 15:09ID:???Dynamic Sphere Mapping
http://www.opengl.org/developers/code/sig99/advanced99/notes/node180.html
Dynamic Dual-Paraboloid Mapping
http://www.opengl.org/developers/code/sig99/advanced99/notes/node187.html
http://cgi3.tky.3web.ne.jp/~tkano/DynamicParaboloid.shtml
advanced99では、いったんキューブマップに通常の線形変換で描画してから
それを歪ませて環境マップを作成している。一方、Kano氏の方法では、
頂点座標を非線形変換させて環境マップに直接描画している。
通常の線形射影変換では、原理的に画角を180度にはできないのでは?
0098名無しさん@お腹いっぱい。
01/11/21 21:34ID:kiEpb28WDirect3DでXファイルを読み込んで表示するまではできたんですけど(ライブラリ使いましたが)
モデリングする時と実際に表示される時の大きさが分からないと不便なので
カメラも視点がXY方向の平面に垂直だとして、
3Dでの640が画面の640ピクセルになるようにしたいんですが、
(0,0,0にある640*480の物体が画面いっぱいに表示されるということ)
どのような式を書けばいいんでしょうか。
カメラに映るZの範囲は-100〜100にしたいです。
ということはカメラのZは-100ですよね。
XYに垂直なのでX = 0, Y = 0 まではわかるんですが、
視野角度というものを何度にすればいいのか分かりません。
教えてください。
009993
01/11/21 21:55ID:???確かにCPUで2000ポリぐらいは行けそう。
それでも背景は2回描くはめになるからやっぱり
コストは高そうだなぁ。
VertexShaderで頂点変換は必須になりそうだ。
写りこみ用モデルはローポリ&テクスチャで
ごまかしたやつを使うか。
>>97
>一方、Kano氏の方法では、
>頂点座標を非線形変換させて環境マップに直接描画している。
kano氏もいぢわるしないで日本語でバカにも解るように
解説してくんねーかなぁ。
0100名無しさん@お腹いっぱい。
01/11/21 22:12ID:???スレ違いだと、思うぞ。
OpenGLプログラミングガイドにそれなりに載っている。
3D初心者はDirectXよりも、OpenGL+GLUTライブラリの方が良いと思うが。
0101名無しさん@お腹いっぱい。
01/11/21 22:30ID:???トランスフォーム済みの頂点フォーマット
使っちゃダメ?
2Dスプライト的に使うならD3DFVF_XYZRHWを
使えば十分。
3DでやりたいならCマガジンの10月号で
似たような記事があったよ。
>>100
まっageてくれたからいいじゃん。
おれ的には初心者の質問もOKだと思うよ。
0102名無しさん@お腹いっぱい。
01/11/21 22:57ID:???>kano氏もいぢわるしないで日本語でバカにも解るように
>解説してくんねーかなぁ。
掲示板やメールで質問してみるとか。
ここも見てるだろうけどリアクションは無いと思うのん。
つうかKanoさんモテモテね。きゃは。
0103名無しさん@お腹いっぱい。
01/11/22 00:34ID:hpjXjtgwこのエフェクトやってみたいんですが仕組みについて
ヒントだけでも聞かせてもらえないですか?
0104名無しさん@お腹いっぱい。
01/11/22 00:54ID:GSH8d9fw上で散々っぱら話されている動的スフィアマップと大体同じ考え
なんじゃないかな。
違うのはテクスチャー行列(というかテクスチャの座標変換)
を反射から屈折にするくらいかな。
っていうか屈折って行列で表現できるのかはわからないけど。
0105名無しさん@お腹いっぱい。
01/11/22 01:15ID:???モデルの頂点を透視変換かけたものをuv座標に
してから適当にずらすとかあったが。(んなアホな)
他の可能性としてはバンプマッピングも
考えられんか?おれには解らんが。
0106名無しさん@お腹いっぱい。
01/11/22 01:18ID:???別に、動的スフィアみたくテクスチャを変形しなくても
背景をテクスチャにレンダリングしてそれをそのまま
環境マップ用のテクスチャとするだけでそれっぽく見えないかな?
変換の式を適当にいじる必要はあるだろうけど。詳細はわからんっす。
屈折マッピングについては
↓聖地とか
http://developer.nvidia.com/view.asp?IO=Refraction_paper
↓聖書とか
Game Programming Gems
・・・にあります。
0107名無しさん@お腹いっぱい。
01/11/22 01:21ID:???0108名無しさん@お腹いっぱい。
01/11/22 01:29ID:???動的キューブ環境マップか動的スフィアが
必要になってきて速度的にヤバそうだな。
>背景をテクスチャにレンダリングしてそれをそのまま
>環境マップ用のテクスチャとするだけでそれっぽく見えないかな?
この路線がいいとは思うがそのままだとうまく
いかんと思うなぁ。
0109名無しさん@お腹いっぱい。
01/11/22 01:38ID:???普通に考えると、
>背景をテクスチャにレンダリングしてそれをそのまま
>環境マップ用のテクスチャとするだけでそれっぽく見えないかな?
このやり方では映り込んでいるように見えると思う。
屈折させたいなら環境マップとテクスチャ座標の計算式は
変えなきゃだめだと思う。
0110名無しさん@お腹いっぱい。
01/11/22 01:43ID:???>変えなきゃだめだと思う。
Gemsにもあるスネルの法則ってやつで
屈折させるんだと思うけど、どこにどーやって
組み込むんだろう。
環境マップも頂点シェーダーで独自で計算とか?
0111名無しさん@お腹いっぱい。
01/11/22 01:45ID:???0112名無しさん@お腹いっぱい。
01/11/22 01:45ID:???光の進入角を-Nと考えると、結構簡単に屈折した法線角を
でっちあげることはできそう。
0113名無しさん@お腹いっぱい。
01/11/22 01:50ID:???0114名無しさん@お腹いっぱい。
01/11/22 01:55ID:???なるんだけど、なんか小手先みたいな感じがして積極的に
ゲームに取り入れる気がしないよう。
もっと包括的に、シーングラフレベルでのテクニックみたいなの
はないかなあ。シーングラフで屈折マップも表現できるのなんて
無いか。
0115106
01/11/22 02:32ID:???↓
SetTextureStageState(1, D3DTSS_TEXTURETRANSFORMFLAGS, D3DTTFF_COUNT2)
SetTextureStageState(1, D3DTSS_TEXCOORDINDEX, D3DTSS_TCI_CAMERASPACENORMAL)
・・・とかやってみる。
↓
マトリックスをゴニョゴニョ
↓
屈折まっぷ(゚д゚)ウマー
とか、こんな程度でなんとかならんもんかと妄想してみる俺・・・
0116名無しサソ
01/11/22 09:32ID:???SphereMapを使うと良いとは思うけど、光学迷彩はそこまでしなく
ても良いんじゃないかな。透過する背景が遠方にあると仮定して、
屈折した先の光線の角度を視野角内に何とかして収めれば、
フレームバッファをそのままテクスチャに使えると思う。多分(適当)。
厳密にやるならPixelShaderとかの出番だね。真面目にやるか
汎用性・高速性を取るか。PSのMGSでもそれなりに見えるから、
自分は後者で良いかな。
0117名無しサソ
01/11/22 09:38ID:???>95
SphereMapは球の表面に映り込む風景だから、単純に
視野角を狭めるだけではおかしくなると思う。>96のはその通り。
これはCubeMapも一緒だね。解説は>97にも紹介されている
けど、bio100%の3DFollowsBBSにその話題が出ているから、
リンクを辿ってみて。ちなみに、自分が話しているのは>97の
ようなCubeMapからSphereMapを作るの方法ではなくて、直接
ShereMapを描画する方法。
>99
当たり前の話だけど、人間の目って動く物体の映り込みの
中身まで、そんなに見ていないよ。と言うわけで、ローポリで
十分だし、実際にもそうされていると思う。GT3でもよく見ると
案外省略されまくってるし。ただ、動的か否かはやっぱり違うね。
0118名無しさん@お腹いっぱい。
01/11/22 10:03ID:???0119名無しさん@お腹いっぱい。
01/11/22 10:08ID:???その形をレンズに置き換えて見ると向こう側の絵は
虫眼鏡のように拡大されるはずじゃないですか。
それが環境マップのように縮小されて張られているけど
おかしくない?
0120115=106
01/11/22 11:58ID:???D3DTSS_TCI_CAMERASPACENORMAL
じゃなくて
D3DTSS_TCI_CAMERASPACEREFLECTIONVECTOR
だった。
・・・つってもただの妄想なんでいちいち訂正せんでもいいが。
0121名無しさん@お腹いっぱい。
01/11/22 13:44ID:/aoY3CGVIF氏って誰?
0122名無しさん@お腹いっぱい。
01/11/22 13:57ID:???http://www5.tok2.com/home/IF/index.html
0123名無しさん@お腹いっぱい。
01/11/22 14:13ID:3nhjK6ydThanks。解説が詳細でイイ!
0124名無しさん@お腹いっぱい。
01/11/22 21:32ID:hpjXjtgw>屈折した先の光線の角度を視野角内に何とかして収めれば、
>フレームバッファをそのままテクスチャに使えると思う。多分(適当)。
その計算式が解るなら苦労しないんだけど。
いまいち根拠にとぼしいから試す時間を裂けん。
もしかして成功例とかある?
>>120
>D3DTSS_TCI_CAMERASPACEREFLECTIONVECTOR
試してみたが屈折というより反射に見えるじゃないか。
その妄想完成させてくれよ。
0125名無しサソ
01/11/22 21:58ID:???申し訳ない。こちらも時間が割けないのは同じでね(苦笑)
光学迷彩は上に書いてあるようにBBXの少し前のログに
残ってるよ。11月3日の書き込み。そこから実践している
ページもリンクされているので辿ると良いよ。個人的には、
あんまりここで直接リンクを張りたくないんだけど、良いのかなぁ。
自分はちょっと嫌な物で。
0126名前は開発中のものです。
01/11/23 00:04ID:???それなら、JAVA、3Dあたりの用語でわかる人はわかるかと。
0127124
01/11/23 01:12ID:???>光学迷彩は上に書いてあるようにBBXの少し前のログに
>残ってるよ。11月3日の書き込み。そこから実践している
>ページもリンクされているので辿ると良いよ。個人的には、
さんきゅ〜。確かに実践してるんで参考になるよ。
やっぱ実際に見ると感動があるね〜。
あれなら時間裂いて試す価値あり。
ただ120の言ってる環境マップを利用した方法も
可能じゃないのかなぁと期待はしてたりする。
あとバンプ利用するとピクセル単位で屈折を
表現出来そうで面白そうだなぁ。
0128名前は開発中のものです。
01/11/23 05:39ID:???0129120
01/11/24 08:33ID:???そうですか、反射に見えますか・・・なるほろ。今後の参考にします(^^
#って、自分の妄想の実験を人任せにする奴
0130名前は開発中のものです。
01/11/27 17:11ID:???0131名前は開発中のものです。
01/11/28 15:08ID:???実際にゲームで使われてるのかなぁ?
このゲームは凄いよみたいな情報キボンヌ
0132名前は開発中のものです。
01/11/28 17:21ID:???某箱用のゲームで使われていくハズ。
0133名前は開発中のものです。
01/11/29 01:06ID:???どっちが高速に処理できるんだろ?
つーか動的環境マップで一番実用的なのはどれ?
0134名無しサソ
01/11/29 10:40ID:???だとセルシェード系はこれを使っているのでは?他に高速で実現出来る
方法を知らないだけかも知れないけど。
>133
現状ではCubeMap以外選択肢がないかも。GeForce/Radeonが
それなりに普及していて、でもShaderがそれ程普及していない現在だと。
自分はSphere派だけど、あまり未来はないと感じてるよ(苦笑)
0135名前は開発中のものです。
01/11/29 13:46ID:???もちろんTnLHALで可能。詳しくはHeidrichのオッサンの論文でも読んで。
動的生成の場合のネックは座標変換とZテストかな。
1枚のテクスチャがカバーする視野が180度なおかげでクリッピングが簡単だから、
描画負荷はSphereとそう変わらないレベルになりそう。テクスチャは2枚だと
RenderTargetの切り換えで遅くなりそうだから、1枚のテクスチャをViewPortで
分けて使うのがいいかと。
>>134
半球ライティングとテクスチャは関係ないよ。
テクスチャを併用するとShaderでは内積を1回計算するだけで済むから、近似
としてテクスチャが使われることはあるけど。ただ、テクスチャを使ったシェー
ディングはテクスチャのサイズをかなり大きくしないとマッハバンドが目立つ
のが欠点。
0136名前は開発中のものです。
01/11/29 14:32ID:???座標変換は具体的にどうやるんですか?
0137名無しサソ
01/11/29 14:47ID:???いや、現状でテクスチャ以外で実装している人は居るのかな、と。
・・・・・良く考えればShaderが使えるよの中だから、居そうだね(自滅)
マッハバンドは嫌な欠点だね。使いどころを考えないと。
0138名前は開発中のものです。
01/11/29 23:04ID:???0139名前は開発中のものです。
01/11/30 01:05ID:poVUBJ45おれもDual Paraboloidは全然理解してないけど
頂点の座標変換ならココで説明してる気がする。
http://www.opengl.org/developers/code/sig99/advanced99/notes/node185.html
このページの説明を実践すれば欲しいテクスチャが2枚生成されるって
事でよいかな?試した人いる?
0140名前は開発中のものです。
01/11/30 01:47ID:???誰か試した?
0141135
01/11/30 03:06ID:???Dual ParaboloidはD3DTSS_TCI_CAMERASPACEREFLECTIONVECTORを使うわけだけど
D3DTSS_TCI_CAMERASPACEREFLECTIONVECTORで自動的に計算されるベクトルと、
環境マップされる物体から環境までのベクトルとの関係を考えれば簡単に分かると
思いますよ。
# ズバり答えを書いてもいいけど、図でも描いて自分で考えてみてください :-)
# これって出し惜しみ?
SphereMapの場合は、ハーフベクトルを求める必要があるんですよね?>やった人
そのコストを考えると、Dual Paraboloidでも座標変換のコストはほとんど変わら
ないと思います。
0142名前は開発中のものです。
01/11/30 07:52ID:???DirectXでトゥイーニングを使った 人物のアニメーションを自前でつくろうとしているんですが、
メタセコイア を使って同じ頂点数で ポーズの違うXファイルを2つ用意して、時間によって頂点座標を
線形補完させるというやりかたをしようと思ったんですが、
モデリングした2つのXファイルの頂点情報の並び方が違ってしまいます。
座標を変えても同じ頂点情報の並びになるようなモデリングソフトを誰か知りませんか?
0143136
01/11/30 12:57ID:???いや、なんか基本的なことが解かってないんで申し訳ないです・・・
Dual〜とかsphere用のテクスチャを作成する際に
テクスチャに対してレンダリングしますよね。
その時に座標変換用のマトリックスを作成して透視変換をかけると
思うんですが、これって通常のプロジェクションマトリックスの替りに
環境マップ用のものにすれば良いということですか?
なんか、レベル低くて申し訳ないっす・・・鬱氏
0144名前は開発中のものです。
01/11/30 14:54ID:???2パターン作ればすむ話では?
0145名前は開発中のものです。
01/11/30 21:09ID:poVUBJ45市販の3Dソフトならだいたい出来ると思うけど。
使った事ないけどフリーならMikotoってのもあるが。
http://www2.nbn.ne.jp/~you-ri/cgi-bin/?11271800
http://niigata.cool.ne.jp/cyphers/tuft/miko/
それより頂点列の並びが変わるってのは元データを
少しいじってXファイルにしても元データと並びが
変わってるの?普通あまりありえんと思うけど。
0146名無しサソ
01/11/30 21:35ID:???案外こういう事している人達って多くはないのかな?
>141
ハーフベクトルという言葉の詳しい定義は知りませんが、
全天球の空間を半球の空間に変換する計算の事でしょうか?
多分それ程負荷は変わらないかと。クリッピングを除けば。
しかし、どうも知っている人のような・・・(笑)
>142
そう言う物なの?>144の話している通りでは駄目なのかなぁ。
マテリアルとかを変更していると変になりそうだけど。元が同じ
モデルで頂点座標だけ移動させる限りは大丈夫のような。
0147名前は開発中のものです。
01/11/30 21:45ID:???入らないポリゴンはクリッピングで省くんですか?
でもそれを判定するには座標変換しないとわからない
と思うから結局半球への変換は背景モデルを2回
座標変換するって事?
もしそうだとスフィアの2倍変換が必要になるけど。
0148名前は開発中のものです。
01/11/30 22:37ID:???出し惜しみしないで質問しまくると厨房と呼ばれてしまう罠(鬱)
しかも、某BB※とか野朗BBSでも同じく教えて君な俺…
#いや、低レベルな質問には答えるようにしてますってば。(←それしか答えられない)
0149135
01/12/01 01:11ID:???ハーフベクトルは、ようするに2つのベクトルのニ等分角のベクトルです。
ttp://www.microsoft.com/japan/developer/directx/japan/dx8/SpecularLight.asp
ついでなので、DynamicSphereEnvironmentMappingのページを見てきたけど、座標変換に
三角関数使ってるんですか?ベクトルで計算するともっと簡単だと思いますよ。
長さが同じ2つのベクトルを足すと、それだけでハーフベクトルが求められます。
SphereMapの座標系で計算してるなら、ハーフベクトルを正規化すればそのx,y成分がその
まま求めたい座標になると思います。
DualParaboloidの場合は位置ベクトルに行列1つ掛けてxとyをzで割ってあげればいい
のかな?あまり変わりませんね。
SphereMapもDualParaboloidも実際には試してないので、嘘ついてたらゴメン :-)
DualParaboloidはVertexShaderだけで実現するメドが立ったので、暇ができたら試して
みます。
>案外こういう事している人達って多くはないのかな?
してても表で発言できない人は多いと思います。
>>147
DualParaboloidの1つのテクスチャに必要な視野は180度だから、カメラの前か後ろか
の判定だけでクリッピングできますよ。その判定はカメラの方向ベクトルのz成分と物体
への方向ベクトルで内積を計算するだけです。
ちなみにSphereMapもDualParaboloidも極点が存在するので、クリッピングしないと
カメラの正面や真後ろをまたぐポリゴンが画面を覆ってしまう問題があります。
SphereMapでは極点がテクスチャの必要な領域に存在するので困りますが、DualParaboloid
では極点がテクスチャの外側になるので単純にクリップするだけでほとんど解決でき
るかと。クリップしなくても頂点のα成分にカメラの方向ベクトルのZ成分との内積を
入れれば、αテストで背面のポリゴンは消せそうですね。座標変換のコストは減りませんが。
0150名無しサソ
01/12/01 12:39ID:???あ、言葉通りの意味ですか(笑)
で、実際に言われているとおり足して単位化すれば済む話
でしたね。最初に考えて、確か計算量が多そうだと勝手に
思い込んでいたようで・・・(駄目人間)
で、書き換えたコードはこんな感じです。
D3DVECTOR v,half;
FLOAT cosa = sqrt((1.0f+v.z)*0.5f) * 0.5f;
v.z = 0;
v = Normalize(v);
の部分を
half = v;
half.z -= 1.0f;
half = Normalize(half);
に。平方根が見事に減ってますねぇ(汗)ご指摘どうもです。
0151147
01/12/01 15:39ID:???おお、丁寧な説明のおかげでだいぶ頭の中にイメージが
出来てきた。クリッピングのコストが少し心配だけど
スフィアよりちょっと負荷がある程度ですむのかな。
これならVertexShader化まで試してみたくなるなぁ。暇ねーけど。
ちなみに俺は148じゃないよ。某BBSはロムってる。
先輩方サンキューです。
0152名前は開発中のものです。
01/12/01 16:54ID:Of8w23Ey動画じゃなくってすごいヤツ見ました。
0153名前は開発中のものです。
01/12/02 03:30ID:k+1aWkNwバネモデルで揺らせば出来そうだが。
エターナルアルカディアとかは町の人も髪や服が
揺れてるけどボーン方式とクロスの2種類な感じ。
プログラムで一人づつ作っていくなら量的に大変そう。
0154名前は開発中のものです。
01/12/03 11:53ID:???やっぱ、髪の毛とか乳みたくプログラムで特別に制御するモデルって
他の部分とは別で持つの?
それともモデル中にフラグ立てて管理してる?
0155153
01/12/03 21:18ID:???3Dソフトも布とかは跡付けでやってるし。
デザイナがモデリングした服とかの一部を揺らそうと
思うと頂点が等間隔じゃないからやりずらくないか?
0157名前は開発中のものです。
01/12/04 13:31ID:???行列だけでは無理ですね。VertexShader使うか、自分で変換する必要があります。
SphereMapもDualParaboloidも途中で正規化が必要になるので。
>>154
乳はボーンで処理するなら、制御するのはボーンだけでいいから、フラグ立てる
ならボーンの方ですね。
0158名無しサソ
01/12/04 13:33ID:???今までのレスを見ていれば分かりそうなんだけど・・・
ただ「分からないから」教えてくれ、と言うだけじゃ進歩が
無いよ。直接のレスでなくてもちゃんと関連する話題も
あったのだし。
投影行列に何か指定するだけで良いのであれば、
Shaderなんてわざわざ使おうとはしない。視野角を
180度に近くしても、球面上に映り込んだときの歪み
は再現できない。擬似的に出来ると思うのだったら、
自分で試してみるべし。
0159名無しサソ
01/12/04 13:34ID:???0160名前は開発中のものです。
01/12/04 13:57ID:???やはり、自前変換が必要なんですか・・・
たしかに、頂点座標を変換するだけでは球状のゆがみなんて再現できないですよね。
#ポリゴンを細かく分割していけば擬似的には再現できるかもしれないですが。
行列だけで何とかお手軽に、と思ってたんですが甘かったですね。
頂点シェーダーについても、もっと勉強してみます。
0161名前は開発中のものです。
01/12/04 21:32ID:???おいおい、このスレの性質からして教えて君が聞くのは
当たり前なんだよ。むかついたんなら無視しろよ。
誰かが質問して誰かが答えないとこのスレなりたたないよ。
>>160
http://www.daionet.gr.jp/~masa/column/98-11-07.html
masa氏のコラム参考になるぞ。
やった事は無いが背景ポリゴンの頂点座標からターゲットの
座標を引いて単位化したベクトルをm=2*sqrt(x*x+y*y+(z+1)*(z+1))
から書かれている式に入れればuvが求まると書いてある。
これで変換したポリゴンをTLVERTEXでレンダリングすればよさそう。
まずはCPUで頂点変換して物が完成してからシェーダー化
すればいいんじゃないの。
0162名前は開発中のものです。
01/12/04 23:17ID:???masaさんのページ見たけど、
その式はどうやって導出したものか説明がないですね。
教えて欲しい。
0163名無しサソ
01/12/04 23:39ID:???いや、別にむかついた訳じゃないんだけど・・・
話題がちゃんとでていたのだから、>156でもうちょっと
分からないことを絞って欲しかっただけだよ。気分を
害したのなら申し訳ない。マターリと行こう。
と言うわけで折角だからソース公開。汚いけど気合いで
読んでもらえると幸い。
D3DMATRIX vmat,wmat //vmat:ビュー変換行列 wmat:モデル変換行列
D3DVECTOR v,half; //v:単位化した頂点座標 half:ハーフベクトル
WORD a = *pTIndices; //頂点のインデックスを取得
wmat = *pMatrixStack->GetTop(); //モデル変換行列を取得
pd3dDevice->GetTransform( D3DTRANSFORMSTATE_VIEW,&vmat); //ビュー変換行列を取得
v = *((D3DVECTOR*)&pVertices[a]); //モデルの座標を取得
D3DMath_VectorMatrixMultiply(v,v,wmat * vmat); //ビュー座標への座標変換
v = Normalize(v); //vの単位ベクトル化
half = v;
half.z -= 1.0f; // vに視点ベクトルを足してハーフベクトルを算出
half = Normalize(half); //ハーフベクトルの単位化
m_pTLVertices[NumVertices].sx = half.x * 0.5f + 0.5f;
m_pTLVertices[NumVertices].sy =-half.y * 0.5f + 0.5f;
m_pTLVertices[NumVertices].sx *= viewport.dwWidth;
m_pTLVertices[NumVertices].sy *= viewport.dwHeight; //テクスチャのUVテクスチャ座標に変換
こんな感じ。
0164名無しサソ
01/12/04 23:41ID:???重そうなので2乗のままで保持していたり。この辺は適当で良いかも。
ただ、ライティングはこのままだと不可能。個人的にはやっても意味は
あまり無いと思っているので、していない。
0165名前は開発中のものです。
01/12/05 00:53ID:o0Rw16Fu>あまり無いと思っているので、していない。
あ、やっぱり。シェーダー考えるとライティングどうしようかなぁ
って思ってた。クランプとかいろいろちゃんとやると結構速度低下
するから省くか頂点カラーかどっちかがいいかなと。
でもアンビエントぐらい足してやりたいなぁ。
0166名前は開発中のものです。
01/12/05 01:06ID:???最近よくBRDFって聞くから気になる。
http://tom.g-micro.co.jp/graphic/01q1/010227/geforce3-23.html
#そういや半球ライティングとかの説明が出てた。
#DIYライティングが気になる。
http://www.microsoft.com/japan/developer/directx/welcome/dsmsdn/directx11192001.asp
0167160
01/12/05 01:30ID:???早速、教えてもらった部分を理解できるよう努力します。
#見ただけではすぐに理解できない辺りが・・・
俺的に今年度最高の名スレ&名レス認定。
>>161 教えて君で申し訳ない。
元々数学的素養が欠如してるので最近の3Dマンセーな開発事情は
辛いんですよ…いや、飯の種なんで頑張りますけどね。鬱氏。
0168名前は開発中のものです。
01/12/05 01:35ID:???ひょっとしてこれって説明じゃ。
http://www.opengl.org/developers/code/sig99/advanced99/notes/node177.html#s.equation
0169名前は開発中のものです。
01/12/05 02:03ID:???vの正規化の時点で距離は求まってるから、それを利用するといいかと。
それと、ライティングはオブジェクト空間で計算するといいですよ。
法線を変換するのではなくて、ライトをオブジェクト空間に変換します。
描画前に1回だけライトを変換すればいいので、法線を変換するよりも
計算量が少なくなります。スキニングとかの関係でオブジェクト空間では
処理できない場合もありますけど。
(いま書きかけのシェーダー関係のhtmlに全く同じ事書いてあるから、ます
ます身元がばれてしまうな)
0170名無しサソ
01/12/05 02:14ID:???プロの人?となると将来何かいい結果が目に見えて
生まれるのかな?期待してます(笑)
>169
あ、Z値はどうにかしてますです。上のコードには簡単の
為に書いてないだけで。あと、ライティングは実用では
わざわざする程の効果はあるのかな、と。ちゃんとする
のであれば、オブジェクト座標系が多分効率がいいでしょうね。
0171名前は開発中のものです。
01/12/05 10:47ID:DEoHzlOJマジでお金貰ってコード書いてる人?
それだけが知りたい。
0172160
01/12/05 11:37ID:???まぁ、プロにもピンからキリまであるって事っすよ。
低層プログラマの憂鬱・・・鬱出汁脳
0173名前は開発中のものです。
01/12/05 13:27ID:???動的環境マップをやるならこれくらいやらないと。
ムービーで確認せよ。
■ このスレッドは過去ログ倉庫に格納されています