DXライブラリ 総合スレッド その3
■ このスレッドは過去ログ倉庫に格納されています
0001名前は開発中のものです。
2009/03/31(火) 01:14:36ID:IgyJcgapGUIのゲームを比較的容易に作成する事を可能にする、
「DXライブラリ」に関するスレッドです。
DXライブラリの詳細ついては
http://homepage2.nifty.com/natupaji/DxLib/
を参照して頂きたい。
DXライブラリに関するテクニックなどの情報交換などを行う事で、
多くのDXライブラリユーザのスキルの向上に役立てたら幸いです。
過去スレ:DXライブラリ 総合スレッド
http://pc11.2ch.net/test/read.cgi/gamedev/1197468399/
DXライブラリ 総合スレッド 2008
http://pc11.2ch.net/test/read.cgi/gamedev/1224923873/
0647名前は開発中のものです。
2009/07/01(水) 00:31:13ID:9VzVKeVm知人がタイマーイベント仕掛けてWM_TIMERがきたときにループ処理してたからそういうもんだと思って疑わなかった
0648名前は開発中のものです。
2009/07/01(水) 05:08:47ID:aia3X3LP0649名前は開発中のものです。
2009/07/01(水) 09:35:30ID:LrL8gFoC0650名前は開発中のものです。
2009/07/01(水) 19:59:44ID:eeCacGXjきちんと関数化、ライブラリ化すれば難しいゲームでも綺麗に書けるってこと
DXlibの機能には制限があるし、余計な機能もついているので、
最終的に自分で最適なライブラリを書くようになれるのがいいよ
0651名前は開発中のものです。
2009/07/03(金) 20:54:33ID:BsjXjKQw他の関数は普通に使える
0652名前は開発中のものです。
2009/07/04(土) 18:08:40ID:p2ue3IYDうちでは正常に動くが。ヘッダから消してしまったとか。
0653名前は開発中のものです。
2009/07/06(月) 22:42:09ID:AVbDbUwfおせーて
0654名前は開発中のものです。
2009/07/08(水) 01:56:14ID:OgMSMAZ50655名前は開発中のものです。
2009/07/08(水) 02:25:32ID:94RipojrSetLoopPosSoundMemではだめなの?
0656名前は開発中のものです。
2009/07/08(水) 02:58:22ID:OgMSMAZ5ありがとうございます。すみません、説明不足でした。
PlayMusicでストリーム再生し、ループ位置を設定したいのです。
0657名前は開発中のものです。
2009/07/08(水) 11:53:36ID:Qn1Es1PySetLoopPosSoundMemとSetCreateSoundDataTypeを使って解決しました。
ありがとうございました。
0658名前は開発中のものです。
2009/07/08(水) 22:05:37ID:qTICtjjxRAM 4GB
GPU GeForce 9600M GT
VRAM 2GB
OS Windows Vista 64Bit
DxLibで作られたソフトをこいつで動かすと、始めは60fpsでなめらかにも関わらず、
しばらくすると30fpsになるのはなぜなんだ?
ガクガクするならまだしも、ぴったり30fpsなんだ。
またしばらくすると治ったりもするし、なにかひとつの関数が原因になってたりするのかな?
0659名前は開発中のものです。
2009/07/08(水) 22:17:02ID:i+ja7A8H0660名前は開発中のものです。
2009/07/08(水) 22:40:16ID:uhEtjIe1うちも24か30で安定、フルスクリーンだと60fpsありがとうございます状態。
0661名前は開発中のものです。
2009/07/08(水) 23:16:39ID:tUPC3dXe0662名前は開発中のものです。
2009/07/08(水) 23:26:07ID:Sk8AIN2R60、30、24ってよく見る数字だし
0663名前は開発中のものです。
2009/07/09(木) 01:06:35ID:h1wYunUV(1) 1フレームの処理が1/60秒未満なら1秒間に60回描画できる
(2) 1/60秒以上2/60秒未満なら30回描画できる
つまり瞬間的には30か60のどちらかになる
1のケースと2のケースが混ざったとすると長期的には平均することで30と60の間の値になりうる
しかし大抵の場合は1フレームの処理が1/60秒で収まるか、あるいは超えるかで30と60に分かれる
と予想
0664名前は開発中のものです。
2009/07/09(木) 02:46:07ID:IPUdantx0665名前は開発中のものです。
2009/07/09(木) 22:24:55ID:9TUAw73Mというか、GPUの設定をどう変えてもまったく同じ・・・
0666名前は開発中のものです。
2009/07/09(木) 23:12:54ID:PnCCkvgD0667名前は開発中のものです。
2009/07/10(金) 06:17:28ID:On7fn4n80668名前は開発中のものです。
2009/07/10(金) 06:55:03ID:aqVpLVfM0669名前は開発中のものです。
2009/07/10(金) 09:02:40ID:G7FiBYYu全部読んでそれでもわからなかったらまたおいで。
0670名前は開発中のものです。
2009/07/10(金) 12:51:04ID:xhZ5jDJO0671名前は開発中のものです。
2009/07/10(金) 13:23:29ID:Pbfo1cNYbullet[i].locate.x = 320; とか多重に扱うと見た目が重く感じるぐらい。
0672名前は開発中のものです。
2009/07/10(金) 13:23:43ID:GMEf2Yqs0673名前は開発中のものです。
2009/07/10(金) 15:09:18ID:xhZ5jDJOthx
多重に気をつけて、メンバ変数は極力そのクラス内で処理するようにしますわ
0674名前は開発中のものです。
2009/07/10(金) 23:17:50ID:kvfVpi7wとかなら、ちょっとは考えろよwwとか思うけど。
普通に組んでる限りじゃ、そんな気にする必要はないかと。
どうしても気になるなら、POINTなりをpublicで継承すりゃ、
bullet[i].x=320にできるし、どうせゲームだからこれで問題無いでしょ。
0675名前は開発中のものです。
2009/07/11(土) 01:55:20ID:UeAE0WWVbullet[i].x()=320;
これくらいなら見た目もタイプ量も許容範囲だろ
0676名前は開発中のものです。
2009/07/11(土) 01:56:20ID:UeAE0WWV0677名前は開発中のものです。
2009/07/11(土) 07:49:08ID:wBBMdddU0678名前は開発中のものです。
2009/07/11(土) 18:21:58ID:SvZlB+M+0679名前は開発中のものです。
2009/07/14(火) 04:20:59ID:wRlAP6qv再起動してみると普通に実行されるのは何だろう
0680名前は開発中のものです。
2009/07/14(火) 04:40:19ID:mFQZCpWd何を言いたいのか分らんが・・・
(エスパー希望の相談なのか、只の雑談なのか、愚痴なのか?)
とりあえず、タスク がタスクマネージャーとかのタスク(application)の事なら、
単純にどっかが無限ループに嵌ったか、画面書き換えの部分を通らなくなったか(orキー入力の部分を・・・)
だろう。
とりあえず、printfを色んな所に仕込んでおいて、デバックを掛けるとかするのが基本。
怪しい所がどうみてもライブラリ側だったら、公式に書き込めばいいし、
そうでないなら、再現性を高めて、その変な挙動をここででも、公式ででも聞いてみればいい。
大概は、配列でindexが超えて・・・・とか、switchでbreak;が抜けてて・・・とか
if文の後に変なモノがあって、ifでの抜けだしが効かなくなってたりとか、
{}の対応が微妙にずれてて・・・とか、初期化してないのを使っていて、タイミング次第で・・・とか
(後は、WindowsUpdateしてなさ過ぎて、リターンが遅れてるのを応答なしに解釈されてるとかもあるか、)
0681名前は開発中のものです。
2009/07/14(火) 04:49:20ID:wRlAP6qvその通り
>単純にどっかが無限ループに嵌ったか、画面書き換えの部分を通らなくなったか(orキー入力の部分を・・・)
>だろう。
そういった部分は見当たらなかった
何せOSを再起動させてそのプログラムを再び実行させたら何の問題もなく動いたのですからプログラムに原因があるとは思えないのですが
0682名前は開発中のものです。
2009/07/14(火) 05:07:49ID:pOq3rm7Pあるいは君だけが体験できるくらいレアな現象って事になるだろう?
調べる事ができるのは君だけなんだから
素直に>>680の忠告に従って、きちんと調べていけばいい。
「これで合ってるはず」なんて余計な「思い込み」はデバッグ作業の邪魔にしかならないぞ。
0683名前は開発中のものです。
2009/07/14(火) 05:36:27ID:mFQZCpWdそれだけの事で、プログラムに問題があるとは思えないって・・・・
とりあえず、
初期化なしでつかってる場合にはOS再起動とかで簡単に変わるし、
時間取得なんかをちゃんと処理してないと、
日にち跨ぎや時間跨ぎで、発生したりしなかったりする。
>>682も言うとおり、思い込みよりも手を動かしてデバックしなぁ。
プログラムは書いた通りに動いても、思った通りには動くとは限らないんだからさぁ。
0684名前は開発中のものです。
2009/07/14(火) 06:46:29ID:wRlAP6qvまあ動くようになった訳だからそのまま何事もなかったかのように過ぎていくのだろう
0685名前は開発中のものです。
2009/07/14(火) 07:14:55ID:MgrfsfEm0686名前は開発中のものです。
2009/07/14(火) 07:53:46ID:wRlAP6qvその可能性のあるコードって、(実行時に処理を通ってるコードの中で)
while( (!ProcessMessage()) && (!keybuf[KEY_INPUT_ESCAPE]) )
しかなかったんだが(変な書き方でスマソ)
確かに keybuf はグローバル変数にしてしまってるし
char keybuf[256] = {0};
で初期化したつもりになってるけどどうなんか分らん
まあ動くようになったし確認しようにももうできないからな、動くから
まあ良しとして続けるしかないな
0687名前は開発中のものです。
2009/07/14(火) 08:07:50ID:1FTDe9TM0688名前は開発中のものです。
2009/07/14(火) 09:43:25ID:MgrfsfEm0689名前は開発中のものです。
2009/07/14(火) 20:58:42ID:2Fk/wASWプログラムに思い込みは絶対あかん。
0690名前は開発中のものです。
2009/07/14(火) 23:37:46ID:wRlAP6qvこの先動かなくなる可能性ないわけではないが
そうなったところでこれ以上バグは見つからんだろうな、俺の力では
0691名前は開発中のものです。
2009/07/15(水) 00:00:28ID:MHxGaYOY外見上動いてても、バグがあれば意図してないデータが含まれてる。
0692名前は開発中のものです。
2009/07/15(水) 01:08:24ID:ouOmT7td多分printfとかで一つ一つ処理の中身を吐き出して見てもどの道今の俺の能力では
バグを発見できるとは思えないから忠告はありがたいがこのままいくことにするわ
以前も同じようなこと何回かあったしそんときもちゃんと完成まで漕ぎ付けているし
0693名前は開発中のものです。
2009/07/15(水) 01:17:22ID:Pli3pE87ID:ouOmT7td
お前さ、そんなスタンスなら、なんでわざわざここに書き込んだわけ?はじめから書き込むなよ。
なに、構って欲しかった?わざわざお前の書き込みに一生懸命考えてレスしてくれた
人達に失礼だと思わないの?
0694名前は開発中のものです。
2009/07/15(水) 01:49:11ID:9zT2ADv7プログラムを書いた本人に見当がつかないなら、他人の経験に頼るのも良いと思うよ。
自分がそんなバグにぶち当たったとしても根気だけで調べようとは思わないな。
時間が余ってるなら別だけど。
で、他人の立場から言うと、あれだけの情報で問題のありそうな点を指摘するのは無理だ。
アドバイスとしてはバグ発見を諦めるのではなく自分用バグリストを作ってそこに追加しろ。
0695名前は開発中のものです。
2009/07/15(水) 02:09:56ID:ouOmT7tdでアドバイス通りに考えてみたけど駄目だった
0696名前は開発中のものです。
2009/07/15(水) 02:15:50ID:oAaV9htYそうか、お疲れ。
コード晒す勇気があれば、案外デバックしてくれる人が居るとおもうけど…
(自分一人だと考えがなかなか間違いに気付きにくいからコードレビューは有効だと思う)
「アドバイス通りに考えてみた」ってのは、
もちろん、printfとかでデバック情報をポコポコ吐き出させたけど、バグらしき場所が見あたらなかった
って意味だよね。念のため。
0697名前は開発中のものです。
2009/07/15(水) 02:28:23ID:HAQqwNAf無理なら帰れ
0698名前は開発中のものです。
2009/07/15(水) 06:33:25ID:jzF+qqts俺だけ?
0699名前は開発中のものです。
2009/07/15(水) 07:55:06ID:OJRObvUW意外とバグって見当つけてたとこ以外にあったりするもんなんだよなぁ
0700名前は開発中のものです。
2009/07/15(水) 08:38:43ID:MHxGaYOY>>692でデバッグしてないと言ってるじゃん。
0701名前は開発中のものです。
2009/07/15(水) 10:08:04ID:kzUIqF8J0702名前は開発中のものです。
2009/07/15(水) 10:45:30ID:jzF+qqts分かる分かるw
そしてバグを再現させるのは非プログラマに丸投げする俺
0703名前は開発中のものです。
2009/07/15(水) 11:25:55ID:aCtz8rQi0704名前は開発中のものです。
2009/07/15(水) 20:48:39ID:vgHuQMIaテストも作れないし
そもそもバグなのか想定なのかも混乱するんだろ?
0705名前は開発中のものです。
2009/07/15(水) 21:06:50ID:SOTm+sdF0706名前は開発中のものです。
2009/07/15(水) 21:09:53ID:MHxGaYOY0707名前は開発中のものです。
2009/07/15(水) 23:03:43ID:MZkEPg1i最終的にうまく動作するものが仕様です。
どだい、仕様書でバグが防げると思ってる法が異常。
仕様書の想定だろうが、結果駄目ならバグだろ!
0708名前は開発中のものです。
2009/07/15(水) 23:17:51ID:OJRObvUW仕様の段階でバグ出すレベルの人はちょっとヤバイ。
0709名前は開発中のものです。
2009/07/16(木) 00:10:27ID:ZK0MxNzH紙に書いてみたらあっさり解決ってのはよくあることだけどな。
0710名前は開発中のものです。
2009/07/16(木) 03:15:22ID:1/ar+JW7のが重要なんです!」と力説する新人が入った時を思い出した
0711名前は開発中のものです。
2009/07/16(木) 10:03:06ID:qgWixxR7仕様書がなければダメになる人とそうでない人がいる。
始めた時は正しい方向に向かっていたが、
出来上がった時には違った方向を向いている、
世の中にはそんな人も多くいる。
チームで進めるとき、意思の統一が重要で
依頼しても、出来上がりが違うものになるのは困り者。
人それぞれなので、きちんとできるひともいるので、そのような人は不要と言われる
0712名前は開発中のものです。
2009/07/16(木) 10:53:13ID:glHWB671「言った、言わない」の問題になってしまうから
あらかじめ、ちゃんと紙にして保存しておくって事だろう。
できるできないの問題じゃないよ。
自分のため、相手のための保険みたいなもんだ。
0713名前は開発中のものです。
2009/07/16(木) 11:11:34ID:qgWixxR7チームで行う時の基盤になる、開発ドキュメントとして
取り扱い説明書として、保守業務の基準として必須のものである。
0714名前は開発中のものです。
2009/07/16(木) 11:30:46ID:Frg8+T60作り方が違うだろ
ttp://marupeke296.com/DXCLS_BottumUpStructingOfClass.html
0715名前は開発中のものです。
2009/07/16(木) 13:48:32ID:JxCE3uCoいつかは。
0716名前は開発中のものです。
2009/07/16(木) 16:20:01ID:MA5d2Bm10717名前は開発中のものです。
2009/07/16(木) 16:29:44ID:K0RdyJ0x0718名前は開発中のものです。
2009/07/16(木) 17:36:09ID:sfuED1R60719名前は開発中のものです。
2009/07/16(木) 21:20:58ID:0qzmxnbaダウト
仕様はソースと答え合わせする為のもの
ソースみて内容がわかるのと、本来どうあるべきなのかは別問題
0720名前は開発中のものです。
2009/07/16(木) 22:04:34ID:sfuED1R6はっきり切り分けないで話してるからこんなにカオスなのか
0721名前は開発中のものです。
2009/07/17(金) 09:45:51ID:iPNwCeP80722名前は開発中のものです。
2009/07/17(金) 09:47:37ID:ZC/cxW1dそれにコメントは確かに大事だが
関数名をgetScreenFrameParSecondみたいにきちんと書けば、仕様が明らかにわかる
クラス・変数名も同じ
例えばiteratorをitとか省略して書くのはダメ
タイプ速度は速くなるが、後のコーディングで詰まるから、作業は全く速くなってない。むしろ遅くなる
省略しなければiteratorという言葉を知らない他人が見ても、ググれば意味がわかる
あとは、日本語で名前つける人がいるけど
ネットに和英辞書あるんだから使ってほしい
英語の勉強になるし国際化にも対応できる
0723名前は開発中のものです。
2009/07/17(金) 10:08:40ID:fic4arti国外にソース晒すほど立派なもん作れるなんてうぬぼれてない。
0724名前は開発中のものです。
2009/07/17(金) 10:48:52ID:XzHK2st60725名前は開発中のものです。
2009/07/17(金) 11:36:53ID:71PbqEZA0726名前は開発中のものです。
2009/07/17(金) 14:37:53ID:AtGtaSaV0727名前は開発中のものです。
2009/07/17(金) 14:42:09ID:vX9OmGXPとかは問題ないと思うけどな。宣言のクラス名で大体分かるし。
宣言が遠すぎて分からんような関数ならその時点で問題だし。
0728名前は開発中のものです。
2009/07/17(金) 15:20:17ID:vX9OmGXP定番の良書とかでも普通みんなそうだし、Linuxカーネルみたいな大物ソースでも
そうだし。
結局、識別名だけで理解できる情報は限られるのも現実。そうでなければ、それこそ
アプリケーションハンガリアンなんかを全識別名に徹底すれば最高なのかもしれない
けど、実際は関数エントリにはしっかりした出入り仕様のコメントが欲しい訳で。
まぁ、スレ違いなんだけどね。
正直、D3DXのせいで、「扱いやすくする」という使命のラッパーライブラリの系統
は居場所を失ってるから、このスレの居場所も同様によく分からないんだよなぁ。
0729名前は開発中のものです。
2009/07/17(金) 15:37:38ID:/TZL4Vnl| ノ ヽ
/ ● ● | クマ知ってるか。
| ( _●_) ミ 出雲地方では、木と岩と水の在る場所を「熊々しい谷」と呼ぶ。
彡、 |∪| 、`\ 「熊々しい」とは、神々しいの意味だ。
/ __ ヽノ /´> )
(___) / (_/
| /
| /\ \
| / ) )
∪ ( \
\_)
0730名前は開発中のものです。
2009/07/17(金) 22:02:14ID:Z3s3jxcY引数がある場合とかに
複数行にわたってしまって
なんだか見づらくならない?
今まで見たソースだとgetScrFPS程度には略してるけど
おまえらどうなの?
0731名前は開発中のものです。
2009/07/17(金) 22:12:33ID:3aIuRMAB0732名前は開発中のものです。
2009/07/17(金) 22:12:54ID:a1yK0hIN0733名前は開発中のものです。
2009/07/17(金) 22:29:41ID:PpX+kDe1ひとつのGetPos()って関数で渡すにはどうしたらいいかな?
考えてみたんだけど、どうしても一つでいろいろなところで使える方法がみつからないんだよ。
まだプログラム経験が短いもんで。
0734名前は開発中のものです。
2009/07/17(金) 22:47:07ID:a1yK0hIN0735名前は開発中のものです。
2009/07/17(金) 23:03:35ID:TRJ/ynqn基本Getは単一変数を返す方がいい。
内部の構造体のデータを返すのは間違っている。
その場合はとるのではなく、チェックしてもらう。
bool chk_XXXX (pos *dat); が正しい。
で、この関数はインラインであれば、スピード的には何の問題も無い。
考え方が逆。
0736名前は開発中のものです。
2009/07/17(金) 23:06:22ID:TRJ/ynqnこれ基本中の基本
0737名前は開発中のものです。
2009/07/17(金) 23:31:36ID:cB4HhxMPでもゲームは作れてるぜ!
0738名前は開発中のものです。
2009/07/17(金) 23:36:29ID:iPNwCeP80739名前は開発中のものです。
2009/07/18(土) 00:03:32ID:pCmtYAM2private の場合 getx(){return x;} でアクセスするのと速度変わらんのか
0740名前は開発中のものです。
2009/07/18(土) 08:04:35ID:QevxnE5g詳しい事はしらんが、常識的な範囲でコンパイルを考えれば、
最適化が普通だったら遅くなる理由は無いと思う。
最適化をしないなら、クラスから関数のアドレスに飛んで、
そこで値:xを取得して、それをどっかに格納な分
遅くなるんだろうけど・・・。
0741名前は開発中のものです。
2009/07/18(土) 08:54:43ID:UXbVEGUEちょっと違う
getx(){return x;} がクラスの中に書かれ、そのクラスがヘッダーファイルなら。
インライン展開されるので
aa = getx(){return x;}
||
aa = A.x と同じ
最適化は関係ない
0742名前は開発中のものです。
2009/07/18(土) 08:56:36ID:UXbVEGUE0743名前は開発中のものです。
2009/07/18(土) 10:41:55ID:PwgwIsF1ソース側で定義でもinlineつけて展開できるなら同じじゃないっけか
後、クラス内での処理はインラインしてくれるのが普通だったきがする
メンバ関数内で別のメンバ関数呼び出して処理とか
まー、>>736か
0744名前は開発中のものです。
2009/07/18(土) 14:09:33ID:xlxZEQtnclass Foo {
Pos pos_;
public:
Pos& GetPos() { return pos_; }
const Pos& GetPos() const { return pos_; }
};
スコープの外側にインスタンスを返すなら、参照渡しじゃ無理なので、コンパイラの
NRVOに期待して、例えば以下のように書くことになる。
inline Pos GetPos() {
Pos result;
/* code */
return result;
}
NRVO非対応でRVOだけ対応のコンパイラだと、
inline Pos GetPos() {
/* code */
return Pos( /* code */ );
}
こういうコードじゃないと>>741の言うような最適化は掛からない。
コンパイラーメーカーもC++標準化委員会もNRVOが掛かるように頑張ってるはずだが、
実装状況はコンパイラによってまちまちなんで調べてくれ。多分検索すればすぐ分かる。
VC++なら2005からNRVO行けるっぽい。/O1くらいでもNRVOは掛かる模様。
プロファイラで後から最適化ってのも常道だけど、I/F設計段階の話はそうもいかないし
なぁ。
まぁ、俺なら基本的には参照渡し、リターンで解体される自動変数なら値渡しで返して、
後者がボトルネックになるならインライン化でたぶんNRVO発動でおk、って書く。で、
「この設計だと遅そうだしポインタ渡そう」って言われたら、実際どうなるか興味ある
んでベンチでも書いたり、ついでに↓みたいなのも一緒に見たりしながら相談する。
http://msdn.microsoft.com/en-us/library/ms364057(VS.80).aspx
0745名前は開発中のものです。
2009/07/18(土) 14:20:17ID:xlxZEQtnスコープの外に「自動」インスタンスを返すなら、だな。
つーか、二つめと三つめは最初の質問のシチュエーションから逸脱してるな。すまん。
まぁでも、メンバ関数でもNRVOは重要なんで、仕組みは知っておいた方が。
0746名前は開発中のものです。
2009/07/19(日) 05:29:35ID:TXlg+NUwif(key & PAD_INPUT_B){
for(double t=0; t<10; t=t+0.1){
int vo = -60;
int ay=10;
jikidata.y = vo * t + 1/2 * ay * t*t + jikidata.y;
WaitTimer( 1000 );
jikidata.ghandle = LoadGraph("media\\imgbb4792ea7ec6f3d_frame_0009.bmp");
}
}
DXライブラリを使ってアクションゲームのジャンプをプログラムしたいんですが
これで実行すると、キャラが止まったり、動かなくなってしまうんですが、どこを改変すればいいんでしょうか?
■ このスレッドは過去ログ倉庫に格納されています