User talk:Neo

From OniGalore
Revision as of 08:44, 11 September 2009 by Neo (talk | contribs)
Jump to navigation Jump to search

New OniSplit version: OniSplit v0.9.41

What's new:

  • fixed the Collada importer to work with 3DSMax exported files

New OniSplit version: OniSplit v0.9.40

What's new:

  • support for exporting/importing sound animations to/from xml files
  • better Collada export for environment
  • support for full color transparent textures (-format:bgra32 on the command line, ARGB8888 format in an xml file)
  • different (hopefully better) xml export format for animations (this one is actually from 0.9.38 but since that wasn't mentioned here...)
  • a more or less complete animation importer. This one deservers some notes:
-unlike other importers that produce .oni files this one produces and .xml file (similar to the one you get when exporting a TRAM)
when you do
 onisplit -create:tram target_dir animation.dae
in the target dir you'll get a TRAManimation.xml file.
You need to add some stuff to that file to make it actually work as an animation. In particular the animation type, from/to states and varient needs to be set.
-For all I know this works with animations exported from Oni and modified in Softimage. If you come up with a completly new animation it should work as long as the skeleton is similar to the one used in Oni.
-Note that the geometry that is present inside the Collada file is used to compute the "vertical extents" so it better be the same or close to the one the animation is intended for.
-The biggest problem are the attacks. While it's not difficult to add attacks to the xml file, computing the necessary "extents" is not going to be easy. I guess in the end I'll have to add some command to OniSplit to do it.
-Everything else that I forgot :)

Neo

New OniSplit version: OniSplit v0.9.37

What's new:

  • support for transparency in the environment importer


New OniSplit version: OniSplit v0.9.35

What's new:

  • conversion of recorded films (.dat binary files) to xml files that can be used to create FILM .oni files
   OniSplit film2xml out_dir film.dat


New OniSplit version: OniSplit v0.9.34

What's new:

  • SNDD importer
-WAV files (.wav, mono/stereo, 22.05KHz/44.1KHz, uncompressed(PCM)/compressed(MS-ADPCM)) produce SNDD files that are compatible with Oni PC retail.
-AIFC files (.aif/.aifc/.afc, mono/stereo 22.05KHz, compressed(ima4)) produce SNDD files that are compatible with Oni Mac.
Example


 OniSplit -create out_dir test.aif
 OniSplit -create out_dir test.wav


  • LOD support for creating TRBS files. This can be done by creating an xml file containing the following:
 <?xml version="1.0" encoding="utf-8"?>
 <Oni Version="0.9.29.0">
     <Instance id="0" type="TRBS">
         <Elements>
             <Link>barabus_body_1.dae</Link>
             <Link>barabus_body_2.dae</Link>
             <Link>barabus_body_3.dae</Link>
             <Link>barabus_body_4.dae</Link>
             <Link>barabus_body_5.dae</Link>
         </Elements>
     </Instance>
 </Oni>
