Author Topic: Importing Audio  (Read 20354 times)

dutch_619

  • Regular
  • **
  • Posts: 90
    • View Profile
    • Email
Importing Audio
« on: 2008-11-18, 06:49:37 PM »
I have had a few issues with importing audio from the FX library. I get an error message stating that SGDK2 failed to decapsulate info from the fmod.cs package. Is this a common error? Or perhaps I did something stupid...

I finally went back an finished a game I started oh so long ago and decided to do something new.

dutch_619

  • Regular
  • **
  • Posts: 90
    • View Profile
    • Email
Re: Importing Audio
« Reply #1 on: 2008-11-18, 09:44:39 PM »
Hmm, seem to have gotten the problem more or less resolved. Still won't import, but was able to edit and add what I needed (and a little judicious copy and pasting helped).

bluemonkmn

  • SGDK Author
  • Administrator
  • Fanatic
  • *****
  • Posts: 2761
    • ICQ Messenger - 2678251
    • MSN Messenger - BlueMonkMN@gmail.com
    • View Profile
    • http://sgdk2.sf.net/
    • Email
Re: Importing Audio
« Reply #2 on: 2008-11-19, 04:17:57 AM »
Is there not a file "fmod.cs" in the directory with the SGDK2 file from which you are trying to import the sound?  What version are you using?

dutch_619

  • Regular
  • **
  • Posts: 90
    • View Profile
    • Email
Re: Importing Audio
« Reply #3 on: 2008-11-28, 11:07:40 PM »
It seems that I had some leftover files from a beta release of SGDK2 that caused an issue. After a complete uninstall and a clean install it ran quite smoothly. From there I just added the correct files and imported the audio (as described in the tutorial).

I am quite happy with the C# implementation too. I finally got an old old game to run, but it was ugly due to my inexperience with VB.

bluemonkmn

  • SGDK Author
  • Administrator
  • Fanatic
  • *****
  • Posts: 2761
    • ICQ Messenger - 2678251
    • MSN Messenger - BlueMonkMN@gmail.com
    • View Profile
    • http://sgdk2.sf.net/
    • Email
Re: Importing Audio
« Reply #4 on: 2008-11-29, 08:52:36 AM »
I'll try posting from my PSP. So you're saying you remade an SGDK 1.4 game in SGDK 2.0? From scratch? Any comments on how the 2 compare?

dutch_619

  • Regular
  • **
  • Posts: 90
    • View Profile
    • Email
Re: Importing Audio
« Reply #5 on: 2008-11-29, 11:48:36 AM »
No, it was an alpha release of SGDK2 (I used the Beta name mistakenly). I did finish a game started in SGDK1.4 (at long last) which is how I started using SGDK2. I imported tilesets from the 1.4 rev as well as much of the various sprite behaviors. I did write the sprite behaviors in C# directly rather than using the rules creator. This was done as the alpha had some... issues.

As far as comparing the two, I find SGDK2 both much harder to use as the learning curve is steeper and at that same time a bit more intuitive. I find it easier to write/script behavior for a sprite in C# than it was in VB.

The released version of SGDK2 is much more polished than the earlier version with MUCH more functionality. While I still have issues with the graphics editor, the ability to export a sheet, then to re-import it with graphics added externally allows me to bypass this.

SmartBoy16

  • Contributor
  • Fanatic
  • **
  • Posts: 587
  • Looking for inspiration.....
    • View Profile
    • Email
Re: Importing Audio
« Reply #6 on: 2008-11-29, 10:02:01 PM »
i say that SGDK1 is easier for beginners and SGDK2 for anyone with some game development skill
Looking to the skies.....

bluemonkmn

  • SGDK Author
  • Administrator
  • Fanatic
  • *****
  • Posts: 2761
    • ICQ Messenger - 2678251
    • MSN Messenger - BlueMonkMN@gmail.com
    • View Profile
    • http://sgdk2.sf.net/
    • Email
