08/12/09 20:29:41 zdIJJ+hv
>>XQDNdxlU
毎度毎度乙です。
イベントの発生条件を弄れないか探しているがさっぱりわからん。
任意のイベントを無理やり起こすなら、「会う」の汎用会話と置き換えるしかないのかな?
あと同じ行数、同じ文字数での会話の書換えツールみたいなのならできますかね?
ファイル見てるとイベントは次々追加できそうな作られ方してるなぁ
フラグ関係のmain.swだけ領域が足りないようだが、メーカーはイベント追加も視野に入れてるかな?
それとも手抜きか・・・
141:名無しさん@お腹いっぱい。
08/12/09 21:48:08 zdIJJ+hv
選択分岐以外でもイベント最後の文末にある0010から+0x1Dの場所にあるのがイベント終了後の処理のようだ。
例えば会話イベントなんかはBFになっていることが多く、このBFもmain.lbに繋がってる。
すなわちBF×4=[0x02FC]=main.lb内のアドレス
0x02FCはmain.sdの0x2AA0B0を呼び出してる。
ためしにこのBFをBBにしてみると、
BB×4=0x02ECで、main.sdの0x0CD3F1が呼び出され、
会話終了後に信長のイベント「いてぇな・・・・・・。」が始まる。
BFはなんだろうな、会話の回数フラグを1回増やすやつかな?
142:名無しさん@お腹いっぱい。
08/12/09 21:57:28 zdIJJ+hv
会話イベントのみのキャラを見てみると、
BF以外ではキャラ別の最後のイベントの終了時の処理は00になっていて、
00だとキャラ名の一覧の少し前を参照していることになる。
これはもう何も処理しませんよ。ということかな?
しかしこれ、うまくイベント連鎖させたら全イベント一気に起こせるかもな。
143:名無しさん@お腹いっぱい。
08/12/10 00:10:35 xq3+Her5
>>140
とりあえずイベントが見たいだけならmain.lb書き換え?
>>138の方法で良ければ見たいイベント言ってくれれば書き換え方書くケド、
書き込み内容から察するにID:zdIJJ+hvならmain.lbの書き換えぐらい
鼻毛を抜くぐらいの気軽さでやれちゃいそうな印象g
とりあえず文字数の変更が無いのであれば、↑のどっかにある拙作のクソツールでも
rawモードとかそんなんで出来そうな気が。でも構造解析とか全く出来てなかった頃の
シロモノなのでイロイロとアレです(; ・`д・´)
(バイナリエディタでいじった方が早そう…w)
タグ解析が進んで、文章だけじゃなくて立ち絵とか背景とか音とかいじれるようになって、
イベントの追加とか削除まで出来るトコまで来たらエディタ的な何かを作ってみよう
かなぁ…と思わないコトも無いけど、ちょっとモチベがなくなってきたのと、
ウチOCN丸の内なんでそろそろ年末恒例大規制祭りがやってきそうな予感ggg(;・∀・)
144:名無しさん@お腹いっぱい。
08/12/10 00:11:15 xq3+Her5
で、ひょっとしたら>>141は大発見をしているかも知れないのでもっと詳しく(゚∀゚)!
正直意味がワカランかった…w
文章終端の[10]から29byte先に次イベントのmain.lb内のアドレスが書かれているってコト?
主人公の一人語りみたいなのが続いてるトコだと[0F]の後に[10]が来て、
そのすぐ後にまた[0F]がはじまるので、29byte先はもうすでに[0F]内だったりするんだけど、
オレが根本的に読み取れてないのかな…?(;・∀・)
145:名無しさん@お腹いっぱい。
08/12/10 05:54:15 xq3+Her5
・信玄&道雪のイベント見たいケド、辿り着く頃には死んでんだよなぁ(;´Д`)
・ランダムイベントってランダムにも程があるだろうッ何この宝クジッヽ(`Д´)ノ
みたいな人は
■菊五郎さんに聞いてみよう(゚∀゚)!ver0.01 DLkey:sghmod
URLリンク(apple.mokuren.ne.jp)
↓こんなの
URLリンク(apple.mokuren.ne.jp)
URLリンク(apple.mokuren.ne.jp)
イベントを強制的に発生させるモノです。
いつもどーりほとんど未テスト(゚∀゚)
146:名無しさん@お腹いっぱい。
08/12/10 06:36:45 uy0wzIgT
>>145
神棚
何という忙しい人の為の戦極姫
147:名無しさん@お腹いっぱい。
08/12/10 07:14:24 /DyhBmaZ
out/main.sd に書き出したよってでるけどファイルが生成されてない/(^o^)\
どうしてだ
148:名無しさん@お腹いっぱい。
08/12/10 08:56:18 xTdbYJ5H
>>144
1つのイベント途中の会話の後ではなく、そのイベントの最後の文章の後ね
例えばmain.sdの0x2721E0あたり常信エリの1回目の会話イベント「オッス! 颯馬元気?」だと
0x002721E0 : 00 01 81 75 83 49 83 62 83 58 81 49 81 40 E9 44
0x002721F0 : 94 6E 8C B3 8B 43 81 48 81 76 00 10 0E 0E 00 01
0x00272200 : 0E 11 00 D6 F9 03 00 08 0E 14 00 21 01 00 00 00
0x00272210 : 01 00 00 00 02 0E 17 00 BF 00 00 00 01 0E 1F 00
2行目「0x002721FB」の [10] がこのイベントの文末となるわけだが、
ここから+1Dの「0x00272218」の [BF] がmain.lbの「0x02FC」に繋がっている。(BF×4=2FC)
で、main.lbの「0x000002FC」を見ると[B0 A0 2A]となっておりmain.sdの0x2AA0B0を呼び出す。
よってこの[BF](おそらく2バイト単位)を書き換えるだけでイベントが連鎖されていく感じになる。
イベントを作為的に発生させる場合はmain.lbのアドレスデータを直接目的のイベントのアドレスに書き換えるか、
会話後の[BF]の部分を書き換えるかどちらかでいけそう
ちなみに、このBFの4バイト後が次のイベント
つまり常信エリの2回目の会話イベントの頭になっているようだ。
149:名無しさん@お腹いっぱい。
08/12/10 09:14:44 xTdbYJ5H
今調べたんだが、ゲームのVerによって少しアドレスに差があるな、
Ver1.01だと例の部分は[BF]だがVer1.00だと[BE]、1.02はしらん。
全部Ver1.01で調べてます。
150:名無しさん@お腹いっぱい。
08/12/10 10:35:38 xTdbYJ5H
ID:xq3+Her5のモチベUPの為に・・・
イベント中のキャラの立絵は変更できそう。
main.sd内の会話等の開始アドレス(main.lb内参照)から+0xC(3バイト)がそうみたい。
この3バイトは同じmain.sdのアドレスを指していて、
調べると["キャラ名"_A 基本]とかの文字列の少し前にある[ 03 08 ]ってところを呼んでいる。
この3バイトを別のキャラのに置き換えてみると立絵も変わった。
背景は今のところ不明。
エディタ期待してますぜ!
151:名無しさん@お腹いっぱい。
08/12/10 13:14:10 xTdbYJ5H
昼休みに速攻で調べてみた。
上のは一旦忘れてくれ。
★★★背景CG★★★
main.sd内において、main.lbで指示されたアドレスに飛び、そこが[2D]からはじまる場合
その2Dの何バイト後ろになるかはわからないが[ 01 ?? ?? ]があるはず。
その01の4バイト後ろにあるのが背景CGを呼び出すアドレスのようだ。
main.sd内のそのアドレスに移動すると背景CGリストがあり、
呼び出されるファイル名の手前の[ 56 04 ]のところに飛ぶ。
また、main.lbで指定されたアドレスが[01]からはじまる場合は、その+4バイトの位置が背景の指定みたい。
このケースは、ほぼ会話イベントでいきなり室内の場合だと思うが、背景指定アドレスは[ 84 38 01 ]になっている。
この[ 84 38 01 ]はちょっと特殊で、多分だけど、背景を変更しないってことだと思う。
つまり「会う」での会話イベントは、デフォルトで室内の背景CGが呼び出されるようだ。
また、エロイベントとかでイベント途中のCGの変更は、CGが変更される直前の文末の終端タグ[10]から
少し後にある[ 01 ?? ?? ]の[01]の4バイト後ろがCG指定のアドレス。
イベントCGは背景扱い。イベントCGの上に立絵も乗せられた。
★★★立絵CG★★★
背景CGを指定するアドレスの後ろに[ 01 ?? ?? ]がある場合、その4バイト後ろが立絵の呼び出しアドレスみたい。
main.sd内のそのアドレスに飛ぶと「"キャラ名"_A ~~~ 基本」とかの文字列の少し前にある[ 03 08 ]に飛ぶ。
★★★まとめ★★★
見たサンプルが少ないから合ってるかどうか不明だが
頭が2Dから始まるイベントの場合は、
「背景の指定」→「BGMの指定」→もう一度「背景の指定」→「立絵の指定」→「声の指定」→「文章」
頭が01から始まるイベントの場合は、
「背景の指定」→「立絵の指定」→「声の指定」→「文章」
となっている感じ
01などのタグの後ろの????はよくわからんが勝手に増えていくやつなので無視して解析してみた。
CGは[01]のタグとセットになっていて一旦main.sd内にあるCGのファイルリストに飛んでから個別のCGファイルにアクセスしてるみたいだね。
BGMや声は文字列で指定されてるんでいじるのは厳しいかな?
152:147
08/12/10 13:52:11 /DyhBmaZ
自己解決
「kikugorou.exe」があるフォルダに「out」という名前のフォルダ作ったらその中にmain.sdが生成されますた
153:名無しさん@お腹いっぱい。
08/12/10 15:28:15 xq3+Her5
読みづらいだろうけど>>129-136の内容を読んでくれると以下がよくワカルと思うのだが、
何か説明中イロイロと混乱するので、まずは共通言語を決めちゃおう。
『シーン』:例えば光秀がメイド服着てうんちゃらかんちゃらみたいな
一連のお話の流れ1つ。エピソードと言い換えても○。
『イベント』:シーン内において、クリックとかEnterとかで進める一つの単位。
で>>148のバイト列を0x002721FBから意味的に区切ると↓こんな感じ。(ズレたらスマン
10 0E 0E 00
01 0E 11 00 D6 F9 03 00
08 0E 14 00 21 01 00 00 00 01 00 00 00
02 0E 17 00 BF 00 00 00
01 0E 1F 00 [ここに画像関連情報が4byte続くハズ]
↑ ↑ ↑ ↑ ↑
① ② ③ ③ ④こっから先全部④
①:コマンド的な意味を持つもの。[0F]なら文章[01]なら画像関係とか
②:同一シーン内で共通の数値が使われる。
③:この2byteは同一シーン内でインクリメントされていく。
④:①の種別によって固有データが入る。
154:名無しさん@お腹いっぱい。
08/12/10 15:29:31 xq3+Her5
で、>>141と>>148の内容が指し示すのは>>136でヨクワカランに分類されていた
[02]タグの謎を解き明かしたというコトなのだ(゚∀゚)!
[02]タグはシーン読み込みを示すタグで、④の固有データ域は4byte。
固有データ領域にはmain.lbのアドレス配列indexが入っている。
こういうコトだ!すごいぞ!謎がひとつ解けた(゚∀゚)!
155:名無しさん@お腹いっぱい。
08/12/10 15:37:56 xq3+Her5
>>147 >>152
ごめんw圧縮前のデータにはoutディレクトリもあったんだけど、
圧縮する段階で空のディレクトリは消されてしまうみたいだ…w
何かダミーファイルでも置いてから圧縮すればよかったスマン(;´∀`)
156:名無しさん@お腹いっぱい。
08/12/10 16:45:21 xTdbYJ5H
じゃあ次は>>148内にある[ 08 ]をば!
>>148では
08 0E 14 00 21 01 00 00 00 01 00 00
となっていますが、本来なら[ 21 01 ]ではなく[ 20 01 ]です。ごめんなさい、確認のため書き換えたままでした。
この[ 08 ]はフラグ管理ですね。
①[08] でフラグ立てますよ~(②③はとりあえず無視)
④[20 01] がフラグリストの呼び出し。
ここではmain.swn内のアドレス「0x4800」(0x0120×0x40)を指している。
このシーン名は「meet_eri_00_end」なんでOKだな。
⑤?[00 01] 最後のこの0001は入力する値でしょう・・・・・・多分。
main.swnの0x4800は、main.swの0x0480(0x4800÷0x10)に対応。で、ここに01を書き込む。
実際、メモリ内の対応する場所に01が入った。
このあたりがあまり意味ないのはフラグ管理なんて面倒な事やってられないから・・・
157:名無しさん@お腹いっぱい。
08/12/10 23:42:59 xq3+Her5
っていうかよく[08]とフラグ管理結びつけられたな…w
>>156を受けて、ちょっと[08]タグ調べてみた。まずデータ貼る。
参考アドレス0x00040559 (main.lbnによるとシーン名[start]らしい。)
[0x00040559 ベタ書き]
01 02 06 00 F4 3B 01 00 1E 02 09 00 00 00 00 00
03 02 0C 00 01 32 00 00 00 03 12 00 00 00 00 00
00 00 00 02 02 00 00 00 12 02 0C 00 AA 05 04 00
08 02 0D 00 37 00 00 00 04 15 08 93 56 8F E9 E9
44 94 6E 00 08 02 0E 00 32 00 00 00 00 01 00 00
00 0B 02 12 00 00 00 00 00 09 00 00 00 1E 00 00
00 1F 00 00 00 20 00 00 00 21 00 00 00 22 00 00
00 23 00 00 00 24 00 00 00 25 00 00 00 26 00 00
00 08 15 07 00 37 00 00 00 04 06 08 8F E3 90 99
8C AA 90 4D 00 08 15 08 00 37 00 00 00 04 17 08
[0x00040559 タグ解析]
01 02 06 00 F4 3B 01 00
1E 02 09 00 00 00 00 00
03 02 0C 00 01 32 00 00 00 03 12 00 00 00 00 00 00 00 00 02 02 00 00 00
12 02 0C 00 AA 05 04 00
08 02 0D 00 37 00 00 00 04 15 08 93 56 8F E9 E9 44 94 6E 00
08 02 0E 00 32 00 00 00 00 01 00 00 00
0B 02 12 00 (ちょっと長すぎるんで複数行に分解)
---00 00 00 00 09 00 00 00 1E 00 00 00 1F 00 00 00
---20 00 00 00 21 00 00 00 22 00 00 00 23 00 00 00
---24 00 00 00 25 00 00 00 26 00 00 00
[↓こっから別シーン]
08 15 07 00 37 00 00 00 04 06 08 8F E3 90 99 8C AA 90 4D 00
08 15 08 00 37 00 00 00 04 17 08 ...データがつづく
158:名無しさん@お腹いっぱい。
08/12/10 23:44:20 xq3+Her5
で、シーン02内の[08]タグを抜き出すと、順に。
08 02 0D 00 37 00 00 00 04 15 08 93 56 8F E9 E9 44 94 6E 00
08 02 0E 00 32 00 00 00 00 01 00 00 00
下の方は分かりやすくて>>156の解析と同じタイプ
0x32 * 0x40 = 0xC80 -[main.sfw]-> amagi_add のフラグ操作
上の方はちょっと構造が違う感じで
0x37 * 0x40 = 0xDC0 -[main.sfw]-> temp01
で、続くデータで文字として読めるのを解析すると
93 56 8F E9 E9 44 94 6E = 天城颯馬
なんでtemp01に『天城颯馬』を書き込むのだろう。
(ちなみに別シーンの方の文字列は『上杉謙信』
多分[08]から数えて9byteめ(04と00になってるトコ)がデータタイプを決定していて、
00ならboolとかintとかで、続く4byteに値が格納されている。
04ならstringとかそんな感じかな~?
ending_checkとかdead_check系列のイベントを解析したら、
フラグを読み出すタグも分かるかのぅ…?(存在するかは知らないが(; ・`д・´)
とりあえずイイ仕事したwお疲れ(゚∀゚)>>156
159:名無しさん@お腹いっぱい。
08/12/11 01:51:16 /Ge9NhuP
すげーよ、おまえら。
この調子ならマジでイベントエディタが完成しそうだ。
ただレベルが上がりすぎていて、俺も含めて協力できる人が少なそうだ。
160:名無しさん@お腹いっぱい。
08/12/11 03:51:40 byL96ENs
>>159
何故>>129あたりからオレが暗号文じみたものを書き込み出して、
今スレの流れがこんな状態になっているのかをキチンと説明しておこぅ(; ・`д・´)
まず一般的なデータフォーマットの話をしよう。
世間で良く使われているデータフォーマットって、すっげー投げやりに言うと、
[データサイズ][データの中身]
みたいな構造をしているのだ。PNGとかはこんな塊が複数集まって出来ている。
で、こんな構造になっていると、データの中身とかデータの意味とかは知らなくても
サイズだけを元にデータをキレイに切り出せるワケだ。
ところがだ(; ・`д・´)
main.sdの中身を解析してみると、全然こんな構造になっていないのだ。
(別にこの事自体は悪いコトだとは思わない。)
だから『このアドレスからはじまるイベントの文章を書き換えたい』とか言われても
データの構造(せめてタグごとのデータ長)を全て把握していないと、文章データまで
正しく辿り着けないのだ(; ・`д・´)
(※現状ある程度は出来るが、未解析のタグが出て来るともうダメ。)
161:名無しさん@お腹いっぱい。
08/12/11 03:52:36 byL96ENs
なので、最低限、全タグのデータ長の算出方法が知りたいワケさ。
それには多分2つのアプローチがあって、
[1] 論理的にタグの構造を解析して、データ長の算出方法を類推する。
[2] main.sd内に含まれるある種のタグのデータ長が全て同じである事を確かめる。
※データ長が同一で無い場合、内部構造を解析する必要アリ。
オレが主にやってるのは[1]なんだけど、中にはタグ3つぐらい見て
『もうコレ8byte固定で決まりっしょ(゚∀゚)』とかやってるのも多々ある…w
で[2]の手法に関しては、main.sdからある種のタグを全て抜き出すというのが
ものッ凄い大変だし、そもそもある種のタグを抜き出すのに他のタグ構造を知らない
と抜き出しが出来ないというニワトリ卵。
実際にやるかやらないかは別として、イベントエディタを作るという観点で言うと、
我々はまだスタートラインにも立てていない…w
正直心が折れそうデス(; ・`д・´)全鯖規制きたらもう二度とやらない…w
162:名無しさん@お腹いっぱい。
08/12/11 05:10:25 2W6N751a
>>161
そしたらしたらばに板借りてきてやんよ
163:名無しさん@お腹いっぱい。
08/12/11 10:07:13 o+deS0te
早速eonet全鯖規制\(^O^)/
でも、めげずに書き込むよ!
>>157
むっちゃ乙。貴方だけが頼りです!
当方バイナリエディタ1本でちまちまやってるので憶測が多くてスマン
タグの解析ツールはかなり参考になります。
いくつか見てみたが[2D]ではじまるシーンは「シーン鑑賞」に出てくるやつばかりだった。
そのシーンの頭にある[2D]は、4バイト後ろの[1E]とセットで存在してる。
また、そのシーンの終了部分には[1E][2F][2E]がセットで並んでる。
その後[08]が入り最後が[02]の流れ。([1E]はシーン途中にも存在する。)
・[2D][2E](謎のカウンター部分含めて4バイト)
シーン頭の[2D]と終了部分の[2E]は、文章での[0F]と[10]の関係に近いのかも。(憶測)
・[1E](00郡が後ろにあるので全8バイトかな)
その存在している位置から「BGMのストップ命令」かと思い。
シーン途中でBGMが止まる場所の[1E]を[00]にしてみたらBGMが止まらなくなったので多分合ってる。
BGMだけのストップ命令かどうかはわからないけど。
・[2F](4バイト後ろにデータあるので全8バイトかな)
4バイト後が、シーン毎に別の数値が入ってるので何らかの働きはあるんだろうな。
「シーン鑑賞に追加」するフラグかな?
と思って再インストール後この数値を入れ替えてみたらやっぱり別のシーンがONになった。
まあ内容さえわかったらどうでも良い項目だね。
上記以外で現在わかっているのは
[01]:画像
[02]:シーン終了後の処理
[08]:フラグ(アドレス、数値などで、半端な全13バイト?)
[0F]:文頭
[10]:文末
[13]:選択肢
[1F]:Voice(後ろの34がよくわからん)
[22]:SE(後ろに00郡あり)
[49]:BGM
かな?
164:名無しさん@お腹いっぱい。
08/12/11 16:58:46 byL96ENs
>>163
全鯖規制来てるのに何と言う勇者…w毎度毎度オツカレ~(゚∀゚)
[2D]~[2F]とか良く見つけたな…w
言われてみれば『ああ~ホントだぁ~』って感じだわw
[1E]はオレもちょっと[1F]とかの絡みで音停止系統のタグかなーと思ってはいた。
やっぱそんな感じよね~。
何か使ってくれているみたいなので
■main.sd 簡易解析ツール ver0.03 DLKey:sghmod
URLリンク(apple.mokuren.ne.jp)
多少進化したので、とりあえずreadme読んでみてオクレ(゚∀゚)!
165:名無しさん@お腹いっぱい。
08/12/11 17:54:46 jVWt4NGd
ツールさんきゅです!
バイナリエディタで全体を眺めてる分、気がつきやすいのかもしれないね。
というわけで追加で~す。
[2D]と[2E]だけど改めて調べてみたらmain.ev内にあったよ[2D]のアドレスが。
でmain.evはおそらくシーン鑑賞で使うデータの切り出しをしてるみたい。
一つのシーンの途中に[2E]があったので何ぞ!
と思いシーン鑑賞を見てみるとやはりそこで切れた。
[2D]:回想で切り出すシーンの始点
[2E]:終点
CGについてはそれぞれのCGファイル名の前後の始点終点を探してみた。
[56]:始点で(4バイト後ろの[53]にももカウンターがあるのでこれもタグ?)
[0E]:終点のような気がするぞ。(4バイト長)
[30]:ついでに「CG鑑賞」への追加指示はおそらくこれ(8バイト長)
[3C]:後ろの[64]とセットだと思うが不明
こういう書き方のほうが解るかな?
166:名無しさん@お腹いっぱい。
08/12/11 18:26:51 51f2S2KK
おまえらすげぇ・・・すごすぎるよ
167:名無しさん@お腹いっぱい。
08/12/11 20:52:48 jVWt4NGd
重要キャラの死亡チェックのとこ見てたんだけど、
[66]:そのキャラあるいは勢力の状態チェック開始?
[0312]:状態チェック終了?
[040608]:大名名?
[040108]:武将名?
[04010A]:サルだけ名前の前がこれだね。
[0202]:その直前に条件式がありそれが真ならば[0202]の後ろにある処理をする?
[12]:条件分岐「if」みたいな感じかな?
[12]の4バイト後に飛ぶアドレスがありその後ろに条件式。真ならば指定したアドレスに飛べ?
[03]:不明
[FFFFFFFF]:死亡?
こんな感じかな?こればっかりは全く自信がないが
チェックの命令をもし俺がかけるならこんな感じかな?と思って。
0x13ff0あたりの
大名関係のチェック見てみると(多分現在プレイしてる勢力の調査)
[66]-存在チェックみたいなの-[0312]-[040608]-大名の武将名-[0202](真なら?)-[02](飛べ)
で、とんだ先は重要武将の存在チェックのとこ。
になってる気がするんだわ。
キャラチェックに来ても
[66]-存在チェックみたいなの-[040108]-武将名-[0312]-[FFFFFFFF]-[0202](真なら?)-[02](飛べ)
な感じだ。
長尾影虎の場合だけ[12]命令が入ってて上杉謙信に飛ばしてる。
ちなみにこの辺りのチェックやらCGやらの項目の最後は[0E]になってるんで
[0E]は現在のジョブの終了かな?
168:名無しさん@お腹いっぱい。
08/12/11 20:58:18 jVWt4NGd
[04010A]:毛利ガーナと宇佐美もだ
[04010C]:毛利ナッシュとオルテナはこれだった
169:名無しさん@お腹いっぱい。
08/12/11 21:58:33 jVWt4NGd
上あ~ごめん
[040608][04010A]とかだけど
[0406]:大名名の指定
[0401]:武将名の指定
で、次の
[08]やら[0A]は普通に後ろに続く名前のバイト数だったのね。
飯食ってると気がついた。
170:名無しさん@お腹いっぱい。
08/12/11 22:06:52 byL96ENs
ちょwwwメシくって酒飲んでる間に凄いコトになってるwww
ダメだwもうオレの方が追いつけない…w[66]タグとか永久欠番だと思ってたよ…w
まだ>>165の前半の内容を消化して、後半ちみっと見始めたばっかなんだけど(;・∀・)
アレだね。普通にゲーム内でシーンが発生する場合はmain.lbからたどって行って、
回想メニューからシーンを選択した場合はmain.evからアドレスをたどる感じなんだね(゚∀゚)
例えばmain.lbにもmain.evにも[mouri06]ってイベントがあるんだけど、
[49] 1C 05 00... <= main.lbから来るとココ
[2D] 1C 08 00 <= main.evから来るとココ
[1E] 1C 09 00 00 00 00 00
こんな感じだねぇ。まぁBGM再生はじめてすぐストップ処理が走るので、
スクリプトのミスかチェック漏れな気がしなくも無いけど…w
CGに関しては[01]タグとの絡みもあるので是非とも中身を解析したいのだけど
例えば↓みたいに…
171:名無しさん@お腹いっぱい。
08/12/11 22:07:30 byL96ENs
[Address]: 0x00072548 島津シナリオ朝風呂シーン
[01] 2C CC 00 B7 44 00 00
==>data block [B7 44 00 00]
==>0x000044B7 (main.sd)↓
56 05 85 06 53 05 86 06 65 76 65 6E 74 5C 63 67 2D 30 35 36 2E 74 69 67
==>タグ解析
56 05 85 06
53 05 86 06
65 76 65 6E 74 5C 63 67 2D 30 35 36 2E 74 69 67 event/cg-56.tig (次女入浴)
********************************************************************************
[Address]: 0x00077B16 上杉シナリオ冒頭シーン
[01] 2E 04 00 D4 04 00 00
==>data block [D4 04 00 00]
==>0x000004D4 (main.sd)↓
56 04 84 00 53 04 85 00 62 67 5C 62 67 30 36 2E 74 69 67
==>タグ解析
56 04 84 00
53 04 85 00
62 67 5C 62 67 30 36 2E 74 69 67 bg/bg06.tig (上杉領の街並みの絵)
172:名無しさん@お腹いっぱい。
08/12/11 22:08:06 byL96ENs
こんな感じでイベント絵とか背景とかは割と素直に辿れるんだけど、
立ち絵は謎アドレスに飛んだりして、辿り方が全然ワカンネ(;・∀・)
でもたぶん、[56]はCGはじまるよ~。[53]はCGの中身だよ~。とかそんな感じかなぁ。
そうそう。書き方は>>165とか>>167とかの感じで全然わかる。
でも強いて言えば、参考アドレスとかどのシーンで解析してるとか書いてくれると、
確認作業するときに該当個所に行きやすいかなぁ…(;・∀・)
とりあえずオツカレ(゚∀゚)!
173:名無しさん@お腹いっぱい。
08/12/11 22:15:00 jVWt4NGd
とりあえずキャラの存在チェックをまとめると
[66](スキャン開始)->
[0401](武将を検索)[08](4文字)->”ここに武将名”->[0312](スキャン終了)->
[FFFFFFFF](死亡)->[0202](真なら)->[02](4バイト後ろにある処理を実行)->
偽ならその後ろの処理へ・・・
ちなみに[02][??????][09]は[08 06 8A 01 31 00 00 00 00 01 00 00 00](重要キャラの死亡フラグON)を実行し、
これ実行したらGAMEOVERになった。
勢力別の重要キャラリストの最後に人には[02]~[09]の後ろに[02]~[0F]がある。
これは素直にチェック終了の[0E]につながってた。全員生きてたらチェック終われって事だな。
174:名無しさん@お腹いっぱい。
08/12/11 22:30:33 jVWt4NGd
じゃあ次は立絵CGの解析かな。
[0x13FFB]~
大名存在チェックのアドレス主人公存在チェックと一体
[66]~[0312]までのバイト数は[66]を含めて8バイト。カウンター以外は全員同じ数値だ。
武将チェックはそのすぐ後ろの[0x14134]~になってる。
これはmain.lbnからたどれるね。
未解析のタグとかあったら載せてみて、出来る限りがんばる。
なんてか、エロは偉大だな。
信長の野望ならここまで頑張らんぞ。
175:名無しさん@お腹いっぱい。
08/12/12 02:00:31 cgn53N7C
大名の登録順は東北(南部)から00……かな
国番号も城番号の割り振りも北から順番ぽい。
東北(北陸奥→南出羽)、関東(常陸から相模・伊豆まで)、東海(駿河から伊勢まで)、
甲信(甲斐・南北信濃)、北陸(越後~越前若狭らへんまで)、
近畿(近江、山城から紀伊まで順番不詳)、
山陰(丹後但馬~石見)山陽(播磨~周防長門)、
四国(阿波~土佐)と九州(豊前豊後、筑前筑後、肥前肥後、日向大隅薩摩)
176:名無しさん@お腹いっぱい。
08/12/12 18:31:34 wqhpjMwg
>>175
大名の登録順はnew.dat/daimyo21.bin
国はnew.dat/kuni21.bin
にそれぞれ書かれてる順じゃないかな~。
(コレ解析して書き換えたら沖縄とか北海道とか追加できんのかな…?w
177:名無しさん@お腹いっぱい。
08/12/12 18:32:37 wqhpjMwg
ちまちまと文章の文字数を増やしたり減らしたりして、
main.sdのデータサイズが変わる状態でイロイロ試している。
で、いまのところmain.sdと併せて
main.ev main.lb main.tko のアドレスを全て書き換えるまでは出来ていて、
改変後のmain.sdとmain.lbでタグ解析して普通に読めるので出来たかな~と思いきや。
○武田シナリオがSLGパートを抜けた後に始まらずに固まる
○『女に会う』をやると落ちたりする
○城に攻め込もうとしたらいきなりOPムービーが流れたりする
(落ちたのかと思ったらいきなりフルスクリーンで『さぁ~かせてあぁ~つくぅ~♪』)
フラグ操作とかSLGパート関連でも書き換えないとダメな部分があるのかのぅ(;・∀・)
(main.lbとかからのサイド攻撃やめてmain.sd一本に出来んもんかのぅ…。
178:名無しさん@お腹いっぱい。
08/12/12 20:07:57 9awXovP7
毎度毎度乙です。
main.sd内部でのアドレス移動が結構あるんで、その辺りでおかしくなってるんじゃないかな?
最後のほうのエンディング関係のがあるんでその辺りのからみかな?
[12]や[03]が解析できたら結構うまいこと行くかも。
てなわけでその辺りのややこしいのが解るかもしれないCG関係を分解してみた。
新しいタグはそんなに出てこないけどかなり謎が多いので、
解析のヒントになるかな?程度です。
179:名無しさん@お腹いっぱい。
08/12/12 20:09:47 9awXovP7
かなりズレてるんですが勘弁
ゲームのVerは1.00です。
シーン名(立絵:信長_A 驚き)
0x02BE97~0x02BE7Aまで全0xE4バイト
0x000000 : 00 01 02 03 04 05 06 07 08 09 0A 0B 0C 0D 0E 0F
----------------------------------------------------------
0x02BE90 : 00 00 00 0E 0C 39 00 03 0C 45 00 01 49 02 00 00
0x02BEA0 : 03 17 00 00 00 00 FF FF FF FF 02 02 00 00 00 12
0x02BEB0 : 0C 45 00 EB BE 02 00 08 0C 46 00 21 03 00 00 01
0x02BEC0 : 49 02 00 00 08 0C 47 00 D1 02 00 00 01 48 02 00
0x02BED0 : 00 08 0C 49 00 49 02 00 00 00 FF FF FF FF 08 0C
0x02BEE0 : 4A 00 48 02 00 00 00 FF FF FF FF 4B 0C 4E 00 01
0x02BEF0 : EE 01 00 00 6E 6F 62 75 6E 61 67 61 5F 41 00 00
0x02BF00 : 00 00 00 00 8B C1 82 AB 00 03 0C 51 00 01 81 02
0x02BE10 : 00 00 03 12 00 00 00 00 00 00 00 00 02 02 00 00
0x02BE20 : 00 12 0C 51 00 4E BF 02 00 3D 0C 52 00 01 EE 01
0x02BE30 : 00 00 01 21 03 00 00 00 00 00 00 00 01 D1 02 00
0x02BE40 : 00 00 00 00 00 00 12 0C 53 00 61 BF 02 00 3F 0C
0x02BE50 : 54 00 01 EE 01 00 00 01 D1 02 00 00 00 00 00 00
0x02BE60 : 00 40 0C 58 00 00 32 00 00 00 08 0C 5C 00 81 02
0x02BE70 : 00 00 00 01 00 00 00 0E 0C 5E 00 03 0C 64 00 01
上記を詳しく分解してみるます。
[0C ?? ??]:このシーンでのカウンター、無視します!
180:名無しさん@お腹いっぱい。
08/12/12 20:12:14 9awXovP7
>>179
★[0x02BE97]:スタート位置
・[03]:不明(8バイトか9バイト)
・[01 49 02]:何を指すのかわからないが、
後に[49 02]や[48 02]がよく出てくるのでフラグ参照とかしてるのかも。
・[03 17]は武将存在チェックの[03 12](終了)に近い意味かと。
過去に出てきた[66]は8バイトぽいので[03 17]が[03 12]と同じなら
[03]は9バイトなのかな?
他の項目で調べても[03]~[03 ??]まで11バイト。
・[FFFFFFFF]:?
・[0202]:5バイト?やっぱり「AならばB」的な感じかな?
でもなんか違う気もする。謎だ。
・[12]:アドレス移動型のIF命令かな?自信なし!(8バイト)
・[EB BE 02]:アドレス[0x02BEEB]へ飛ぶ。[12]と連動。
181:名無しさん@お腹いっぱい。
08/12/12 20:13:20 9awXovP7
>>179
[0x02BEB7~] ここからが条件?条件の終了は何処だろうね?
・[08]:main.swnを呼ぶ
・[21 03]:main.swn内の0xC840でフラグ名は「nobunaga_vanish」信長消える?
・[01 49 02]:フラグの入力値(謎、後に出てくる[49 02]と関係は?)
シーン鑑賞フラグなどの入力値は[00 01]だったが、ここは[01~]になってる。
[00~]と[01~]で命令が少し違う気がするね。
・[08]->[D1 02](フラグ名「nobunaga_x」)->値[01 48 02]
(また出てきたよ[01~]の値)
・[08]->[49 02]->[00FFFFFFFF](set_vanish)
・[08]->[48 02]->[00FFFFFFFF](set_x)
頭の[00 ????]が値の入力命令で、[01 ????]は値の参照命令なのだろうか?
ここまでの命令は立絵が消えているか、消えてないなら消すとかかな?
182:名無しさん@お腹いっぱい。
08/12/12 20:14:38 9awXovP7
>>179
★[0x02BEEB] [12]命令で飛んだ先
ここからがおそらく立絵を実際に表示させる命令群かな
・[4B](立絵呼び出しの命令?)->[01 EE 01](不明)->"nobunaga_A"
これは「char\nobunaga_A.ch」を呼び出してるのでしょう。
・"驚き"("nobunaga_A"との間に00が6バイト分続いてる)
これはnobunaga_A.chの中の表情ファイルの呼び出し命令かな?
これにより「char\nobuharuA04.tig」が呼び出されるわけだね。
・[03]~[03 12]と続いて[12]命令であっち行ったりこっち行ったり。
途中で・[3D]・[3F]・[40]のタグが出てくるけどまだ不明。
まさかとは思うが立絵の表示位置?
ちなみに[12]タグは同じmain.sd内でのアドレス移動なんで
これでおかしな挙動になるのかもね。
183:名無しさん@お腹いっぱい。
08/12/12 20:16:35 9awXovP7
>>179
★[0x02BE73]に[0E]があり[0x02BE7A]で終了。
謎の文字列だらけだと思ったが、分解してみるとなんとなく解るね。
立絵一つ表示でコレだけの命令があるのは、
キャラが2人以上並んだ時に表示位置をずらす関係だろうね。
ちと今回は自分でも解りにくい感じになってる。
なんせ移動が多くて何を意味してるのかさっぱりとは言わないが難しいね。
誰か援軍ぷり~ず。
184:名無しさん@お腹いっぱい。
08/12/12 20:52:02 9awXovP7
むむむっ
見返していたらなんとなく[03][0202][12]の繋がりが解ってきたぞ。
最初の
[03]~[01 49 02] [03 17] : [01]:参照せよ、[4902]:main.swn内のset_vanishを(main.swでの0x0924)
[FFFFFFFF][0202] : main.swでの0x0924がFFFFFFFFならば
[12]~[EB BE 02] : main.sd内の0x02BEEBへ飛べ。
かな?
[08]~からは[FFFFFFFF]で無かった場合の処理だね多分。
[12]はIF文ではなく単なるアドレス移動かもしれない。
185:名無しさん@お腹いっぱい。
08/12/12 21:37:38 a94ui+gk
凄いな
こんなにらしく動いてる改造スレ久し振りに見たぞ
186:名無しさん@お腹いっぱい。
08/12/12 22:53:30 wqhpjMwg
>>184
なんと言う人間タグパーサー(;゚Д゚)
ていうかオレも開眼したかも知れん。
[Address]: 0x0005258D 信長と最初にボードゲームで遊ぶシーン
[01] 21 C0 00 F7 0A 00 00
[01] 21 C3 00 84 38 01 00
[01] 21 C4 00 16 9D 01 00
1つめ[01] data block [0x00000AF7] => main.sd
56 04 EC 01
53 04 ED 01
=> 62 67 5C 62 67 30 34 2E 74 69 67 00 (bg/bg04.tig作戦会議とかする部屋)
3C 04 EE 01 00 64 00 00 00 62 67 5C 62 6C 69 6E 64 2E 74 69 67 00
0E 04 EF 01 (もどる)
2つめ[01] data block [0x00013884] => main.sd
08 06 1B 00 48 02 00 00 00 00 00 00 00 (set_x) X座標を0にしなさい
08 06 1C 00 49 02 00 00 00 00 00 00 00 (set_vanish) 絵消しフラグを0にしなさい
0E 06 1D 00 (もどる)
3つめ[01] data block [0x00019D16] => main.sd
>>179と似た感じで立ち絵信長基本
立ち絵って800x600の画像なのでX座標0で画面中央に表示される。
187:名無しさん@お腹いっぱい。
08/12/12 23:11:29 wqhpjMwg
うおお絶望した何か凄い絶望した。
[01]も[12]もmain.sd内のアドレスガシガシ参照してるじゃん。
っていうか>>171で自分で[01]タグからmain.sd内参照してるクセに
main.ev main.lb main.tkoのアドレスだけ書き換えても
うまく動くワケないじゃん(゚∀゚)!
188:名無しさん@お腹いっぱい。
08/12/12 23:17:02 cgn53N7C
>>176さんきゅ
順番確認した
それ、やっぱりSS天下統一と同じ格納方式
別口でNEW.DATを弄くって五島や種子島も出てくるようにした、天下統一アドバンスの在野シナリオがあるよ
(全国マップと城・街道の連結も書き換えて)
189:名無しさん@お腹いっぱい。
08/12/12 23:45:44 9awXovP7
>>186
立絵の位置はどうやって変わってるんだろうとメモリエディタで立絵表示中のフラグを観察してみると
[1F FF FF FF]やら[ED FE FF FF]がり、この数値を弄ると移動したので詳しく調べてみた。
立絵中央以外に表示する時は(今回のケースは2人を左右に並べる)
シーンは光秀がメイド服きるとこ。
「0xEC654」
[01] 5E 80 00 A2 38 01 00 <-位置情報01
[01] 5E 81 00 16 9D 01 00 <-信長の立絵
[01] 5E 83 00 66 38 01 00 <-位置情報02
[01] 5E 84 00 8C A1 01 00 <-光秀の立絵
位置情報01
[08] 06 21 00 48 02 00 00 00 1F FF FF FF
[08] 06 22 00 49 02 00 00 00 ED FE FF FF
[0E] 06 23 00
こうなってるわけだが
[08]での入力値が[00 1F FF FF FF]
これは2人を左右に表示させる命令ですぐ後の
[08]~[EDFFFFFF]もセットで命令される[0E]が命令の最後だもんね。
位置情報02
[08] 06 15 00 48 02 00 00 00 E1 00 00 00
[08] 06 16 00 49 02 00 00 00 13 01 00 00
[0E] 06 17 00
この4つの[08]で二人の表示位置を左右に分けているようだ。
「0x138A2」付近は立絵の表示位置情報がいくつか並んでいるっぽい。
というわけで[3D]・[3F]・[40]は関係なかったみたいだ。
なんだろコレ?
>>185
実際何人くらいこのスレ見てるんだろう?
190:名無しさん@お腹いっぱい。
08/12/12 23:51:39 9awXovP7
>>187
実際[12]とかイベント会話アドレスの間とか、
main.sdの最後の方にもあったり参照してたりするので絶望感が出てくる鬱陶しさだな
CGとかのパッケージ化もしてないんだし、
どうせならシーン毎に別ファイルにでもしてくれてればいいのにね。TXTのままでいいじゃん!
最悪アドレスの変更しないような改造で・・・・・・
191:名無しさん@お腹いっぱい。
08/12/12 23:59:50 cEs6WceF
みんな頑張ってるな。
とりあえずエディタができたら信玄タソハッピーエンドの製作に取り掛かりたい…
192:名無しさん@お腹いっぱい。
08/12/13 00:04:57 sUbNIxOZ
>>191
戦闘前とか後に適当な背景+立ち絵で適当な台詞しゃべらせるmodを・・・
193:名無しさん@お腹いっぱい。
08/12/13 00:55:36 S4p4CwSL
>>186 確認しました。その考え方で合ってると思う。
(set_x) (set_vanish) は立絵が無いときに[00000000]になっていて、
立絵があるときは[FFFFFFFF]になってる。
[08]タグの場合、入力値は5バイトで、[00~]が書き込み命令だと思う。
この場合は[00][00000000]になっているので、[00]書き込め[00000000]を、てな感じ。
また、[01]と[12]の違いもこんなかな?
[01]で参照した場合は[0E]に当たると、元の[01]のところに戻る。 <-アドレス参照
[12]の場合は参照先などで命令順を飛ばすとかに使っていて、
[0E]があっても[12]の位置に戻らず[01]のとこに戻る <-アドレス移動
これ[66]やら[03]が解ってくると世界が広がるよ。多分
194:名無しさん@お腹いっぱい。
08/12/13 02:45:42 p9qG+31e
>>189
ツールがちょくちょくあるからRomはそれなりに居ると思う
195:名無しさん@お腹いっぱい。
08/12/13 03:56:02 TavppwVG
マジパねぇ絶望の果てにオレは再び開眼したかもしれん(; ・`д・´)
Youの家でも無事に動く事を願ってやまない…
■URLリンク(apple.mokuren.ne.jp) DLKey:sghmod
196:名無しさん@お腹いっぱい。
08/12/13 10:12:37 lBDFnsWE
>>195
うほっ、いいシナリオエディタ
197:名無しさん@お腹いっぱい。
08/12/13 11:16:28 y/hHOkZE
>>195
殿!やんごとねぇツール作りましたな。野望達成にまた一歩。
ver.100
main.sdも弄りまくってたのでオリジナルに戻してからツールを実行。
新規ゲーム開始で、普通に「殿ッ、~」が始まったので、どこに原因があるのか探ってみた。
通常のシーンならこんな感じの変更でいけるみたいだけど、
ゲーム開始時だけは少し違うみたい
main.lbnを見ると「home_start_mouri」があり、今回改造した「mouri01」
と同じアドレスに飛ばしているので、
・main.lb
[0xB0](mouri01)→[E2 06 04] (元の値に戻す)
[0xA4](home_start_mouri)→[12 D1 32] (ケチャップのアドレス)
・main.sd
[0x32D29F]→[2C 00] (最後、[02]で飛ばす所。2C00はmain.lbの[0xB0])
にしたらケチャップシーンが終わったあと「殿ッ、今年こそ~」が始まった。
開始時に立絵の消去命令が入ってなかったので、信玄がスタンド使ってたがな。
うちだけなのかもしれないが。
198:名無しさん@お腹いっぱい。
08/12/13 13:54:20 TavppwVG
>>197
なんかウチだとhome_start_mouriだと動かなくて、mouri01にしたら動いたのでそんな感じに
しといたんだけど、なんかよくワカランので引数でmain.lbの書き換えたいindexを渡す感じに
してみた。(添付のbatは41と44を書き換える)
■URLリンク(apple.mokuren.ne.jp) DLKey:sghmod
ためしに[08]タグ使って49 02 00 00に 00 01 00 00 00 とか 00 FF FF FF FF とかやって
set_vanishしてみたんだけど、信玄の立ち絵消えなかった…w
>>193
アレかね[01]は言うなればincludeで[12]goto(使ったコトないがw)みたいな感じかね?
[02]との兼ね合いとかどうなんだろう?とちょっと思うけど、
ひょっとしたら[02]の場合は、現在までのシーンで確保した領域をdeleteとかして解放
するのも込みなのかもねぇ。
>>196
スパルタ仕様ですんません(; ・`д・´)解析メンが増えたりすると
プログラムに割ける時間が増えてちょっとはマシになるかも知れません(; ・`д・´)
199:名無しさん@お腹いっぱい。
08/12/13 16:07:02 3/7rkk8/
[01]と[12]はそんな感じ。
[02]はmain.lb経由の移動命令じゃないかな?
似たような役割のタグが複数ある場合は、タグによって参照ファイルに違いがあるとかかな?
立絵を消すのは[01]タグがよいかな
例えばケチャップシーンだと [01 FE 15 01 93 E6 03 00]
これを最後の[02]タグとの間に挿入したら立絵が消えてから本編始まった。([02]のカウンターも+1して)
立絵消去のアドレスはキャラによって違うみたいだ。
・「0x03E693」信玄の場合(表情違っても消せるみたいだね)
[3E] 13 F7 00 01 F8 01 00 00 01 29 03 00 00 00 00 00 00 00 ←main.sw(shingen_C)と(shingen_vanish)の調査?(shingen_C)は07で固定されてるな
[40] 13 FA 00 00 32 00 00 00 ←?、[3E]とセットなのかな?、[3E]と[3F]の調査の終了命令かもね?
[08] 13 FE 00 29 03 00 00 00 00 00 00 00 ←shingen_vanish
[08] 13 FF 00 D9 02 00 00 00 00 00 00 00 ←shingen_x
[08] 13 02 01 89 02 00 00 00 00 00 00 00 ←shingen_view
[0E] 13 04 01 ←戻る
いろいろ調べるたびに1行目の[01 F8 01]が、
[01]:ただ単に見ろ、[F801]main.ibの[0x7E0]に見えて仕方がない。
200:名無しさん@お腹いっぱい。
08/12/13 17:17:54 Wzqs92ti
[01]:ただ単に見ろ、
[F801]:main.swの[0x7E0]をに見えて仕方がない。
だね。ごめん
201:名無しさん@お腹いっぱい。
08/12/13 18:02:23 TavppwVG
>>199
あーそうか。そういや[02]はmain.lbを参照してるんだったね。
立ち絵の処理系はコマンド群としてもう出来上がってるんだねぇ。
自前で[08]ポチポチ書くよりか[01]からコマンド群直接includeしちゃった方が
楽だし確実ってコトか(゚∀゚)
199の後半あたり読んでmain.swnにそんなフラグまであんのか…w
と思って改めて見てみたら1000個近くあるな…w
とりあえず↓main.swnをdumpしたもの.txt DLKey:sghmod
URLリンク(apple.mokuren.ne.jp)
なんか調べもせずにスゲ適当書くケド[3E]の中身って
if( shingen_C && shingen_vanish ) みたいな感じかねぇ?
202:名無しさん@お腹いっぱい。
08/12/13 18:11:17 TavppwVG
またスゲ適当に妄想書くケド、
[03] if( condition )
[3E] if( !condition )
とかで例えば
[3E] でshingen_Cのデータが正しく読み込めたかをチェックして
[40] でエラーダイアログを表示して
[08] 群で、とりあえずshingen_C表示言われたら無視しとくようにする
とか…?(;・∀・)
203:名無しさん@お腹いっぱい。
08/12/14 00:35:53 5Ll1RUPn
>>202
そうかエラーダイアログってのもあったね。なるほどそうかもしれん。
でも確認しづらいなこれは。
・[03]
>>179 の
0x02BF09 : 03 0C 51 00 01 81 02 00 00 03 12 00 00
の中盤の[01][81 02 00 00]
これはmain.swの「set_vanish」を見ていると考えるとつじつまが合う。単純に1アドレスのみ見てるね。
・[3E]
[3E 13 F7 00](4byte) -> [01][F8 01 00 00](5byte) -> [01][29 03 00 00](5byte) -> [00 00 00 00 00](5byte)
>>199の[3E]~は上のように分解できるが、意味的にも参照してるのは、main.swでしょうね。
[F8 01]は常に固定されてる気がするので、この部分は何を調べているのかわからんな。
最後が5バイトなのが気になり、後半は書き込み命令かとも思って、
いろいろ弄ってみたが、具体的にどんな仕事してるのかわからなかった。
・[3F] : >>179で出てくるが、[3E]との違いがわからん。全く同じ構文だ。もしかしたら[08]の変形型かも。
・[3D] : [3E]の後半が2つになってるバージョンか?
[3D](4byte) -> [アドレス0](5) -> [アドレス1](5)->[00群1](5) -> [アドレス2](5)->[00群2](5)
これに関しては>>179を見てると[08]の複数命令にも見えてくる。
これらはイベント作成上、おそらく入力することがないと思うので、
バイト長くらいを調べておくだけでもいいかもしれない。
204:名無しさん@お腹いっぱい。
08/12/14 06:07:44 n3kogcN0
>>203
もしかしたら[3X]系のタグってif文みたいののバリエで
if( condition )
if( !condition )
if( conditionA && conditionB )
if( conditionA && !conditionB )
if( !conditionA && conditionB )
if( !conditionA && !conditionB )
こんな感じで論理積が論理和になっちゃってるバージョンとかも
イロイロと個別に実装されてんのかもねぇ。んで条件式は==0ばっかりとか。
そうするとflag位置を参照だけしてるっぽい動きも納得できる気がする。
(まぁ、納得したいがためのこじつけな気がしなくもないけど…w
# しかしまぁ、コレだけ色々複雑に出来るようにエンジンは作ってあるのに、
# ADVパートにほとんど活かされてない気がするねぇ…w
# むしろこの複雑さが逆に仇となってクソ重くなってる気がする…w
とりあえずID:5Ll1RUPn には皆まで言わずとももう分かってるぽいけど、>>187あたりから
オレがかなり方向性を変えたので、[3X]系タグの解析は自分が納得できる点あたりで、
いったんpendingしてください。キミのブッ壊れたタグ解析能力のおかげで、
イロイロと見えなかったものが見えるようになったよ。(中には見たくなかった真実も
あったりしたけど…w)心からのリスペクトを込めてありがとう(゚∀゚)!
205:名無しさん@お腹いっぱい。
08/12/14 06:18:44 n3kogcN0
で、main.sdの既存部分を書き換えるというアプローチではもうシャレにならない労力が
伴うコトが分かったので(その労力を払っても成功するかはワカンネ)
main.sdに新規にデータを継ぎ足して、main.lbとか比較的構造の単純なヤツをいじって
リンクの張り替え的なアプローチをしてみるコトにした。
■sgh_editor 超絶実験版 ver0.01 DLKey:sghmod
URLリンク(apple.mokuren.ne.jp)
↓こんなの
URLリンク(apple.mokuren.ne.jp)
URLリンク(apple.mokuren.ne.jp)
# ぶっちゃけこの手法で無理そうならもう撤退します(;・∀・)
206:名無しさん@お腹いっぱい。
08/12/14 10:04:00 +yJY6h9s
>>205
神!
形になったね。すばらしいツールになってきてる。
で、実験してみたけどうまく行ったよ。
あとはmain.lbの何処に追加するかの選択と、
シーン終了後の[02]がしっかり出来たらほぼ動くんじゃないかな?
・[02]
単純に「会う」で簡単な会話のときは[02]~[BE](main.lbnでのmeet_end)
回想シーンなどに関しては[02]~[02](main.lbnでのmain.txt)
シーン連結を考えないのならどっちかを末尾に加えるだけでいいかもね。
・[08]
ストーリー部分の差し替えは[08]が絡むからフラグリスト選択してそこに01を入力
[08][?? ?? ??] [(main.swnのリスト÷0x40)] [00 01 00 00 00]
てな感じで・・・
フラグの構造はいたってシンプル。
最初の[mode]、[char] はバグルかもしれんので弄らない。
[「キャラ名」_View]、[_x]、[__vanish] 及び
[「キャラ名」_A]、[「キャラ名」_B] なんかは立絵関係なんで弄らない。
「キャラ名_feeling」は会った回数なんで会うごとに+1されていくが、
[08]タグではここを追加することをやってないみたい。弄る必要性無し。
残りのイベントフラグは、イベント終了後に01が入力されるだけ。
このあたりを理解してると改造も楽だね。
まあ、フラグは後回しでいいと思う。
207:名無しさん@お腹いっぱい。
08/12/14 12:28:23 +yJY6h9s
>>205
回想シーンなどに関しては[02]~[02](main.lbnでのchar_scn_end)
の間違いだった。
作成したシーンを「会う」と置き換えてみたんだが、
[02]~[BE]を入れても、
作成したシーンを二回繰り返した後、置き換えたシーンの次のシーンにつながってしまったり
永遠にループしたりとやっかいだな。[02]が効いてない気がする。
実験的に1回目の会話イベントの最後の[02]に
2回目の会話イベントのmain.lbのアドレス入れてみたら、1回目の会話の無限ループが始まった。
[02]の代わりに[12]を入れてmain.sdの2回目の会話のアドレス入れたら1回目の会話の後に、すぐ2回目の会話が始まった。
もしかして[02]はmain.lb経由の移動命令ではないのかもしれない。
作成したシーンも最後の[02]を[12]に変えて適当なアドレス放り込んでみるとループしなくなった。
でも、上のように会話の連鎖もしないな。SLGパートに戻るだけ。
208:名無しさん@お腹いっぱい。
08/12/14 13:06:12 +yJY6h9s
追加シーンを2つ作成して
それぞれを誰か適当な人間の会話シーンに置き換えてみた。
[02]がなんだか頼りなくなってきたので、
[12]命令で追加シーン同士を連鎖させてみると、連鎖せず。
既存のシーンへ飛ばしてみると連鎖したりしなかったり・・・・・・落ちたり・・・
動きが読めん。
んで、とりあえず各シーン最後の
[02]~を [12]~[38 39 01](これが安全なのかどうかは不明だが)
に変更したらエラーなく元に戻れた。
[12]で入力するアドレスをミスったら落ちる落ちる。
しかしまあ、いけそうだなコレ。
209:名無しさん@お腹いっぱい。
08/12/14 15:43:27 n3kogcN0
>>206-208
そうそうそうそうそう(゚∀゚)!
readmeに書いといた直近問題ズの移動系タグのハナシは、
この辺が結局プログラムに落とし込めるほど理解できて無いのよ。
どんな時に02なのか12なのか、とか。
でも02とか12でchar_scn_endに飛ばすってのはナルホドなぁ~って感じだわw
ちなみに入れ替えてみたシーンって信長?
BE(ウチではちょっとズレてるみたいだが)って名前自体はmeet_endになってるけど、
参照元ファイルはnobunaga_s.txtになってるみたいなんで、
汎用命令として使えちゃうのかな?(; ・`д・´)
とりあえず
>もしかして[02]はmain.lb経由の移動命令ではないのかもしれない。
この仮説が恐すぎる((((;゚Д゚))))
210:名無しさん@お腹いっぱい。
08/12/14 18:11:10 n3kogcN0
>>208
あぁぁわかったかも(; ・`д・´)
アレだよね?シーンA用のbin_source.datとシーンB用のbin_source.datを用意したとして、
[素のmain.sd][シーンA][シーンB]
みたいに連結してAの最後をBに繋げようとしたんだよね?
いずれ何とかしないとな~と思ってはいたが、実験版制限仕様に書き忘れていた項目が
あって、各タグのメタデータ領域は何も設定をしないとscene_id FEのevent_id 1から順に
自動的に振られている仕組みになっているのだ。
なので例えばシーンAが終わってシーンBに飛ばす
=>シーンB冒頭のタグが処理される…
=>がしかし、scene_id FEのevent_id 1でシーンA冒頭とかぶる…
=>かぶったのでシーンB冒頭のタグ要求が破棄される。
みたいなコトが内部で起こってるんじゃないかのぅ…?(; ・`д・´)
シーンIDはrc/system.iniのSCENE_IDで指定してるので、例えばシーンBをFDとかで
作ってやると上手く行くかも知れん。
それか、たぶんこの段階で256もevent_idを使っていないと思うので、
バイナリエディタで開いてシーンBの各タグのtt aa bb bbの bb2つめを01とかに
書き換えてもイイかも知れん。
何にせよコレで意図した通りに動いたら、オレの情報伝達ミスだ。
もの凄くコレで動く予感がするので先にあやまっておく。正直スマン(;´∀`)
211:名無しさん@お腹いっぱい。
08/12/14 20:21:29 +yJY6h9s
>>210
>>[素のmain.sd][シーンA][シーンB]
その通り。実験的にやってみた。
タグの後ろのFE????は適当に入れてる。数字がかぶらない程度。
[0F]の後ろの変な数字はとりあえず0000のまま。
入れ替え元のシーンは、信長の2回目くらいの汎用会話と半蔵の「ニンッ」
main.lbの毛利オープニングのとこもこのシーンにつなげてる。
シーン終了後すぐ1ターン目になった。
[12]命令で[char_scn_end]に飛ばした理由はなんとなく
[meet_end]に比べて命令が単純に見えたので。
[char_scn_end]は重要なシーン終了後、プレイ中の大名?のフラグチェックして
問題なければ最後にある[0E]に飛ばしてるだけだったので。
[meet_end]は背景の処理なのか立絵の処理なのか画像系の処理とフラグ調査をやってる。
一応ここに飛ばしてもエラーや不具合は起きていない。
[02]なんだが、
もう一度実験したらループ現象が起きなくなって普通に動いた。挙動不審だな。
使用するための条件とか環境が厳しいのかな?これが確実に動けば完成したも同然なんだが・・・
シーンの連結だけど、
既存のイベントでも綺麗につながるかどうかもわからないし、
普通つなげることはしないと思う。するんだったら一つのシーンに纏めたほうが管理しやすいし。
本来存在しないはずのアドレス同士の連結なんで厄介なんだろうな。
212:名無しさん@お腹いっぱい。
08/12/14 20:38:44 892+JQom
続き
シーンIDを[FF]と[FD]に変更するのを試したが、
シーンの連結はせず、何事もなくSLG画面に戻る。
となると[02]とか[12]って、ここで仕事してるのかな?
会話に関しては画像が出て話が出来て、
んでもって[08]が動けば問題ないのだが。
[02]が動いてないと、置き換えるシーンを誤ると
エンディングチェックが出来ず、エンディングを迎えられないとかでるかも。
ゲームの再起動は度々やってたんだが、
ループ現象とかも起きなくなってるのはWindwosの再起動でメモリがリフレッシュされたから?
わけわからんな。いまは安定してるんだよな。
213:名無しさん@お腹いっぱい。
08/12/14 20:52:03 892+JQom
あ~でも[02]とかが仕事してなかったら次のシーンとの切れ目がなくなるので、
二つのシーンが繋がるんだよな。
ということは、
命令としての[02]や[12]きちんと動いてるが、移動先アドレスを無視してる状態なのか、
移動先での処理でなんらかの制限が加わっているのか。
214:名無しさん@お腹いっぱい。
08/12/14 21:47:49 n3kogcN0
ぬおお何か良くわかんなくなってきたぞ(; ・`д・´)
とりあえずID:892+JQomの現状としては
○『女に会う』のリンク張り替えを試している。
○新規作成部分の最後で『meet_end』に飛ばす場合、
(i) [02]でmain.lbのindex指定をして動いている。
(ii) [12]で直接アドレス指定をして動いている。
○新規作成部分の最後で『char_scn_end』に飛ばすと
(i) [02]でmain.lbのindexを指定するとループ現象が起きたり挙動不審
(ii) [12]で直接アドレス指定をすると動く。
こんな感じ?
215:名無しさん@お腹いっぱい。
08/12/14 23:06:02 c78xIT53
>>214
今のところ[02]で飛ばしているが、問題ない
新規作成シーン2個
>>○『女に会う』のリンク張り替えを試している。
その通り。
「meet_end」「char_scn_end」双方に[02]と[12]で飛ばす実験をしてみた。
シーンの最後はこんな感じに
[02] FD 0E 00 02 00 00 00
又は
[12] FD 0E 00 38 39 01 00
・最初の改造時
[02]を使用 -> 「meet_end」「char_scn_end」のどちらに飛ばしても挙動不審となった。
[12]を使用 -> どちらに飛ばしても問題なかった。
・飯食って家帰ってきてから再度[02]を試したら
「meet_end」「char_scn_end」のどちらに飛ばしても問題なく動いた。
この間にしたのはWindowsの再起動くらいだったんで、わけわからんのだ。
・現在の状況
[02]で「meet_end」に飛ばしてる -> 問題なし・・・
[02]・[12]でシーンの連結 -> 繋がらないが、SLGパートには戻る。
「meet_end」とかに飛ばしても、他のシーンのアドレスに飛ばしてもエラーなくSLGパートに戻る。
うまくはいってるんだが、連結しないくせにエラーも無いし、挙動がおかしくなる事もないのが逆に気になるんだわ。
移動できなかった時、あるいは移動先でなんらかの障害があった時の処理はどうなってるんだろうという疑問が・・・
既存のイベント同士でも[02]で連結しないことがあるしな。
216:名無しさん@お腹いっぱい。
08/12/14 23:10:22 c78xIT53
結論から言うと
「連結はするな!」だな。
実際オリジナルのmain.lbでシーン連結してるの見たこと無いし。
(正確には見つかってない)
217:名無しさん@お腹いっぱい。
08/12/14 23:23:14 n3kogcN0
なるほどなるほど>>215は凄くまとまっていて分かりやすいな(゚∀゚)
エッセンスだけを抜き出すと、
『女に会う』のイベントのリンクを張り替える場合(インターセプト?乗っ取り?)
最後は[02]タグでmeet_endに飛ばすのが妥当であろう。
というコトだな。
ついでに
>「連結はするな!」
だな…w
とにかくオツカレ(゚∀゚)!
218:名無しさん@お腹いっぱい。
08/12/14 23:49:41 8qvpAkoK
>>217
まとまってなくてスマン
なんせ調べる度に新しいことが解ったりコレまでの予想がはずれたりで・・・
遂次書き込んでると変になるね。
ある程度たったら一旦まとめ入れたほうがいいかな?
main.lbを書き換えて既存のシーンを無視してるので、インターセプトに近いかな。
「女に会う」でエロイベントがない場合「meet_end」
ターン更新時のイベントや「シーン鑑賞」に登録されるようなものは「char_scn_end」に飛ばすのがデフォルトらしいが。
今のところはどっちでもいい感じがする。
通常作成されるのが予想されるイベント等は、キャラチェックなんかのプログラム部分へ飛ばすことはないと思うので
シーン終了時の処理として上の二つへのリンクを選択できればベターかな?
219:名無しさん@お腹いっぱい。
08/12/15 00:09:22 1Lrw+EyK
>>218
あーいやいや。
とりあえず思いついたら何か書き込むスタイルの方がイイと思うぞ(゚∀゚)
現在何が進行していて、どの程度まで進んでいるのかとか分かるし、
書き込むために文章まとめてるウチに脳内整理されて気付くこともあるだろうし(゚∀゚)
んなワケで今のところ↓こんな感じになってる。
URLリンク(apple.mokuren.ne.jp)
中身スッカラカンだけどね~(゚∀゚)
220:名無しさん@お腹いっぱい。
08/12/15 00:31:51 1Lrw+EyK
ああんオレ日本語読めてなさすぎ(;´Д`)
区切り区切りでまとめ入れるか入れないかの話か。
まぁ、とくにルールにしなくてもイイんじゃないかのぅ?
ウダウダ話しあって収束したあたりで必要があればやる程度で(゚∀゚)
221:名無しさん@お腹いっぱい。
08/12/15 02:48:44 1Lrw+EyK
■sgh_editor 超絶実験版 ver0.02 DLKey:sghmod
URLリンク(apple.mokuren.ne.jp)
とりあえず本日実装分(゚∀゚)!
222:名無しさん@お腹いっぱい。
08/12/15 14:16:40 GlBNrwGq
>>221
_、_
( ,_ノ` ) n
 ̄ \ ( E) グッジョブ!!
フ /ヽ ヽ_//
「meet_nobunaga_01」との置き換え実験は一発で成功。(Ver1.00)
[なま]は手動でタグと数値をぶっこむやつだね?
追加で実装したらいいタグは、[1E]のBGMストップ(4+4バイト?)くらいか?
[08]のフラグはいろいろ実験成功してからでいいかな。
main.sdの後ろにデータ追加して、そこにmain.lbとかから飛ばすってのは、すばらしい発想だったね。
そのおかげでほとんどのタグを無視できるようになった。
実際イベント作成で使うタグなんてほんの数個だし。
後は、画像関係のリストができたら、ほぼ完成だね。
俺はただの解析厨だが、貴方は本当に神だ!
今度は[13]関係を調べてみようと思うが余力はあるかい?。
選択肢が絡むとかなりややこしい事になると思うので、
調べてみて面倒だったら止めたらいいし。
EO復活万歳\(^o^)/
223:名無しさん@お腹いっぱい。
08/12/15 15:30:25 E9MHJLfz
解析ラー乙でし。自分は半分も理解できてないけど、新しいイベントに差し替えができそうやね。
最後は織田ルート全面改定をば......
224:名無しさん@お腹いっぱい。
08/12/15 17:17:07 1Lrw+EyK
>>222
HAHAHAデータ書き換えでは見事に敗北したが、インターセプト作戦でイーブンだ(゚∀゚)!
[なま]はver0.03のreadmeに書いといた。
[1E]つけた。
[08]保留。
[13]保留。
とりあえずタグの生ブッ込みを実装したので、理論上書けないタグはなくなったし、
01タグの中身も外部ファイル定義にしたのでreadme見て調べて試せばなんとかなるだろ。
コマンドリストのセーブとロードもつけたので、コマンドリストのデータと
連結してほしいエントリさえ聞けばシナリオ配布も可能(なハズ)
なのでまぁ、あとは基本的にKIAIかなと。
で、今まで使える使えないは置いといて、それなりの数のツールをリリースしてきた
つもりなんだけど、今までマトモに改造とかされてんの一度も見たコトが無いので、
(png2tig作ったときにテラ北斗なSS一枚見ただけな気が…w)
これ以上だ~れも使わないであろうツールに労力を割くのもどうかな~と(; ・`д・´)
もしもシナリオとかイロイロ書く人があらわれて、オレが楽しめるようになった時に
シナリオ書く上でタグ書きが煩雑すぎたりするようなら、何か対応しようかなぁ、と。
まぁ、その時にこのスレを見ているかどうかは分からないケド(゚∀゚)
225:名無しさん@お腹いっぱい。
08/12/15 17:17:39 1Lrw+EyK
んなワケで
■sgh_editor 実験版 ver0.03 DLKey:sghmod
URLリンク(apple.mokuren.ne.jp)
とりあえず不可避な致命的バグでも出ない限り開発一旦pendingします(;・∀・)
ID:GlBNrwGqへ
オレがタグの概念を教えたハズだったのに、あっという間に抜かれてしまって
正直ちょっと悔しいw途中からタグ系の解析丸投げな格好になっちゃって
申し訳なかったけど、それでも「も~何このタグぅ~」とか思ってたのが
見る見るウチに解き明かされていく様はなかなかに面白かったぞ(゚∀゚)
226:名無しさん@お腹いっぱい。
08/12/15 17:24:34 pnjGJvjo
この解析班優秀だな
久しく見てないぞこんな改造されてんの
日曜になったらオルテナをガッツのタカさんにするから待っててくれ
227:名無しさん@お腹いっぱい。
08/12/15 18:02:59 GlBNrwGq
ID:1Lrw+EyK
ひとまずおつかれ~
結構面白かったぞ。
ちなみに俺が開眼したのは
[タグ][アホカウンター][DATE]
の並びになってるのを教えてもらった時だった。
あとは弄って実験と、想像でなんとか。
>>(png2tig作ったときにテラ北斗なSS一枚見ただけな気が…w)
これ俺だ。w
最初はCGの差し替えを何とかできないか、だけだったから・・・
柴田勝家は最初、戦国ランスのにしようとしたが立絵が切れてて止めた。
現在CGリストを完全にする作業をちまちまやってるが、無茶苦茶うっとうしいなコレ。
背景だけでもノーマル、明るい、暗いの3種あって150種類近くあるんだな。
アドレスも文字数によって変化するのでただ単にいくつ+とかではいかないし・・・
立絵と背景を別々のリストで指定できるようにはできんかな?
全部並べたら結構見にくいぞ。
あと、エフェクトはどうするかな?
見る限りホワイト系とブラック系しかないし、[01]で飛ばしてるだけだろうし。
簡単だと思うから調べてみようか?
228:名無しさん@お腹いっぱい。
08/12/15 18:21:51 GlBNrwGq
>>立絵と背景を別々のリスト
背景とイベントCGと立絵の3種・・・
229:名無しさん@お腹いっぱい。
08/12/15 18:24:43 E9MHJLfz
>>224アガトウ
エディタは使いこなせてないけどPNG-TIGは使ってるよ。
鍋島さんとか、北条や佐竹の一門衆とか
尼子十勇士っぽい方々とかてきとーに画像当てて声も差し替え。
ほんとは元ネタ同一シリーズで固めるべきなんだろうなぁ...
高橋紹雲(鎮種)や高橋統虎(立花宗茂)なんかも女性化すればいいのになー統虎なんか本多のへーちゃんと双璧で誉められてたんだし
230:名無しさん@お腹いっぱい。
08/12/15 21:34:09 3MmbYFFB
ここみてると、ADVパートはなんでこんなの作っちゃったんだろって出来だな
231:名無しさん@お腹いっぱい。
08/12/15 21:40:34 5oUuM/xx
>>230
いまさら何を言ってるんだ
232:名無しさん@お腹いっぱい。
08/12/15 21:59:43 3MmbYFFB
すまん、本スレと誤爆した
233:名無しさん@お腹いっぱい。
08/12/15 23:22:38 1Lrw+EyK
おし。オレ的にかなりパーフェクトに近い島津オープニングが完成したぞ(; ・`д・´)
URLリンク(apple.mokuren.ne.jp) DLKey:sghmod
動作実験や練習も兼ねてヒマな人以下をやってみてオクレ
①sgh_editorのinディレクトリにmain.ev main.lb main.lbn main.sdをコピってくる
②解凍して出て来るshimadu_OP.datをsgh_editor ver0.03で開く(めにゅ~=>ろ~ど)
③右下の方に二つあるリストのmain.lb連結の方からhome_start_shimaduを選ぶ
④コンパイルボタンを押す
⑤outディレクトリにmain.ev main.lb main.sdが出来るので戦極姫のmain/にコピる。
⑥島津でゲームをスタート。
[追記]今回使った01.txtも添付しといたので、必要なら適当にマージしてオクレ(゚∀゚)!
234:名無しさん@お腹いっぱい。
08/12/15 23:40:07 1Lrw+EyK
>>227
なんつーかあんま誰か一人ががんばってリストを完成させる必要は無いかな~
と個人的には思っていて、画像系のはKIAIさえあればバイナリエディタで開けば分かると思うんだ。
開くか開かないかの差であって。
んで、誰かが何かを書く際に調べた01情報が少しづつマージされていけばいいかな~なんて(゚∀゚)
ただまぁ、自分でちょっとやってみて消去系のはmain.swとかとの関連が分かっていて
ある程度タグが読める人じゃないと無理くさい感じはしたかも。
それとリスト分割のハナシだけど、まぁまぁそんなに焦らずに
リストが成長したころに一度、画面の上から下までびろ~んって広がってるプルダウン見て
うっはwwwwナニコレwwww長すぎwwwwwwwwwwwwwwwwww
なんて一笑いしてから考えようz
分割に関してコレが正解というのがまだ見えていないのと、
実装工数のハナシになっちゃうけど、コマンドリストからの書き戻し処理を入れたので、
ぶっちゃけちょっとメンドクサイ。これがFAというのが出ていて一度きりならすぐやるけど、
「ああんやっぱりこうがイイ」「いやいやこれはこっちだろ」みたいになると超メンドクサイ。
それとエフェクトだけど、余裕があったらちょっと見てみて欲しいかなぁ。
ハマるようならエフェクトはしばらくお預けって感じでもイイし。
# っていうかテラ北斗やっぱりオマエか…w
235:名無しさん@お腹いっぱい。
08/12/15 23:50:52 1Lrw+EyK
sgh_editorがどんな発想で動いているのかをドキュメントにまとめてみた。
■URLリンク(apple.mokuren.ne.jp) DLKey:sghmod
一応目を通しておくと、一見複雑に見えるmain.lb連結だのが何故必要なのかがワカル(゚∀゚)!
>>226
なんだか日曜日を待っておく(; ・`д・´)
>>229
ssはまだか。ssはまだなのか。
236:名無しさん@お腹いっぱい。
08/12/15 23:54:04 GlBNrwGq
URLリンク(apple.mokuren.ne.jp) DLKey:sghmod
CGリストを一応作ってみた。
イベントCGなんか、まだこの3倍あるわけだがしんどいので基本を全部入れただけ。
立絵は表情なしの基本と消去を入れてみた。
解凍後「rc」フォルダに入れるのだ。
立絵位置(左)
立絵位置(右)
というのがあるが、これは「立絵位置(左)」を追加し直後に、立絵を追加すると絵が移動するかもしれないモノ
一回も試してないがな・・・
アドレスが間違ってるのがあったら教えてください。
>>225 すまねぇ
やっぱ[08]が必要だ。
俺は[まな]でいけるのだが、フラグ無しではイベントが進まなくなると思う。
例えば
main.lbの[meet_ai_01]と追加シーンを置き換えたら、
main.swの[meet_ai_01_end]に01を入力しないと
[meet_ai_02]がはじまらなくなると思うのだ。
書式は
[08][aa bb bb][xx xx xx xx][00 01 00 00 00]
aabb = カウンター
xxxx = main.swnのリストのアドレス÷0x10
シーンの最後の「移動とか」を入れる直前にこれを入れないとな。
本当にすまないが、もうしばらく付き合ってくれないか? m(_ _)m
237:名無しさん@お腹いっぱい。
08/12/16 00:21:23 nBcMkhMv
>>235 いい解説ですじゃ。
ファイルのサイズが変わると落ちる。みたいな仕様でなくてよかった。
main.sd の上のほう・・・Verでアドレスが変わってたらいやだな。Ver縛りが入ってしまう。
Ver1.01で見てみたけど上のほうは変わってない気がするが、ソフマップ特典はやばそうだ。
フラグ関係はかなりずれてると思うから。
リストの件だけど
現段階ではリストからの選択は面倒だけど
リストが完成してきたら、同じキャラの立絵が並んで逆にわかり易くなるかも。
センスある人にリストの名前部分を直してもらいたい。
このゲーム、顔グラだけなら単純にファイル追加して武将のリスト弄れば、
既存のファイルと置き換えないですむんだな。
理論上65535ファイルまで増やせると思う。
238:名無しさん@お腹いっぱい。
08/12/16 09:47:29 pMT0foMe
>>236
スンゲーリストきたぁ~(゚∀゚)
と思ったんだけど、何かウチとアドレスちなう…w
オレが調べた島津のあたりとかすごいズレてるな…w
ID:GlBNrwGqのトコだと>>233のやつ動かなくね?
[08]に関してだけど、ひとまず開発pendingってのを尊重してオクレ。
それにこの場面でフラグ操作が必要だ。みたいのは
調べたり聞いたりしないとわかんないよ…w
調べる人はほっといても何とかするだろうし、
聞く人には[08]の入力欄用意すんのも
生タグの書き方教えんのも同じだって…w
ひとまず、現状の機能で何とか出来るコトに関してはKIAIで。
○01のプルダウンが長い=>KIAIで選ぶ。
○フラグ操作=>KIAIで生タグ。
オレのスタンスとしてはこんな感じ。
# ついでに01参照のズレが発覚したぽいので更にやる気ggg(;・∀・)
# まぁ、01.txtの運用で何とかなるかも知れんが何かもういいやw
239:名無しさん@お腹いっぱい。
08/12/16 12:04:01 nBcMkhMv
>>238
>>[08]に関してだけど
そかー。じゃあ皆の胆力に期待だな。
立絵の話だけど、
とりあえずリストの頭探して、鼻歌交じりに入力してたら
蓮の基本が終わったあたりで、その下にまた「誰それ 基本」てのが見えてきて
うぎゃー!となってそこでやめた。
一応どっちのアドレスでも動いてる気がするので、
アドレス順で下に来るやつを「~~ 基本2」とか置いてみてる。
あと、そっちの01.txt見てみたが、ナニコレ2のアドレスは[A2 38 01]じゃないか?
そこらは、こうだ
A2 38 01 00:立絵位置(左)
66 38 01 00:立絵位置(右)
84 38 01 00:立絵位置(中央)
まだ、(右端)(左端)へ立絵を移動させる命令がある。
最大5人まで並べられるかな?
俺もそろそろ何らかの改造をやってみようと思う。
240:名無しさん@お腹いっぱい。
08/12/16 12:31:52 ovXcGXUW
>>237
つまりエロゲキャラ総出演とか可能になるわけか
241:名無しさん@お腹いっぱい。
08/12/16 13:08:10 nBcMkhMv
>>240
そういうことだな具体的に説明すると、
URLリンク(apple.mokuren.ne.jp)
画像の
① = 「face64」及び「meet」フォルダのファイル名
ここではCAなんで「202.tig」を呼んでるんで、例えば「255.tig」を読ませたいならFFにすればいい。
ファイルサイズに注意
② = 声の変更ができる。(主にコマンド実行時の「はっ!」とか言う声)
どのファイルと対応という事ではなく、キャラ毎に数値が決まってる。
大体は顔グラファイルと同じ数字を入れると、そのキャラの声になる。
おまけ
③ = [01]を入れると引抜けなくなる。
④ = [02]を入れると「女に会う」で会えるようになる。
会話イベントなどが無いのでエラーが起きるがな。
⑤ = [01]を入れると重要武将になるのかな?
弊害はちと不明。
1回だけしか実験してないので絶対とはいえないが
がしがしやっちゃってください。
242:名無しさん@お腹いっぱい。
08/12/16 13:44:10 XOyjF3Ot
>>241
(5)の1は「敗北条件にかかるユニーク武将」のチェックかなぁ?
(1)の1は引き抜き謀反なしの重要武将になるんやね。
同じ(1)に2を入れると一揆衆や寺社勢力扱いになってやはり降伏・引き抜きなし
ちなみに武将個人でなく集団と見なされ切腹のメッセージは「鎮まりました」とかになる。
243:242
08/12/16 14:06:51 XOyjF3Ot
>242自己レス
(1)は(3)、(2)は(4)の間違いですたorz..o
244:名無しさん@お腹いっぱい。
08/12/16 17:27:17 ovXcGXUW
>>241
解りやすい解説㌧
休みに弄るのが楽しみになってきた
245:名無しさん@お腹いっぱい。
08/12/16 17:44:27 pMT0foMe
>>239
軽く不貞寝して、なんか納得いかなかったので、
再インストールして調べてみたら、島津勢も>>236のアドレスになってた。
ついでにv1.02のupdater落としてパッチあててみたんだけど、
アドレスの変更はなかったぽい感じ。
んで>>237を見てソフマップ特典て何だろう…?
ってリルフィか…wそういやそんなのもあったかもしれん…w
アドレスがズレてたのリルフィっぽい(;´∀`)
# 同じver1.00使ってるハズなのにmain.sdが違うってオカシイとは思ってたんd
ナニコレの0x138A2のトコみてみたんだけど、0x248(set_x)に
00 1F FF FF FFって感じになってたんで>>189の解析と合致するねぇ。
オレの書き間違いか読み間違いだスマンw
そうそう、iehisa_A基本だけやっぱり違っていて、
AC 6A 01 00 になってるけど
4C 6A 01 00 じゃないかな?
手が空いたら確認してみてオクレ(゚∀゚)
246:名無しさん@お腹いっぱい。
08/12/16 19:08:04 nBcMkhMv
>>245 さんきゅ
その通りでした。
ソフマップ特典はいらんな。
イベントが追加され、イベントCGが間に割り込んでくるのでアドレスがずれてたんだね。
武将としては、Ver1.00ですでに登録されているので顔グラだけいただいておくといいかな。
現在は、このゲームがどこまで改造できるかを実験する準備中。
具体的には、立絵を作ってる最中だ。
なんだったらCGとかを、差し替えではなく、追加できるかどうかやろうと思ったが、
今これを書いている最中にとんでもないことを書いてる気がしてきたので、
挫折する気まんまんだ。
立絵の追加はさすがにしんどそうだけど、背景とかはいけるかもしれないな。
いざという時の[12]で
main.sdがぐちゃぐちゃなんでとりあえず再インストールだな。
今度はきちんとバックアップとってやろう。
247:名無しさん@お腹いっぱい。
08/12/16 20:47:37 nBcMkhMv
いい素材を発見したので速攻で作ってみた。
人間タグパーサーの異名をもらっては限界にチャレンジするしかないと思い。
大名や重要武将を書き換えてみたぞ。
うまくイベント繋げるとちゃんとストーリーいけるかもしれないぞ・。
URLリンク(apple.mokuren.ne.jp)
URLリンク(apple.mokuren.ne.jp)
いい感じに出来てるよ。
ちなみに織田信長と明智光秀を改造したよ~
main.sd等の構造をある程度理解してれば楽勝でここまでこられる。
後、文章を追加する際。
名前の欄に何も入力してないと落ちるので注意!
気がつくまでに数回やらかしてしまった。
248:名無しさん@お腹いっぱい。
08/12/16 21:18:48 wcz2WVDs
何だか凄いことになってきたみたいだw
249:名無しさん@お腹いっぱい。
08/12/16 21:20:29 kVqriRhH
全く別物のゲームとしか思え・・・
250:名無しさん@お腹いっぱい。
08/12/16 21:31:27 W+RlAGUC
ハイレベルだなおい
251:名無しさん@お腹いっぱい。
08/12/16 21:49:49 pMT0foMe
>>247
サスガ人間タグパーサー(゚∀゚)!
>>241みて『へぇ~』と思ってちょっとやってみた。
URLリンク(apple.mokuren.ne.jp)
URLリンク(apple.mokuren.ne.jp)
# ↑この『女に会う』ボタンはどこでいじんの?
ついでにコレ。画像差し替えじゃなくて追加でやってみた。
URLリンク(apple.mokuren.ne.jp)
↓こんな感じで
URLリンク(apple.mokuren.ne.jp)
背景のとこパクって連結無しで追加しておいて、
あとから01とかからアドレス叩いてやればいけるっぽい。
イベントCGのトコをパクったら、絵が出てすぐ終わっちゃったので、
フラグ関連の下準備とかしておかないとイベントCGとかは
動かないのかもシレン(; ・`д・´)
あと『女に会う』とシーンがどう繋がってるのかわかれば、
ソコに飛ばすようにすれば会えるようになるね(゚∀゚)!
252:名無しさん@お腹いっぱい。
08/12/16 21:51:53 pMT0foMe
ああごめん。最後の画像ちょい間違った。
[30]タグの行無しで(;´∀`)
253:名無しさん@お腹いっぱい。
08/12/16 22:19:03 nBcMkhMv
>>251 CG追加
鍋食ってる間に結構やらかしてますな。
そうだった[12]だったら元に戻ってこれないんだった・・・
「女に会う」なんだが
会うのボタン押すとどこに飛ぶとかそんなことはわからないけど、
既存のキャラで会える人なら乗っ取れる。
busyo21n16new.binで汎用キャラの名前書き換えた後、
main.lb内の誰か会える武将を、この新キャラの名前に置き換えてしまうのだ。
で、安全のため乗っ取ったキャラは武将ファイルの「会える」の02(もしくは01)を00にしとけば大丈夫だと思う。
俺は念のためすべての名前を書き換えたよ。
織田信長を孫策伯符と置き換えたら大名家も勝手に孫策家になった。
つらいのが名前の長さだな、アドレス変わるとおしまい・・・
どうやらキャラの呼び出し等は名前の文字列でやってるようなんだ。
しかもそのリストはおそらく存在チェックのあたりでやってると思うので、
追加したらアドレスが狂ってしまうし、なにより会った回数等を記録するフラグエリアに空きがない。
後は乗っ取ったキャラの会話シーンのアドレスをインターセプトする。
同じ名前の武将複数いたら、「会う」と信長が出てきたりする。
254:名無しさん@お腹いっぱい。
08/12/16 22:36:03 nBcMkhMv
纏めてみます。
ちなみに俺がやったのはこんな感じ。
busyo21n16new.bin 織田信長 を 孫策伯符 に
↓
main.sd 念のためすべての織田信長 を 孫策伯符 に
実はこれだけ・・・
もし汎用武将で会える武将を乗っ取るならこんな感じ。
busyo21n16new.bin 汎用武将 -> 呂蒙子明(「会う」の場所の[00]を[02]に)
↓
busyo21n16new.bin 明智光秀の「会う」の[02] -> [01]
↓
main.sd 念のためすべての明智光秀 -> 呂蒙子明
これでいけるかと
もし汎用キャラで「会える」キャラをのっとる場合は、大名は乗っ取らないように。
リストに無いキャラが大名になるため、存在チェックでGAMEOVERになるかと。
重要武将の場合は重要武将リストにある名前が部下にいたらOKだと思う。
255:名無しさん@お腹いっぱい。
08/12/16 22:37:00 nBcMkhMv
>>busyo21n16new.bin 明智光秀の「会う」の[02] -> [01]
じゃなく
busyo21n16new.bin 明智光秀の「会う」の[02] -> [00]
だ
256:名無しさん@お腹いっぱい。
08/12/16 23:09:07 nBcMkhMv
>>251
>># ↑この『女に会う』ボタンはどこでいじんの?
読み違えていた。
このボタンの顔グラは「face64」のがそのまま来るよ。
表示されていない細かい理由は不明だけど、
おそらく上にあるようにキャラリスト外だからかな?
よく考えるとこのキャラ存在リストには「杉田玄白」やらがいないな
ということはここはあくまで重要キャラリストで、
イベント関係は、シーンの会話が乱立する合間にあるリストから呼び出してるのかな?
ということはおそらくこれだね。
main.sd [0x000AE0A7](Ver.1.00)
257:名無しさん@お腹いっぱい。
08/12/16 23:10:25 pMT0foMe
>>254
あーやっとワカタw>>253でmain.lbの名前を書き換えろって書いてあったから(;´∀`)
main.sdの文字列を全部置換しちゃうってコトか。
新人キャバ嬢いれるのはナカナカ大変そうじゃのぅ。
258:名無しさん@お腹いっぱい。
08/12/16 23:13:58 nBcMkhMv
>>257
すまねぇ。なんとな~く間違えてしまった。
長い名前と置き換えるのは厄介だね。
259:名無しさん@お腹いっぱい。
08/12/17 00:01:41 pMT0foMe
>>256
ナイスアドバイス(゚∀゚)!なんかできたw
0xAE761あたりからのリスト
↓こんな感じになってて、
0xAEB8E
66 49 70 00
=> 04 06 08 91 BA 8F E3 82 B3 82 F1 00 (村上さん)
=> 03 12 00 00 00
=> 01 01 00 00 00
=> 02 02 00 00 00
=> 02 49 70 00 A3 00 00 00
0xA3->meet_murakami-san
この名前書き換えてmeet_murakami-sanを
>>251の3枚目の画像のシーンにリンクしたら
『女に会う』でこのシーン発生した(゚∀゚)!
フラグ関連ノータッチなんで毎回同じシーンだけど…w
260:名無しさん@お腹いっぱい。
08/12/17 00:11:34 qcvPdreE
たぶんmain.lbnにシーン名1つ新しいの作って、
対応するindexでmain.lbに繋げたいシーンのアドレスいれとけば、
>>259のリスト書き換えれば、リンク処理しなくてもいけちゃいそうだねぇ。
main.lb経由でこのリスト作ってるトコ見つければ(仮に処理AのアドレスAとしよう)
[処理B] アドレスB
[66]タグとかで新キャラ名とmain.lbnの新エントリを連結
[12]?とかでアドレスAに飛ばす。
こんな感じのを新規領域に作っといて、
main.lb->アドレスB->処理Bが走る->アドレスAに飛ぶ->処理Aが走る
ってコトが出来ると既存のキャラ潰さなくても
新人キャバ嬢が追加できそうな予感(゚∀゚)!
261:名無しさん@お腹いっぱい。
08/12/17 00:28:18 6Avnn48H
>>247
噴いた
262:名無しさん@お腹いっぱい。
08/12/17 00:31:33 ZAfSRkU7
表紙は意外とまともだったと思う
10年前はそれぐらいしか判断材料がなかったので色々と騙されたぜ
263:名無しさん@お腹いっぱい。
08/12/17 00:33:47 JPxf47GB
>>259
やはりそうか。
しかし村上さんは一箇所しかなく会話イベントは複数回ある。
つまりだここはあくまでキャラチェックの場。
シーンを発生させるためのフラグチェックはここではなく
なにやら[0x00238C3A]以降から匂ってくる。
例えばこれ、ちょっとバイト数には自信が無いが
[0x00238C6F]
66 EF 11 00 01 20 00 00 00 :murakami-san_feeling 会った回数フラグの位置
03 12 00 00 00 00 01 00 00 00 :会った回数。すでに2回目会っている(0回[FF*4]、1回[00]、2回[01])
02 02 00 00 00 :真なら
02 EF 11 00 96 01 00 00 :meet_romtyan_03_end へ飛べ
余裕でフラグ調整可能だな。
追加シーンでフラグの調整してこことうまく繋げるとなんでも出来そうだ。
>>260 スゲーアイデアだ。
追加シーンの前に上の[0x00238C6F]こんな感じのフラグチェックリストを作ると。
まずここに飛ばしてから、会った回数に応じた各追加シーンへ移動とかもできるね。
ただリスト作るならまたすこし解析が必要だ。
264:名無しさん@お腹いっぱい。
08/12/17 00:38:08 JPxf47GB
あかん、集中力が無いのかミスバッカだ。
02 EF 11 00 96 01 00 00 :meet_murakamisan_00
会った回数とかのチェックは少し違うかもしれないけど。
だいたいここでやってるぽい。
265:名無しさん@お腹いっぱい。
08/12/17 00:41:25 qcvPdreE
>>263
おおナルホドそんな秘密g(; ・`д・´)
あと立ち絵群のハンドリングを解明してしまえば
『女に会う』が可能な完全な新キャラが作れてしまいそうだな(; ・`д・´)
266:名無しさん@お腹いっぱい。
08/12/17 00:46:09 JPxf47GB
さらに発見。
村上さんフラグチェックのリストの頭にあるとこ
分解すればこうじゃないかな?
[0x00238C3A]
[01] EF 05 00 79 03 00 00 : とりあえず画像表示(室内)
[09] EF 08 00 20 00 00 00 : 会った回数のフラグの位置に
[00] 01 00 00 00 : 数値を+1して入力せよ
毎回ここに飛ばすのは会った回数を記録するためかな。
[09]は数字の[+]という意味かな。
会うシーンのとき画像を表示させなくても室内のなるのはこれが原因か。
267:名無しさん@お腹いっぱい。
08/12/17 00:57:44 JPxf47GB
もし↑がmain.sdの追加エリアでいけるなら
フラグファイル(main.swとmain.swn)も後ろにmeetエリア増やして、
[09]~の後ろのアドレスを追加エリアにすると、
新キャラでも会った回数に応じたシーンを発生させられるんじゃないかな?
やべぇ。本気でなんでも出来そうだ。
268:名無しさん@お腹いっぱい。
08/12/17 01:11:08 JPxf47GB
>>260
こういう手はどうかな?
main.sd [0xAE761]からだけど、
[0E]タグをはさんでないところを見ると
会った武将を上から順番に検索して見つけたら[02]で飛ぶ、となっているぽいので
キャラリストの最後の「檜前蓮」のとこをつぶして[12]なりで追加エリアに飛ばす。
(つぶしたことで出来る隙間を00で埋められないなら少し考えないといけない)
追加エリアの一番最初につぶした「檜前蓮」のをコピペなりしといて、その後ろに新キャラのリストを追加。
また、その後ろに新キャラのフラグチェックを入れ、シーンを追加する。
269:名無しさん@お腹いっぱい。
08/12/17 01:13:36 qcvPdreE
たぶん>>266はあってると思う
>>259でシーンが発生する前に
一瞬だけ自室の絵が出たので間違いなさそうだ。
なんかアレだな。main.sd読んでるだけじゃなくて、
実際に何か作ってみると副作用的に解析進むな(゚∀゚)
270:名無しさん@お腹いっぱい。
08/12/17 01:16:28 qcvPdreE
あー>>268も結構スマートな方法かも知れんね(゚∀゚)
潰したトコを飛ばした先に書いとけばいいし、
[12]で飛んじゃえば潰したトコのゴミが残ってても
関係なさそうだしね(゚∀゚)
271:名無しさん@お腹いっぱい。
08/12/17 01:37:50 JPxf47GB
>>269 結構無茶なこと考えてるとなおさらね。
立絵なんだけど、もしかして背景として追加できないかな?
と思ってやってみたが、背景の重ねがけは出来なかった。
もう寝るか・・・
272:名無しさん@お腹いっぱい。
08/12/17 02:13:40 qcvPdreE
たぶんだけど、立ち絵はchar/以下のchファイルに関連が定義されていて、
もしもchar/以下にある拡張子chのファイルを全て読み込む
というような設計になっていれば、画像用意してchファイル作って
[01]で立ち絵呼び出すようなトコを追加してやれば出来る(ような気がする)
# こう書くと単純そうだが、いざやるとなったら結構ダルそうだ…w
273:名無しさん@お腹いっぱい。
08/12/17 08:16:57 JPxf47GB
立絵はフラグも絡むからね。(~_vanishとか~_x、~.set)とか
chファイルと立絵ファイル追加して、main.sdに立絵処理と追加する場合、
上のフラグも用意するか、誰かの立絵位置などのフラグを借りるかしないとね。
借りた場合は同じシーン内で、そのキャラと同時に表示できなくなる弊害が出てくるが。
基本的にはフラグを借りるわけだが、なんとかコピペでいける方法を考えてみた。
.chファイルだけど下のほうに空間が開いてて立絵の単純追加はできるから
開いてる空間に呼び出し符号(基本とかの代わりに「改造」とか)を記入し、参照ファイル名(新キャラの立絵)を入れる。
chを借りてるキャラの表情命令をコピーして追加エリアに書き込んだ後、
「基本」とか書いてるとこを「改造」に書き換えたら、とりあえずはいけるんじゃないかな?
途中、作業順を飛ばすための[12]命令が入ってるので、そこは直さないといけないだろうが・・・
274:名無しさん@お腹いっぱい。
08/12/17 09:44:58 JPxf47GB
上記の方法で立絵の追加でけた。
■URLリンク(apple.mokuren.ne.jp)
追加立絵を「nobunagaA20.tig」にリネームし
nobunaga_A.chのした方の空欄をこう変更。
多分ファイル名は何でもよい。
■URLリンク(apple.mokuren.ne.jp)
main.sd の最後に[03]~[0E]のコレを追加。
「表情」の部分と、
途中の[12]のとこの移動アドレスを変更。
ツールの01.txtの最後に↓を追加。
12 d1 32 00:実験(関羽)
14 E4 03 00:実験(関羽)消去(nobunaga_A 消去)
■URLリンク(apple.mokuren.ne.jp)
こうなる。
275:名無しさん@お腹いっぱい。
08/12/17 14:18:51 JPxf47GB
汎用武将を犠牲にしたが、会える新キャラの追加ができた。
立絵は上の方法でやっている。
■URLリンク(apple.mokuren.ne.jp)
「main.lb」にアドレスindexを追加、「main.lbn」の最後にシーン名追加
■URLリンク(apple.mokuren.ne.jp)
「busyo21n16new.bin」の信長の上にいる津田君をリネームして、会えるようにして、顔グラの指定を直す。
キャラと会うリストの「檜前蓮」をつぶして[12]で最後に飛ばす。
■URLリンク(apple.mokuren.ne.jp)
「main.sd」の最後に檜前蓮のキャラチェックをここに移動、続いて新キャラのチェック追加。
新キャラのチェックの最後で、念のため信長のフラグチェックアドレスの先頭に[12]で繋いでおく。
[02]で「main.lb」の追加したアドレスindexに飛ばす。
その下にシーン追加。今回は「会う」で自動発生するだけで、会う回数に応じたシーンは作ってない。
■URLリンク(apple.mokuren.ne.jp)
「会う」の選択画面。
■URLリンク(apple.mokuren.ne.jp)
会ってみた。
どだ!簡単だ。
276:名無しさん@お腹いっぱい。
08/12/17 15:20:47 qcvPdreE
>>273-275 やりやがった(゚∀゚)
そういや描画用の変数も個別になってるんだったね
その分追加するか、間借りするしか無いワケか。
しかしまぁよくやったよ…wオツカレ(゚∀゚)!
# なにげにオレもセイバーつくるとき津田君潰したんでちょっとウケたw
277:名無しさん@お腹いっぱい。
08/12/17 15:40:08 qcvPdreE
どうでもいいけど>>251でアイコン出てなかった理由ワカタ(゚∀゚)
元のPNG画像にalpha-planeが無かったからだ。
278:名無しさん@お腹いっぱい。
08/12/17 17:14:34 iBvsgAMB
むはー、雲長さんやセイバーたんがぞろぞろ出てくるスーパー戦極姫対戦への道か
279:名無しさん@お腹いっぱい。
08/12/17 18:07:15 JPxf47GB
>>276
疲れるから、どんどん増やそうという気は無いので、
基本的には既存のキャラを潰して遊ぼうと思ってる。
>>278
おうよ。
ここまで弄れる人はさすがに限られてくるだろうが、
神ツール2種+バイナリエディタのみで、簡単にキャラの乗っ取りは可能だ。
いろいろ弄って楽しんでくれ。
280:名無しさん@お腹いっぱい。
08/12/17 18:29:13 qcvPdreE
>>279 とりあえずKIAIだな(゚∀゚)
んで>>247の最後は何かちょっとマズイだろ~(; ・`д・´)
と思って暫定対策いれてみた。(名前空欄なら全角スペースに置き換えるだけ
■sgh_editor 実験版 ver0.03a exeのみ要DLLとか DLKey:sghmod
URLリンク(apple.mokuren.ne.jp)
ついでに自分用にさっきチョチョイと作ったツール
■bindata_append exeのみ要DLL DLKey:sghmod
URLリンク(apple.mokuren.ne.jp)
Openしたファイルにinputのデータをdata typeの形式で
alignmentバイト数、空欄をblankで埋めて追加する。
intの場合はLEもBEも4byte固定。
data typeをFileにして左のリストからファイルを選んで
[Write]するとファイルの中身をドドンと結合する。
※別のファイルを開くか終了するまでファイルハンドルを放さないので注意
イロイロと複雑なコトやりだしたので、
ある程度マニアな処理を固めたbin_source.datを複数とっておいて、
main.sdにペチペチ単純結合できたほうがイイかな~と(゚∀゚)
281:名無しさん@お腹いっぱい。
08/12/17 19:22:59 JPxf47GB
>>280
対応さんきゅです。これでうっかりミスも減るはず。
こっちはこっちで、chファイルを間借りしてる立絵を、宿主と同時に表示できないものかと実験してた。
結論からいうとできた。
■URLリンク(apple.mokuren.ne.jp)
「main.swn」にこれらを追加。
これはただのindexで実際は何もしなくてもいいが、indexが無いと管理しにくいので書いた。
「main.sw」には十分な領域がすでにあったので「main.sw」には何も追加してない。
「main.sd」では、
前追加した立絵呼び出しの一連の命令のうち
マークしてる部分を書き換え。
■URLリンク(apple.mokuren.ne.jp)
孫策と関羽は同じchリストにあるけど問題なく並べられた。
ちなみにフラグのとこを変更してないと、片方しか表示できない。
282:名無しさん@お腹いっぱい。
08/12/17 20:19:32 qcvPdreE
>>281
おお凄いな(゚∀゚)
オレもちょっと同じコトは考えていて(考えてただけ)
main.swnとmain.swの末尾に新規フラグ領域を確保して、
それからmain.sdを①画像下段っぽくやったら上手く行くかな、と思ってた。
とりあえずIfGotoOnce系のフラグが未使用なら
極端な話、ドコ使ってるかさえ把握しとけば
main.swnの書き換えすら不要ってコトだねー。
# まぁ名前ちゃんと変えた方が分かり易いケド(゚∀゚)
ココまで出来たら、あとchファイルを読み込む部分が
charディレクトリ以下のchを全て読み込む設計になってれば
chファイルも分離して、かなりイイ感じで新キャラ追加ができそだね(゚∀゚)
283:名無しさん@お腹いっぱい。
08/12/17 20:58:18 JPxf47GB
chファイルのことだけど。簡単にいけたよ
こんな感じ、
nobunaga_A.ch を nobonaga_A.ch 等とファイル名少し変えて
nobonaga_A.ch の中身の表情とファイル名を適当なのに変えて
それにあわせて立絵ファイルをリネームする。
後は、
main.sd の立絵呼び出しのとこの nobunaga_A と 表情 を変更後のに書き換えるだけ。
284:名無しさん@お腹いっぱい。
08/12/17 23:13:00 JPxf47GB
>>282
IfGotoOnceのとこだけどなんか使ってるぽい。
ランダム発生型のイベントでかな?
檜前蓮のとこ調べてると、そこを参照してるようなんだ。
ちなみにここでは[IfGotoOnce0052]使ってた。
逆に言うとランダムでシーンを発生させたい場合、このあたりが使えるのかもしれない。
285:名無しさん@お腹いっぱい。
08/12/17 23:15:37 3oOn+CN5
>7
ちょう遅レスだが、1行目6500は現在居る城の番号 siro21.binの順番そのまま
ゲーム中で後のFFFFに書き込まれるのは攻め込む(予定の)城かね
286:名無しさん@お腹いっぱい。
08/12/17 23:54:20 qcvPdreE
おおスマン致命的なバグを1つ見つけた(; ・`д・´)
ループ抜け判定が甘くてバイナリ吐く時に最後にゴミをくっつけてた。
■sgh_editor 実験版 ver0.03b exeのみ要DLLとか DLKey:sghmod
URLリンク(apple.mokuren.ne.jp)
>>283-284
今ためしにchファイルを新規で作って追加してみようとやってたんだけど、
↑のバグ潰ししてた…w
でもchがとりあえず読み込まれる設計になってるぽいのが分かってヨカタ(゚∀゚)
# フラグは追加のがイイのかなぁ?main.swの書式全然知らんけど…。
287:名無しさん@お腹いっぱい。
08/12/18 00:06:43 E9/qx4NO
■sgh_editor 実験版 ver0.03c exeのみ要DLLとか DLKey:sghmod
URLリンク(apple.mokuren.ne.jp)
タグのカウンター自動生成部分ちょい間違ってた(; ・`д・´)
288:名無しさん@お腹いっぱい。
08/12/18 00:39:20 DtAQpDOv
>>287
修正乙。
復習のためにスレ読み直してた。なかなか面白いな。
main.sw だけど、フラグはそれなりに難しい。入力される数値がややこしいからな。
フラグはすべて4バイト単位。main.swnと対応してる。
弄るのは主に2種類。
main.swnのindex名でいくと、
「キャラ名_feeling」 : 会った回数の記録。main.swのFFFFFFFFのとこに書き込まれる。
「キャラ名_end」 : 会話シーンとかとにかくシーンが発生済かどうかのフラグ[01]で発生済
大体の人は新規武将を作らないと思うので、「キャラ名_feeling」はキャラ毎のフラグリスト通せば自動的に増えるが、
「キャラ名_end」 だけはシーンの最後に追加する[08]で入力されてるので、これは自力入力しなければいけない。
中間にある「キャラ名_view」と、「kikugoro_A」から下は、画像関係とかの特殊なフラグなんで弄らないほうがよいとおもう。
何回か書いたがおさらいだ、書き込みの書式は
[08 ?? ?? ?? xx xx xx xx 00 01 00 00 00]
???? = カウンター
xxxx = 書き込み先指定(0x4倍するとmain.swのアドレスになる)
01の前の[00] = 書き込めという命令
[01 00 00 00] = 書き込まれる数値
未発生にするには 00 を書き込む。
出来たら非常に便利だと思うのは、
リスト選択すると[xx xx xx xx]の部分が自動的に入り、
[01 00 00 00]のとこの数値は自分で決められる、というのがベターだが、
とりあえずはリスト選択すると自動的に01がはいればいいかと。
289:名無しさん@お腹いっぱい。
08/12/18 00:56:45 DtAQpDOv
会った回数を増やす[09]タグも式は[08]と一緒だ。全部で13バイト
「キャラ名_feeling」でしか使わないが・・・
290:名無しさん@お腹いっぱい。
08/12/18 01:08:10 DtAQpDOv
またしても早合点。
>># フラグは追加のがイイのかなぁ?main.swの書式全然知らんけど…。
フラグエリアを追加してそこで画像の作業することだね?
絶対に同じシーンで並べて表示しない宿主さがしてそこを借りるのもいいとおもうが
フラグエリアは結構広いので武将数が多くならないなら新規に追加でもいいかもね。
main.swnにはやはりフラグ名を追加したほうが作業しやすいな
main.sdにはフラグを参照するタグがいっぱいあってややこしい。
[08][09]だけでなく[6x]あたりは全部そうじゃないかな?と思えてくる。
よって既存のキャラのをコピーして、アドレス部分だけ直すと確実だな。
291:名無しさん@お腹いっぱい。
08/12/18 01:15:48 E9/qx4NO
やっと新規chと新規立ち絵で絵がデター(;´Д`)
ものっスゲーメンドクサイなコレ。立ち絵一つ追加するにも↓
03 07 45 00
=> 01 49 02 00 00 (set_vanish)
=> 03 17 00 00 00
=> 00 FF FF FF FF
=> 02 02 00 00 00
=> 12 07 45 00 0D 47 01 00 (5つ下の[4B]直)
08 07 46 00 21 03 00 00 01 49 02 00 00 (nobunaga_vanish)
08 07 47 00 D1 02 00 00 01 48 02 00 00 (nobunaga_x)
08 07 49 00 49 02 00 00 00 FF FF FF FF (set_vanish)
08 07 4A 00 48 02 00 00 00 FF FF FF FF (set_x)
4B 07 4E 00
=> 01 EE 01 00 00 (nobunaga_A)
=> 6E 6F 62 75 6E 61 67 61 5F 41 00 (nobunaga_A:ch名)
=> 00 00 00 00 00
=> 8A EE 96 7B 00 (基本)
03 07 51 00
=> 01 81 02 00 00 (nobunaga_view)
=> 03 12 00 00 00 00 00 00 00 00 02 02 00 00 00
=> 12 07 51 00 70 47 01 00 (2つ下の[3F]直)
3D 07 52 00
=> 01 EE 01 00 00 (nobunaga_A)
=> 01 21 03 00 00 (nobunaga_vanish)
=> 00 00 00 00 00
=> 01 D1 02 00 00 (nobunaga_x)
=> 00 00 00 00 00
=> 12 07 53 00 83 47 01 00 (2つ下の[40]直)
3F 07 54 00
=> 01 EE 01 00 00 (nobunaga_A)
=> 01 D1 02 00 00 (nobunaga_x)
=> 00 00 00 00 00
40 07 58 00
=> 00 32 00 00 00
08 07 5C 00 81 02 00 00 00 01 00 00 00 (nobunaga_view)
0E 07 5E 00