and running the command (assuming the created xml file's name is barabus_body.xml):
 OniSplit -create out_dir barabus_body.xml
It's not strictly necessary to create 5 different geometries for each LOD. The following works just as well:
 <?xml version="1.0" encoding="utf-8"?>
 <Oni Version="0.9.29.0">
     <Instance id="0" type="TRBS">
         <Elements>
             <Link>barabus_body_1.dae</Link>
             <Link>barabus_body_2.dae</Link>
             <Link>barabus_body_2.dae</Link>
             <Link>barabus_body_2.dae</Link>
             <Link>barabus_body_3.dae</Link>
         </Elements>
     </Instance>
 </Oni>


  • An xml file can contain "links" to other xml/obj/dae files. For example you can have the following line in an ONWC xml file:
 <Geometry>pistol.obj</Geometry>
Assuming the file pistol.obj exists in the same directory an M3GM .oni file will be automatically created from it.
Relative paths work just as well:
 <Geometry>geometry/pistol.obj</Geometry>


  • The -create:subt, -create:txmp and -create:m3gm are sort of obsolete. They still work but now you can simply use '-create' (or just 'create'):
 OniSplit -create out_dir crate.dae
 OniSplit create out_dir -format:bgr555 -genmipmaps pic.tga
 OniSplit create out_dir subtitles.txt


  • Work in progress: the AKEV importer now reads Collada materials so the resulting AKEV is textured.
Sample levels:
TestLevel1 -- This level should look like this in-game: Image 1 Image 2 Image 3
TestLevel2 -- This level should look like this in-game: Image 1
A zip file contains the minimum needed to get a new level running in Oni. To "compile" a level extract it to a folder and run the following commands:
 OniSplit -create out -genmipmaps -format:dxt1 *.xml
 OniSplit -import:nosep . Oni\GameDataFolder\level1_Final.dat
(Of course, you need to change the output .dat file path to match your Oni installation path)
Note1: The hexagon level needs to be scaled up to work properly. Use the envscale option for this:
 OniSplit -create out -genmipmaps -format:dxt1 -envscale:40 *.xml
Note2: I've updated the level files to contain 20 empty corpses to prevent crashes.

Neo


I tried to extract the .dae from AKEVhexagon2.oni and got the following error message from OniSplit:

mono onisplit.exe -extract:dae hex3d level7_Final/AKEVhexagon2.oni

 /level7_Final/AKEVhexagon2.oni
 /level7_Final/AGDBhexagon2.oni
 System.NullReferenceException: Object reference not set to an instance of an object
 at Oni.Imaging.Texture.Read (Oni.InstanceDescriptor txmp) [0x00000] 
 at Oni.Geometry.GeometryDaeExporter.WriteImageLibrary (Oni.InstanceDescriptor[] textures) [0x00000] 
 at Oni.Geometry.GeometryDaeExporter.WriteEnvironment (Oni.InstanceDescriptor descriptor, System.String filePath) [0x00000] 
 at Oni.Geometry.GeometryDaeExporter.ExportInstance (Oni.InstanceDescriptor descriptor) [0x00000] 
 at Oni.Exporter.ExportInstanceList (System.Collections.Generic.List`1 descriptors) [0x00000] 
 at Oni.Exporter.Export (Oni.FileManager fileManager, System.String sourceFilePath, System.String filter) [0x00000] 
 at Oni.Program.ExtractGeometry (System.String[] args) [0x00000] 
 at Oni.Program.Main (System.String[] args) [0x00000]

EdT 03:42, 12 November 2008 (CET)

This happens when you don't have all the textures that are used by AKEV in the same folder. In this case the missing texture is TXMP<none> aka TXMP%3Cnone%3E.oni. You can copy it to that folder but there is another problem caused by it's funky name.

If you really want to do that you need to "create" hexagon using a different default texture:

 onisplit create out *.xml -format:dxt1 -envscale:40 -texdefault:notfoundtex

Now you can copy TXMPnotfoundtex.oni to the folder that contains the AKEV file and export should work.

PS: maybe I should make notfoundtex the default texture. That way I avoid using that troublesome <none> and it's more obvious which quads have missing textures.

Neo


DELETED, don't bother with that interpolation stuff (I apologize if you did). I found this bug useful in the end. It can be used for making more final resting poses than standard two, bringing more varienty into a game. But request about blue shield remains.

2)

Subject - Blue shield
Blue shield absorbs both damage and knockback. Is there a way how to make it absorb only damage, so character would be affected by knockback even tough he has blue shield?
I ask because then I could simulate throwing over obstacles with throws via PAR3. Now I cannot due to blue shield's knockback absorbtion.
Or is there any "cleaner" solution of throwing over obstacles (such as dynamic root height)?

Thank you for patience, --Loser 07:45, 30 November 2008 (CET)

I'll say what I can on the matter, if you don't mind. :)
@Blue Shield: Regardless of the ability to remove damage by knockback, you run into several problems:
  • Explosions would still knock you back
  • Explosions _might_ still do damage to you (I'd have to look at the asm, but from what I recall about PAR3, knockback is a type of damage. I never quite got how it worked specifically though, does it do actual damage?)
A better solution would be to somehow apply velocity to TRAMs. With velocity and the right flag (can't recall which...), the sphere tree would unstick.
Another thing: When a character goes over an edge, unsticking depends on either a time spent in the air or size of sphere (distance from ground), I can't tell which. I would hazard a guess that it has to do with time, but I'm not sure. :) If we can decrease whatever value it is, we could get what you are looking for. There is a chance it is a value in the ONCC or a constant in the engine. I'm not sure which. Gumby 10:04, 30 November 2008 (CET)
@TRAMs when characters die, they lose all ability to be animated at all. I know there exists a fix for characters losing MELE information on death (I lost it, gotta ask geyser next time he is on...), but there might also be a way to disable the disabling of animation on death. I know if you set a characters health to 0, attempt to animate it (fail), then set its health to something positive, the first thing he\she does is that animation you asked it to. So all hope is not lost. :) Then again, it might be a good thing you can't be animated after death. That could lead to some crazy bugs. :D Gumby 09:38, 30 November 2008 (CET)

OK, the new music files imports and exports without error. Now how to get it in the game? I duplicated OSBDmus_amasian.grp renamed it OSBDmus_burn.grp used a hex editor and changed the links to the new music file names (I kept the file name the same size) Placed all the files in level0_Final and rebuilt the level and used the command: sound_music_start mus_burn but no music... here are the files http://edt.oni2.net/OniSplit/mus_burn.zip What am I doing wrong? EdT 20:57, 10 December 2008 (CET)

The OSBD files appear to be correct but to be on the safe side you should simply replace exiting sounds (SNDD) to see if the sound really imported correctly.

Neo

Replacing an existing SNDD with a new one works. I next tried duplicating an existing OSBD file such as OSBDmus_xtr1.grp.oni and renamed it OSBDmus_xtr3.grp.oni, rebuilt level0_Final, but when I use the command sound_music_start mus_xtr3 there is no music. Very odd... EdT 01:15, 11 December 2008 (CET)

I think that the sound_music_start command plays an ambient sound, not a group. In general nothing plays groups, only ambients and impulses so you need to create one of those too.

Neo

Looks like group files are used by ambient files. Example on "fight" track.

SNDDmus_fitec1.aif.oni
SNDDmus_fitec2.aif.oni
SNDDmus_fitec3.aif.oni
SNDDmus_fitec4.aif.oni
SNDDmus_fitec5.aif.oni
SNDDmus_fitec_out.aif.oni
- (no links)

OSBDmus_fitec.amb.oni (for level 4 ?)
- mus_fitec
- mus_fitec_in
- mus_fitec_out

OSBDmus_fitec_hd.amb.oni (for level 12 ? looks redundant)
- mus_fitec
- mus_fitec_in
- mus_fitec_out

OSBDmus_fitec_in.grp.oni
- mus_fitec1.aif

OSBDmus_fitec.grp.oni (should be the loop)
- mus_fitec1.aif
- mus_fitec2.aif
- mus_fitec3.aif
- mus_fitec4.aif
- mus_fitec5.aif

OSBDmus_fitec_out.grp.oni
- mus_fitec_out.aif

Here is the updated mus_burn pack. I guess that track wasn't supposed to become looped so it sounds choppy when starting over. Btw, where did the track come from? Paradox-01 19:04, 8 March 2009 (UTC)



How hard is it to add a new screen to Oni? "Screen" as in Main Menu, Load Game, Options, etc. I know that the game wouldn't know what to do with the screen because it wouldn't have any code written for it, but let's say that part's not important. --iritscen 21:49, 12 December 2008 (CET)

Creating WMDDs using xml is easy enough, export an existing one and modify it as you like. But you're right about the fact that they need new code added to the game.

Neo

I should have mentioned, I wanted an existing screen to lead to a new screen when clicking a newly-added button on the first screen. But, looking at the WMDDs, I don't see where the link is from a button to a screen... is that because they're hard-coded into Oni? :-\ --Iritscen 21:33, 13 December 2008 (CET)

Yes, a button triggers an action that must be written in code.

Neo


Neo, is it possible to make OniSplit say something to the user if they double-click the app, that is, run it without sending it any commands? In other words, right now, the console window just flashes onscreen for a moment if they do that. Could you insert a pause, and display a message about how they need to run it by sending it a command? Maybe it doesn't close the window until they press a key. Just a suggestion. I know that we should probably also be clearer about it in places like OniSplit, but it seems like, if this is doable, it probably would only take a minute to code, and it will save users from having to ask this question every couple weeks on the forum :-) --Iritscen 16:10, 21 December 2008 (CET)

For some reason, that idea inspired me so I wrote some test code. http://rossy.oni2.net/files/ConsoleTest.zip :D When it recieves no arguments, the test program checks if it has been run from a console window, if not it creates its own cmd.exe and runs itself. I don't know what would happen on MacOSX, but i think the Process.Start call will fail and cause the program to display a message box instead.
No thanks, I'd rather not use PInvoke in a .NET program that needs to run on another OS :). For now I changed OniSplit so if it's started without arguments (like it happens if it's double clicked) it displays the help and wait for a key to be pressed. Neo

Neo, I used xml to extract and create TXMP files. However, for a file that has an alpha channel, I get a bug: alphabug.jpg

For this example, I extracted the TXMP for Konoko's head using xml and without any changes imported it back using xml.

Any suggestions? EdT

Somehow the reflection got changed into transparency...I have been wondering how this particular trick is done. :) I guess we will find out soon enough. Gumby 05:06, 26 June 2009 (UTC)
EdT, maybe you could post the generated xml file? :) Gumby 07:11, 26 June 2009 (UTC)
Someone had a very similar problem a while ago. He had Oni Demo which meant that Mukade's reflection texture was missing. It was needed by the Spartan plugin so some pieces became transparent.
EdT, did you import Konoko's texture into a plugin? Some files are loaded before files in the original level, other are loaded after them, it depends on the plugin name. Maybe you can test that out: 1) put the reflective map also into the plugin 2) or change the plugin name. Paradox-01 09:43, 26 June 2009 (UTC)
Paradox, it was an xml issue:

<Oni Version="0.9.37.0">

   <Texture>
       <Flags>HasMipMaps</Flags>
       <Format>ARGB4444</Format>
       <Image>TXMPIteration001%2Fk4_head.tga</Image>
   </Texture>

</Oni>

It was missing the <EnvMap>TXMPenvksface</EnvMap> tag, very strange. EdT
Ok. But the question is still there: was this just once or does this kind of bug occur now always when exporting a transparent image? Paradox-01 16:07, 26 June 2009 (UTC)
Paradox, It seems to be just that file: TXMPIteration001%2Fk4_head.oni others with transparency includes the <EnvMap> tag. EdT

Neo,

Is there a way to manually add comments in the xml that OniSplit creates? Sometimes I would like to add notes to help me remember what I was doing. EdT

<!-- Comments go here -->
Of course, they will be deleted when you convert to .oni. :) Gumby 20:31, 1 July 2009 (UTC)

RGBA8888 texture support - Awesome! When will you release a version of Onisplit with that feature? EdT

One of these days... I've already added support for this but some parts of OniSplit are a bit messed up right now and I need to cleanup before release. Until then see if you can swap red with blue in an image editing tool and use -format:bgra32 to import.

Neo

I'll give it a try. Another issue, to create a large TXMP such as 512x512 I would use the option -large using the command create:TXMP, however, in xml, I cannot use large as a flag. It is not listed in the enums. EdT

You don't need -large when importing from xml, it works without it. But -format:bgra32 is ignored and you cannot put it in xml either. So you need to stick to importing tga files directly until I upload a new OniSplit version. Probably tomorrow. Neo

Update: I'm having color issues with the patch and bgra32 as you can see here:

bgra32.jpg

EdT

That looks nice :). I'm having trouble figuring out the hair remained red through all those color swaps. Maybe you should send me the tga or oni files to take a look.

Neo

Here are the 4 TXMP file and one .oni file, the red&blue swap: http://edt.oni2.net/OniSplit/bgra32.zip EdT

Hrmr... I'm don't know what's going on. Your .oni files works fine for me. See head.

Neo

Here is the texture test. bgra32, no alpha channel, envmap:TXMPenvksface EdT

rgb_bra32.jpg

Baffling. It seems to me that the red one has some envmap reflection which means that the alpha got mixed with red. In the other 2 it's obvious that red got mixed with blue and red got mixed with green. I've no idea how come red gets mixed with everything. Please try bgra32 without envmaps and alpha.

Neo

bgra32, no envmap, no alpha channel EdT

noenvmap_bgra32.jpg


Color Depth test, alpha channel, envmap:TXMPstrikerarmor EdT color_depth_bgra32.jpg


Here is a more comprehensive test of bgra32

These were done using xml and <Format>ARGB8888</Format>

bgra32test.jpg


However, these were done using command line and -format:bgra32

bgra32test2.jpg

bgra32test3.jpg


Command line using -format:bgra32 and envmap TXMPstrikerarmor

Redalpha.jpg


Conclusion: As onesadcookie stated, the red/alpha channels and blue/green channels are switched. Also, with the <Format>ARGB8888</Format> the red/blue channels are switched.

So can this be fixed on the Mac? EdT


A comparison of bgra32 and bgra4444

konokobgra32.jpg

I swapped the red and alpha, blue and green channels to make it look right on the Mac. EdT



Rexxar from OCF reports that OniSplit cannot import files with % in the name.

For example: OniSplit -create:txmp out -format:bgr32 -genmipmaps TXMPIteration001%2Fk4_bcp.tga

Produces the error message:

System.IO.DirectoryNotFoundException: Destination directory not found: Oni/Edition/install/out/TXMPIteration001
 at System.IO.File.Create (System.String path, Int32 bufferSize, FileOptions options, System.Security.AccessControl.FileSecurity fileSecurity) [0x00000] 
 at System.IO.File.Create (System.String path) [0x00000] 
 at Oni.Importer.Write (System.String outputDirPath) [0x00000] 
 at Oni.Imaging.TextureImporter.Import (System.String filePath, System.String outputDirPath) [0x00000] 
 at Oni.Program.CreateGeneric (System.String[] args) [0x00000] 
 at Oni.Program.Main (System.String[] args) [0x00000]

But remove the "%" from the name TXMPIteration0012Fk4_bcp.tga then it creates the .oni file. EdT


A user on OCF reported problems with SNDD files as .wav. I confirmed that when extracting a SNDD as wav, instead of the correct sound, I get static and noise. Extracting the same SDNN file as .aif, produces the correct sound. EdT

Works fine here. Is he perhaps trying to extract a Mac SNDD file as wav? Neo

Well, he is apparently a Windows user, so normally I would say "definitely not", however, he mentions working with an extracted sound called "SNDDc01_04_01receptionist.aif.wav". Does that make sense? Should that ".aif" be there? --Iritscen 14:02, 18 August 2009 (UTC)

Yes, the .aif is there because that's how all the SNDD instances are named, PC or Mac. I tried that file but it extracts fine for me. Neo


Do we definitely understand how Oni chooses between LODs for a given model? I used to think it was distance from the camera, but someone told me it is actually based on how many polys (or models?) are onscreen. --Iritscen 13:37, 23 August 2009 (UTC)

I'm not sure but I think it uses both. Neo
Hmm, okay. One day I guess I'll have to test this out. --Iritscen 17:24, 24 August 2009 (UTC)

So, is LOD a universal setting? Individual characters can't be at different LODs, can they? --Iritscen 01:24, 30 August 2009 (UTC)


If I export the .dat files in this .zip, then try to -import:sep them, I get:

Reading files from /Games/Oni/•Mods/Other/mus_tranc/ONI
Removing duplicates
System.NotSupportedException: File /Games/Oni/•Mods/Other/mus_tranc/ONI/SNDDmus_tranc1.aif.oni cannot be imported due to conflicting template checksums
 at Oni.InstanceFileWriter.AddDescriptor (Oni.InstanceDescriptor descriptor) [0x00000] 
 at Oni.InstanceFileWriter.AddDescriptors (System.Collections.Generic.List`1 descriptors, Boolean removeDuplicates) [0x00000] 
 at Oni.OniImporter.Import (Oni.InstanceFileManager fileManager, System.String[] inputDirPaths, System.String filePath, Int64 targetTemplateChecksum) [0x00000] 
 at Oni.Program.Import (System.String[] args) [0x00000] 
 at Oni.Program.Main (System.String[] args) [0x00000]

--Iritscen 17:24, 24 August 2009 (UTC)

It appears that those SNDDs are for PC. OniSplit doesn't convert between AIF/WAV, sorry. Neo

D'oh, where is my brain? That's a big "duh to my world". I guess I only saw the ".aif" in the exported files. --Iritscen 19:11, 24 August 2009 (UTC)

A little request from your friendly neighborhood sysop: I notice that your talk page is getting big again, so I know you might be thinking of clearing it. But, going forward, could you please archive talk instead of just blanking the page? If you're a Wikipedian you already know what I'm talking about, but if not, it's just a matter of making a new page such as User_talk:Neo/Archive1 and moving the old text there with a link to the archive page left at the top of your talk page. Just giving you this request in advance for when you decide the page is too big. Thanks. --Iritscen 01:22, 30 August 2009 (UTC)


Neo

I get this error message using the command create:tram

 System.NotSupportedException: Invalid rotation axis {X:0 Y:0 Z:-1} for rotate transform in animation pelvis-node-ry
 at Oni.Totoro.AnimationDaeReader.FindRotations () [0x00000] 
 at Oni.Totoro.AnimationDaeReader.Import (System.String filePath, System.String outputDirPath) [0x00000] 
 at Oni.Program.CreateGeneric (System.String[] args) [0x00000] 
 at Oni.Program.Main (System.String[] args) [0x00000]  (1)

The dae files are here: http://www.filefront.com/14507129/dae.rar

xml animation file here: http://www.filefront.com/14507115/ID%20walking.xaf

Thanks EdT

Yep, caused by Z-up. I'll see what I can do.

Neo