Re: Importing Audio
« Reply #7 on: 2008-12-01, 07:31:32 AM »
I guess I have a hard time picking up on the details when reading messages on that little PSP screen  :-[.  I see now you were talking about SGDK2.
Back on topic, I understand that importing audio would be more difficult than it was in 1.4.  Are there other areas that are harder to use in 2.0?

dutch_619

  • Regular
  • **
  • Posts: 90
    • View Profile
    • Email
Re: Importing Audio
« Reply #8 on: 2008-12-01, 04:24:35 PM »
Well, part of the problem may be in how poorly I described my problems :whistle:

The things I have found more difficult for the most part have had to do with the rulesets for sprites. A template of basic sprite behaviors as was available in SGDK1 might be a worthwhile thing. Just a very basic set of rules to import for left/right and 360 sprites would be nice to have.

A timer function might be nice to have as well. I have one built using the framerate limiter and a counter linked to it to let me do a "pause" in a map. This lets me play a movie clip on its own map and then jump to the next map.

bluemonkmn

  • SGDK Author
  • Administrator
  • Fanatic
  • *****
  • Posts: 2761
    • ICQ Messenger - 2678251
    • MSN Messenger - BlueMonkMN@gmail.com
    • View Profile
    • http://sgdk2.sf.net/
    • Email
Re: Importing Audio
« Reply #9 on: 2008-12-01, 09:30:34 PM »
Ah yes, the plan was to have an importable sprite template for each useful sprite type that SGDK 1 implemented.  So far you have, left/right flat, left/right jump and left/right slopes, 360-degree car (new), 360-degree spaceship, platform (single-state), cannon (new) and a player sprite.  Are there any other basic sprite types from SGDK1 that you found useful that you think should be made into SGDK2 templates?  Were you aware of these sprite templates serving as the replacement for the basic SGDK 1 sprite types?  (Are they fulfilling their purpose?)

dutch_619

  • Regular
  • **
  • Posts: 90
    • View Profile
    • Email
Re: Importing Audio
« Reply #10 on: 2008-12-01, 09:42:07 PM »
Ah... didn't see know they were there in the source folder... I have been using the help file as I go, but haven't run through the tutorial project. I was attempting to have my sprite do the basic left/right + jumping left/right as well as an attacking left/right by using a rule-set to change the sprites state rather than switching to another sprite doing that action. I think I might need to do it via different sprites however, as my rule-set is already HUGE.

I did storyboard the entire game first this time however. This has proven to be very helpful! My previous tries with SGDK1 were frustrating due to this lack of forethought.

bluemonkmn

  • SGDK Author
  • Administrator
  • Fanatic
  • *****
  • Posts: 2761
    • ICQ Messenger - 2678251
    • MSN Messenger - BlueMonkMN@gmail.com
    • View Profile
    • http://sgdk2.sf.net/
    • Email
Re: Importing Audio
« Reply #11 on: 2008-12-02, 06:20:12 AM »
I think Tanja had a similar problem of the rules getting too complex to manage, and converted it to C# code instead.  Maybe I should add a command to "Convert To Function" that would take all the rules in the current tree (or the selected branch) and generate a function from them which you could call with one rule.  Then you could edit the rules in C# code and keep the rule tree simple.  Maybe this would also address the other issue of displaying the C# code for the rules too.  Thoughts?

dutch_619

  • Regular
  • **
  • Posts: 90
    • View Profile
    • Email
Re: Importing Audio
« Reply #12 on: 2008-12-02, 01:21:32 PM »
I think that perhaps a set of modules to be called would be a good idea. Instead of importing a ruleset for a sprite, you could call a c# module of the basic sprite type. Then the rule tree could be used for any additional behavior beyond the basic sprite control. Perhaps have a basic value for gravity, inertia etc. set that would be edited to fit the users need.

So, perhaps a left/right and jumping sprite module and a 360 module to start? This would allow the user to have a ready to run basic sprite with only rules for attacks or special functions needed. Maybe a menu sprite as well? Something that simply snaps up or down based on the up oe down key to allow text to be highlighted.

bluemonkmn

  • SGDK Author
  • Administrator
  • Fanatic
  • *****
  • Posts: 2761
    • ICQ Messenger - 2678251
    • MSN Messenger - BlueMonkMN@gmail.com
    • View Profile
    • http://sgdk2.sf.net/
    • Email
Re: Importing Audio
« Reply #13 on: 2008-12-02, 06:10:46 PM »
The problem with delivering the pre-defined templates as "modules" is that makes the sprite less customizable and flexible.  One of the goals of SGDK2 is to separate the features/framework into layers so that the user is free to customize the code at a level/layer they're comfortable with.  In version 1.x, you only had 2 choices: use a pre-defined sprite type or script all of your sprite's behavior manually.  SGDK2 creates a new layer of "Rules" that expose behaviors in a format that's (intended to be) simpler to use, but not as complex as coding, and more flexible but not as straightforward as simply selecting a template.  And yet it keeps both other options open.  You can still simply select a template, and you can still totally customize everything at the code level.  If I were to convert all the templates into modules, it would defeat the purpose of having this intermediate layer where the user could perform relatively simple customizations to the sprites' behaviors because the rules would no longer be exposed.  There are too many variables about a sprite's behavior (even those exposed in version 1.x); they just couldn't all be exposed by a single rule function without giving the user the opportunity to control them.  In version 1.x you can control the gravity, inertia, input source and jump height (among other things).  That alone represents too many parameters to pass to a rule function.  To it seems to make sense to split it up a bit more as I have tried to do in 2.0 so that you have high-level functions controlling the sprites behavior at a level somewhere near the midpoint between manually coding everything and simply selecting a template.  Ant the goal of limiting the number of parameters in a rule function to 3 is to help enforce the idea that these rule functions should be simple and easy to create.  If there are more than 3 variables affecting a rule, the rule should be split into multiple rules to make more of it visible as separate components in the tree (or parameters tab) instead of having it all collapsed into a single tree node.

The reason I suggest having an option to convert a set of rules into a single function for non-template sprites is because you have the opportunity to customize those rules in the rule editor before converting them into a function.  Also, the delivered templates are relatively short and don't need to be converted into functions.  The number of rules on most of the templates is quite manageable.  But I imagine that often times you can end up with some pretty complex sets of rules for sprites while incorporating or manipulating them for a specific project, unlike the templates which are just a simple framework for sprite behavior.

Does that make sense?

dutch_619

  • Regular
  • **
  • Posts: 90
    • View Profile
    • Email
Re: Importing Audio
« Reply #14 on: 2008-12-02, 10:08:51 PM »
I believe you may be correct in thinking that a template "module" would reduce flexibility; at least as far as more complex sprite behavior goes. The importable templates are simple enough as you stated to remain in the rules editor. With that being said, I don't believe what I'm doing now is even possible in SGDK1 without a massive amount of scripting.

I think my main issue at this point is that I'm becoming a wee bit overwhelmed with the size of my rule-set tree. It's a bit intimidating. All in all I think SGDK2 is much more flexible than SGDK1 due to the changes in sprite behavior alone. I ended up having to use Visio to develop a flow chart to visualize what I needed to do.