鬱だ氏のう DirectX (Part 7)
■ このスレッドは過去ログ倉庫に格納されています
0001名前は開発中のものです。
02/12/10 17:34ID:tkEwMMYm初心者用相談室では扱わないような少し高度な話題も受け持つ。
■ 過去スレ
Part 1 http://piza.2ch.net/tech/kako/966/966655286.html (プログラム板)
Part 2 http://pc3.2ch.net/test/read.cgi/tech/997101556/ (プログラム板)
Part 3 http://game.2ch.net/gamedev/kako/1005/10051/1005119775.html
Part 4 http://game.2ch.net/gamedev/kako/1016/10162/1016276254.html
Part 5 http://game.2ch.net/test/read.cgi/gamedev/1027351925/
Part 6 http://game.2ch.net/test/read.cgi/gamedev/1033920036/
0678あぼーん
NGNG0679名前は開発中のものです。
03/02/16 15:10ID:lNvw3jDDなんか微妙な用途ですね。
地面につかうとでっぱったポリゴンがキャラにめり込むし。
うーん、誰か効果的な使い方を発見してくれるのをまつことにします。
0680名前は開発中のものです。
03/02/16 15:38ID:kG6Gu6Lzいや、DX9で定義された仕様を全部サポートしてくれた製品じゃないと嫌だなぁって話。
>>679
ディスプレースメントマップをハードでサポートなんて最高じゃんか。
使いまくれ!
ほら、6面体で焼けて膨らむ餅が表現できるぞ(笑)
それより俺はボリュームを何とかして欲しいなぁ……
0681名前は開発中のものです。
03/02/16 16:54ID:tDr+jqjfどういう手順でやればいいですか?
環境はVB6.0+DIRECTXでお願いします。
0682名前は開発中のものです。
03/02/16 17:22ID:3FlUVw2pLPDIRECT3DSURFACE8 tmp;
D3DLOCKED_RECT lock;
d3ddevice->CreateImageSurface(::GetSystemMetrics(SM_CXSCREEN), ::GetSystemMetrics(SM_CYSCREEN), D3DFMT_A8R8G8B8, &tmp);
d3ddevice->GetFrontBuffer(tmp);
tmp->LockRect(&lock, NULL, 0);
RECT rc;
GetClientRect(hwnd, &rc);
int w = rc.right - rc.left;
int h = rc.bottom - rc.top;
ClientToScreen(hwnd, (POINT*)&rc);
BYTE *buf = new BYTE[sizeof(DWORD) * w * h];
for (int i = 0; i < h; i++){
CopyMemory( buf + sizeof(DWORD) * w * i,
(BYTE*)lock.pBits + lock.Pitch * (rc.top + i) + rc.left * sizeof(DWORD),
sizeof(DWORD) * w);
}
delete[] buf;
tmp->UnlockRect();
0683名前は開発中のものです。
03/02/16 18:34ID:A+y5e3fj>>645から読み直せ
0684あぼーん
NGNG0685名前は開発中のものです。
03/02/17 00:13ID:9vsIryvvDirectSoundではサウンドの同時処理は処理速度が許すかぎりいくらでもできる。
CAPSはハードウェアで処理できる限界であってソフトウェアの限界ではない。
0686名前は開発中のものです。
03/02/17 04:19ID:WS9BVvAx毎フレームごとに切り替えるんですか?
つまり、1フレームごとに、座標変換ありの頂点と座標変換なしの頂点を
交互に描画するんですか?
0687名前は開発中のものです。
03/02/17 04:43ID:mWd91DKTうん
0688名前は開発中のものです。
03/02/17 05:09ID:hdzUUYWwなんだそりゃ?
0689名前は開発中のものです。
03/02/17 05:25ID:aOw8ezq90690名前は開発中のものです。
03/02/17 07:19ID:hdzUUYWwだがな、用語が変だぞ。
0691名前は開発中のものです。
03/02/17 07:55ID:vF3bZenv0692名前は開発中のものです。
03/02/17 08:04ID:hdzUUYWw0693名前は開発中のものです。
03/02/17 08:23ID:jFMHe3lL0694名前は開発中のものです。
03/02/17 08:58ID:dBcKYU7J0695名前は開発中のものです。
03/02/17 09:34ID:tG/PvClAなんだ、交互にって?テレビのインターレースかいな。
で、その頂点座標変換あり、なし混在の場合、
頂点変換なし(2D)描画が常に画面の手前になってしまう。
背景(3D)のobjectと何かしら処理が絡むなら(objectをくぐるとか)
自キャラ(2D)もビルボード使って
板ポリで、頂点変換ありでやった方が良いんでない?
0696名前は開発中のものです。
03/02/17 10:48ID:E/qUSJ/70697あぼーん
NGNG0698名前は開発中のものです。
03/02/17 16:57ID:k1lu5QbB3Dを背景とした2Dゲーって言われてもピンと来ないのよね…
地形が3Dで2Dのビルボードを使ったゲームなのか、
背景は3Dだが見た目は完全に2Dなのか。
前者ならビルボードだけど後者だとスプライト。
0699名前は開発中のものです。
03/02/17 17:43ID:mWd91DKT0700名前は開発中のものです。
03/02/17 18:07ID:lk5pRAb10701名前は開発中のものです。
03/02/17 18:26ID:KxwQBCAS>>700のほかにも、
サターンの初期にクロックワークナイトってゲームがあったけど、
あれが確かそういうタイプのゲームだったような。
0702名前は開発中のものです。
03/02/17 20:26ID:k7503aDO残り時間の表示とかは座標変換無しでそのままやりますよね。
まあ、Zバッファ切ってから最後に描画するんでしょうけど。
0703名前は開発中のものです。
03/02/17 22:59ID:68dkEVgwなんで?いいじゃん描いちゃえよ。
0704名前は開発中のものです。
03/02/17 23:04ID:HE1lwuh3Zバッファ切らないで描画したら上書きされないの?
>>702
座標変換なしで描画したら解像度変わった場合大きさが変わらない?
0705名前は開発中のものです。
03/02/17 23:21ID:hdzUUYWwちょっとでも気の利いたことするわけないじゃん。
640x480x16bpp 60fps固定 FSAAなし
以外選べないゲーム作ってる奴らだからな。
0706名前は開発中のものです。
03/02/18 00:17ID:9ivC/Ath解像度変わったらそれに合わせた座標にすりゃいいじゃん。
っていうか、ほとんどのゲームで2Dアートワークってサイズ固定で、
高解像度にすると小さくならない?
0707名前は開発中のものです。
03/02/18 00:20ID:2XDOY6wz解像度は3:4をまもっとけば後からでも変更はいくらでも効くでしょ。
Zバッファはそもそも座標変換ありのものもなしのものも違いないでしょ。
ちなみに2D座標の場合のZの値は1.0が最前面だった気がする。
まあ、前面に描くものはα物だらけだと思うが。
0708704
03/02/18 00:22ID:qi2fP5U0>ほとんどのゲームで2Dアートワークってサイズ固定で、
>高解像度にすると小さくならない?
それはカコワルイと思うけどなぁ
0709名前は開発中のものです。
03/02/18 00:24ID:G8QFcNbI0710名前は開発中のものです。
03/02/18 00:58ID:7nhEB5ouその違いが無い、座標変換ありと無しの
無しの方Zの値をどうやって決める?
ワールド上を自由に動くオブジェクトやカメラの場合、ワールド変換、カメラ変換、ビュー変換
して座標変換ありの頂点は、Z値を持つ訳だ。
そのZバッファに、変換無しの頂点のZ値を、どう対応させる?
まさか、前面描画なんて言うなよ。
それと、α物とZバッファの関係が分ってないようだね。
もしα物が画面奥にあって、その周りを何か物体が回っているなんて場合
君のやり方じゃ、実装不可能だろ。
0711名前は開発中のものです。
03/02/18 00:59ID:r2vh2WJc0712あぼーん
NGNG0713名前は開発中のものです。
03/02/18 01:10ID:HS6mmhB0LightWave使っとります。
0714名前は開発中のものです。
03/02/18 01:14ID:KGJUoVgYそういうのって10マンぐらいするよね。
やっぱ買うわけ?
0715名前は開発中のものです。
03/02/18 01:19ID:SbwOx8MJ0716名前は開発中のものです。
03/02/18 01:19ID:HS6mmhB0当たり前でしょ。あと値段、30万近くするって。
0717名前は開発中のものです。
03/02/18 01:30ID:KGJUoVgY>>715
タイホー。
0718名前は開発中のものです。
03/02/18 02:36ID:Ahzziud70719あぼーん
NGNG0720名前は開発中のものです。
03/02/18 02:45ID:THIYqgowそれを専門に扱った本がみつからないんですよね。
何かありますか?
0721名前は開発中のものです。
03/02/18 02:57ID:HS6mmhB0http://pc.2ch.net/cg/
こっちで聞いたほうがいいと思うが。
0722名前は開発中のものです。
03/02/18 04:28ID:THIYqgowところでみなさん、浮動小数点の絶対値を求めるときどんな関数を使ってますか?
fabsだとdouble型対象となってるので他に何かいいのあったら使いたいのですが。
0723名前は開発中のものです。
03/02/18 04:56ID:HS6mmhB00より小さければ−1をかける、でいいのでは
0724名前は開発中のものです。
03/02/18 08:02ID:QS9PEt6sfabsf・・・結局はdoubleだけどさ・・・。
0725名前は開発中のものです。
03/02/18 09:19ID:5aGkziqdstrcmpで"}"を文字列比較をする時に、lpStringに"てすと"等の違う文字列が
入っていても1(true)が帰ってきてしまいます。
例:
int tmp;
tmp=strcmp(lpString,"}");
しかし、上記で1がtrueと言っていますがMSDNを見ると0が帰ってくるとtrueらしいのです(;´Д`)
0なんて帰ってきた事なんてありませんし…。
どなたかアドバイスお願いします
0726名前は開発中のものです。
03/02/18 09:39ID:QS9PEt6s↓
if (a<b) r=負の数;
if (a==b) r=0;
if (a>b) r=正の数;
0727名前は開発中のものです。
03/02/18 09:53ID:7nhEB5ouなんだかな。ココはDirectXスレな訳で。
Cの構文なら、プログラム板にでも…。
アスキーコード知ってるかい。
文字は全て、数字が対応してるのよ。
strcmpは内部で減算してるだけ。
つまり同じ文字列なら、減算の結果が0で、戻り値が0な訳だ。
だから、戻り値が0なら同時な文字列であろうって感じなだけで
それがtrueな分け無い。
0728名前は開発中のものです。
03/02/18 10:32ID:5aGkziqdということは、これでいいわけですね(・∀・)
if(lpString[0]=='>'){
}
0729名前は開発中のものです。
03/02/18 10:33ID:9TfHrH9k0730名前は開発中のものです。
03/02/18 12:21ID:3N95F/CvつかDirectXと全然関係ないやん
0731名前は開発中のものです。
03/02/18 13:58ID:VIlmLJi8>解像度は3:4をまもっとけば
3:4以外にも対応するべし。1280*1024は5:4なんだなこれが。
2D表示部分はタスクバーのように画面の端にくっつくようにプログラムを組むべし。
>>708
今までサイズ固定じゃないゲームを見たこと無いんだが。
まあquake2を高解像度でプレイしたときの文字の小ささはアレだと思ったが。
0732名前は開発中のものです。
03/02/18 14:11ID:HePtHIHl>3:4以外にも対応するべし。1280*1024は5:4なんだなこれが。
ついでに最近のメーカー製PCはワイド画面が増殖中ッスよ。
こんな感じで↓
http://pcweb.mycom.co.jp/pcbuyers/review/2002/combine/
いちおう考慮しておいたほうがよいやも。
0733名前は開発中のものです。
03/02/18 14:25ID:BxcSfeKF私が以前 DirectDraw でプログラムしていた時は
640x480(画面サイズ)の画像にチップを詰めてたのですが
Direct3D の場合は普通はどういう感じなんでしょうか。
同じように比較的大き目の画像にチップを詰めるのか、
各チップ(パターン)毎に1ファイルずつとか。
サイズはよく256x256というのを聞きますが
となるとやはりパターン毎に(最大256x256の)ファイルにするんでしょうか。
普通はこのぐらいのサイズまでなら大丈夫なんじゃない? という基準とか
あったら教えてください。
0734名前は開発中のものです。
03/02/18 14:38ID:TzLAjW+F256 x 256 (2^8 x 2^8) 推奨というのはそのへんから来ているのではないかと。
0735あぼーん
NGNG0736名前は開発中のものです。
03/02/18 15:18ID:heSsomrkDirectXの場合は1X1までミップマップをつくってくれちゃうんでしたよね。
0737名前は開発中のものです。
03/02/18 15:53ID:3N95F/Cv最大256x256が無難といえば無難。
あと、ファイルをそのままテクスチャにしなければならない、
という決まりはないと思う。
>>736
ミップマップを作成しないこともできるけど?
0738名前は開発中のものです。
03/02/18 16:48ID:f7hIAHrT自分は、テクスチャーを作る時に
ハードウェアの制限調べて(最大サイズとか、2の累乗のみとか、正方形のみとか)、
それにしたがって、内部で分割したり、正方形に修正したりしてるよ。
今のカードだと、制限もだいぶ無くなってきたけど、
Voodooとかだと、最大256*256 & 正方形のみ & 2の累乗のみ
とかの制限に全部引っかかったりするので。
0739733
03/02/18 18:29ID:BxcSfeKFそうですね。
4:3に慣れてしまったので違和感がありますが、、
>>737
256x256だと Voodoo も含めOKと。
>>738
それって難しくないですか?
絵を貼り付けた板を移動するときとか
今は一枚なのか二枚なのか意識しなくちゃならないし
自分がヘタレなだけかもしれませんけど。
最近の市販ゲームだと Voodoo には対応してません
と明記してあるやつが多いですけどそういうやつは
どのぐらいのサイズで作ってるのかなと。
と思ったら >>4 のサイトで調べられますね、、、
Rage Mobilityやi810ですら 1024x1024 いけるんですね。
不勉強でスミマセンでした。
0740738
03/02/18 18:58ID:PMYVEmVG難しくないよ。
スプライトクラスとかを作っておいて、
そのスプライトクラスのメソッド
例えば、CSprite::Load()とかで、テクスチャーを作成する時
ハードの制限等を調べて、分割なり、修正なりすればよい。
描画する時は、描画メソッド
例えば、CSprite::Draw()とかで、テクスチャーの修正情報に従って、修正描画すればよい。
1回スプライトクラスを作っとけば、使う時は何も考えずに使えるよ。
自分は大体こんな感じでやってるけど、みんなは違うのかな?
0741名前は開発中のものです。
03/02/18 19:19ID:BxcSfeKFなるほど。
Spriteクラスは1枚以上の板から成っている、と。
私がこの間3D始めてやっとこさ作ったSpriteクラス(Billbordクラス?)は
1インスタンス = 1枚という感じだったので、、
勉強になります。
0742あぼーん
NGNG0743名前は開発中のものです。
03/02/18 20:29ID:OmAR/C8b俺もラッパークラス作って使いまわしてるよ。
0744名前は開発中のものです。
03/02/18 21:17ID:VM4ycalOヘルプを見て、いきなり
>1. COM の初期化
>DirectMusic オブジェクトを作成するためのヘルパー関数はないので、
>CoInitializeEx を呼び出して COM を初期化する必要がある。
この関数(CoInitializeEx())の使い方、意味、次への繋げ方がもう分からんのですが。
[定義されてない識別子です。]
ヘルプ通り、objbase.h ってのIncludeしたのに!!!ヽ(`Д´)ノ
0745名前は開発中のものです。
03/02/18 21:34ID:3N95F/Cv0746名前は開発中のものです。
03/02/18 21:36ID:oY4uuy6qCOMのこと知らないみたいだからCOMの勉強すれば。
あとはサンプルやウィザードが吐くコードを見るとか。
0747名前は開発中のものです。
03/02/18 23:57ID:SbwOx8MJそもそもDirectX8で動くんか?
0748名前は開発中のものです。
03/02/19 04:01ID:3HHIicMN0749名前は開発中のものです。
03/02/19 04:34ID:K2W4Cmx9どのクラスに保持させていますでしょうか?
とりあえずDirectX8のサンプルにあるフレームやメッシュと同じ感覚で、
モーションデータをパーツ毎に持たせてみました。
しかし、これでは動作がボトムアップといいますか…一元的に管理できない感じで…。
かといって、モーションクラスを作り、トップダウンに個々の
パーツを管理するのも、主体が2重になりそうで…。
言ってることが曖昧ですいません。要するにモーションデータの管理について
悩んでいまして…なにか示唆をいただければ幸いです。
0750あぼーん
NGNG0751名前は開発中のものです。
03/02/19 06:34ID:b63auc8G0752名前は開発中のものです。
03/02/19 06:49ID:athMsZgq上位では階層化メッシュクラスのサブクラスで
アニメーションメッシュクラスを作って管理してます。
内部では各フレームごとにモーション情報を持たせてます。
自分的にはシーングラフには内部の詳細は不要なので、
混乱せずに扱えて便利だと思ってるです。
0753749
03/02/19 10:38ID:K2W4Cmx9レスが遅れて申し訳ありません。ついウトウトと…。
おお!フレーム毎に持たせてらっしゃるのですね。
私も内部の詳細は一切触らず(触れず)に、ただ状況に合わせて
アニメーションさせるだけなんです。やっぱり分かりやすいのが一番ですよねぇ…。
ただ初めての3Dということもあって、もしかしたらこういうのは
トップダウンの方が把握しやすのかなぁと、不安になりまして…。
おかげで安心しました。レスありがとうございました。
0754名前は開発中のものです。
03/02/20 01:00ID:aBMYS0Zfブレンド数やライトやらスペキュラを自由にOn/Offしようとすると
かなり破綻しそうなんですけど…。
9.0のフラグメントナントカって使えるかなー?
0755名前は開発中のものです。
03/02/20 01:16ID:CqEeT/jMマテリアルとかうまく管理しているならそれとよく似た方法で管理すれば問題ないはず。
# というか、シェーダーだけそんなに特別か?
0756あぼーん
NGNG0757名前は開発中のものです。
03/02/20 05:22ID:kkYbtpSU例外を返していますか?
0758名前は開発中のものです。
03/02/20 07:46ID:9HTvRHMZそもそもDirectXで例外ってあんまりみたことない。
(経験不足名だけかもしれないけれど)
DirectXのエラーを例外で処理するメリットが見当たらない。
0759名前は開発中のものです。
03/02/20 09:27ID:E8JYbNB2C++つかってるのに例外を使わないなんて考えられない。
0760名前は開発中のものです。
03/02/20 10:16ID:qrgwODJk予測可能かつ対処可能な失敗コードなら復帰を試みるけど。
DirectXが戻り値でエラーを通知するのはかなり限られた
ケースなんで、ほとんどの場合は例外になると思う。
0761名前は開発中のものです。
03/02/20 11:26ID:weLWt0f50762名前は開発中のものです。
03/02/20 11:35ID:E8JYbNB2関数一つ一つをtry catchで包むわけじゃないのでトータルすればif elseより速くなる(場合もある)。
0763名前は開発中のものです。
03/02/20 11:37ID:deJb/6Zdメインループをtryで包んで、対処不能なエラーとか出たら
例外投げて終了するようにしてるんですがダメでしょうか…。
0764名前は開発中のものです。
03/02/20 11:55ID:weLWt0f5まあそりゃそうだがね。
1つずつ包む(w)なんて使いかたしなきゃコードも見やすくなるし利点は大きいわな。
0765名前は開発中のものです。
03/02/20 13:59ID:tbIY2ozEなんかどこでエラー起こったか良く分からないこと多いし
自作のエラー処理ならどのファイルの何行目で起こったか一目瞭然だし。。。
0766名前は開発中のものです。
03/02/20 14:09ID:v3dcluNUJAVAの例外処理は遅くならない形で実装されている…らしい。
そもそも単にエラーを検出するための手段が本筋のプログラムの動作に影響していたら本末転倒だしね。
もしその発想がC++の設計思想にもあるのなら、エラー検出以外にも使わないのは損じゃない?
0767名前は開発中のものです。
03/02/20 15:03ID:RfvJUoXOむしろ例外使わないほうが破局に至ると思うが。
どこで起こったかわからないって、そら適切にキャッチしてないからやろ。
0768765
03/02/20 16:40ID:tbIY2ozESTLとか使ってるとたまに例外出るけど
どこでそれが起こったのかさっぱり分からん(英語で何やら書かれているけど・・・
0769名前は開発中のものです。
03/02/20 19:45ID:sNEDXPjVもともと遅いからあんまり気にならないだけ。
0770名前は開発中のものです。
03/02/20 21:44ID:iMrHJGZqJavaとか.NETのようなGC環境では、throw後スタックを
リワインドする時に破棄すべきオブジェクトを識別しなくて
いいからちょっとだけ速いと。
C++とかは、tryの時点で、throwされた後に破棄する
オブジェクトを区別する仕掛けをセットアップするので
ちょとだけ重いと。
C++なら、DirectX呼出し毎にtryやthrowしてては大変なので
せめてtryは大局的に使おう。と。
キーボードにマヨネーズが飛んだからこの辺で。と
0771名前は開発中のものです。
03/02/20 22:53ID:zbgoXdj/みなさん、C++なんですか?
0772名前は開発中のものです。
03/02/20 23:04ID:Xe8g5iFj0773名前は開発中のものです。
03/02/20 23:50ID:zbgoXdj/0774名前は開発中のものです。
03/02/21 01:32ID:gtRtCCD/7以前の、DltFastみたいに、画像の(10,10)から(100,120)を表示するにはどのような関数を使えばよいのでしょうか?
0775名前は開発中のものです。
03/02/21 01:42ID:gnTzXupSBltなら、CopyRectsが相当するのでしょうか?
Helpで検索して見てよ。
でも、クリッピング、カラーキー、拡大縮小、αブレンドは対応してないと思ったけど。
8だと、Spriteが推奨されてるよ。
つうか、DirectX9に切り替えれば?
Blt復活してますよ。
0776あぼーん
NGNG0777名前は開発中のものです。
03/02/21 02:00ID:gtRtCCD/Blt復活?
今手元には、I/O別冊DirectX8.03Dアクションゲーム・プログラムだけあるんだけど、概要だけの本なのでちとつらい。
自分で調べようと思って、ヘルプを今見ていたんだが、どうせヘルプで1からやるなら9がいいかなと思っていた。
9に以降しまつ。
おすすめHPなど教えてください。
■ このスレッドは過去ログ倉庫に格納されています