summaryrefslogtreecommitdiff
path: root/make_map_model_b.rb
diff options
context:
space:
mode:
authorTreeki <treeki@gmail.com>2011-06-15 04:27:10 +0200
committerTreeki <treeki@gmail.com>2011-06-15 04:27:10 +0200
commite32b8bf8fff4d0507c34221146a1371ad47a3df5 (patch)
treefb425e415864e02ab03cd1b1653022c7c33bc5a0 /make_map_model_b.rb
parenta36737f8a870182a69b67282a4a41ea5e056c8dd (diff)
downloadkamek-e32b8bf8fff4d0507c34221146a1371ad47a3df5.tar.gz
kamek-e32b8bf8fff4d0507c34221146a1371ad47a3df5.zip
cleaned up the path test stuff
Diffstat (limited to '')
-rwxr-xr-xmake_map_model_b.rb89
1 files changed, 0 insertions, 89 deletions
diff --git a/make_map_model_b.rb b/make_map_model_b.rb
deleted file mode 100755
index 388c4ac..0000000
--- a/make_map_model_b.rb
+++ /dev/null
@@ -1,89 +0,0 @@
-#!/usr/bin/mono /home/me/Packages/IronLanguages-main-ba2094c/bin/Release/ir.exe
-## Requires IronRuby
-
-$: << "/home/me/Dev/NW4RTools/NW4RTools/bin/Release"
-require 'NW4RTools'
-require 'System.Drawing'
-
-include System
-include NW4RTools
-include NW4RTools::Models
-
-brres = ResFile.new
-models = brres.create_model_group
-path = '/home/me/Games/Newer/ModelRev'
-reader = System::IO::StreamReader.new("#{path}/fullworld-Z20nvrc.obj")
-
-ObjImporter.ImportModel(path, reader, brres, "WorldBase", ObjImporter::LightmapType.Map)
-
-model = models["WorldBase"]
-
-alpha_tex = Texture.new
-alpha_bitmap = System::Drawing::Bitmap.new("#{path}/images/alphaBlender.png")
-alpha_tex.images = System::Array[System::Drawing::Bitmap].new([alpha_bitmap])
-alpha_tex.format = TextureFormat.RGB5A3
-brres.get_texture_group.add 'alphaBlender', alpha_tex
-
-# yay
-#model.shapes["World2_PathsPlumbing__World2_PathsPlumbing"].clr_data[0].raw_data = System::Array[Byte].new([255, 255, 255, 128])
-
-# move paths into DrawXlu
-opa = model.bytecode["DrawOpa"]
-if model.bytecode.contains_key("DrawXlu")
- xlu = model.bytecode["DrawXlu"]
-else
- xlu = ByteCode.new
- xlu.instructions = System::Collections::Generic::List[ByteCode::Instruction].new
- xlu.instructions << ByteCode::DoneInstruction.new
- model.bytecode["DrawXlu"] = xlu
-end
-
-shape_array = model.shapes.to_a
-
-to_be_moved = opa.instructions.select do |insn|
- insn.is_a?(ByteCode::DrawShapeInstruction) and
- shape_array[insn.shape_i_d].key =~ /path/i
-end
-
-to_be_moved.each do |insn|
- opa.instructions.remove insn
- xlu.instructions.insert 0, insn
-end
-
-# how's this for hackiness?
-model.materials.each do |kvp|
- next unless kvp.key =~ /path/i
-
- mat = kvp.value
-
- pix = DisplayListWriter.new
- pix.load_b_p_reg 0xF33F0000
- pix.load_b_p_reg 0x40000017
- pix.load_b_p_reg 0xFE00FFE3
-
- # Blend Mode: logicmode: LO_SET, subtract: 0, srcfactor: SRCALPHA, dstfactor: INVSRCALPHA,
- # alphaupdate: 0, colorupdate: 0, dither: 0, logicopenable: 0, blendenable: 1
- pix.load_b_p_reg 0x4100F4A1
-
- pix.load_b_p_reg 0x42000000
- pix.end
- mat.pix_d_l = pix.get_buffer
-
- tc = DisplayListWriter.new
- [0xE2,0xE3,0xE4,0xE5,0xE6,0xE7].each_slice(2) do |first, second|
- tc.load_b_p_reg first << 24
- 3.times { tc.load_b_p_reg second << 24 }
- end
- tc.add_padding 4
- (0xE0..0xE5).each {|bit| tc.load_b_p_reg (bit << 24) | 0x800000}
- tc.load_b_p_reg 0xE688F000
- tc.load_b_p_reg 0xE7800000
- tc.pad_to_size 0x80
- tc.end
- mat.tev_color_d_l = tc.get_buffer
-
-end
-
-final_data = BrresWriter.write_file(brres)
-System::IO::File.write_all_bytes("#{path}/MMFullWorld_mod.brres", final_data)
-