Difference between revisions of "Inkscape-0.4.0"

From X-Moto
Jump to: navigation, search
(Sprite)
(Sprite)
Line 246: Line 246:
 
===Sprite===
 
===Sprite===
  
When you transform an object into a sprite with the menu entry "", this window pops up.
+
When you transform an object into a sprite with the menu entry "''Effects->X-moto->Entities->Convert into Sprite''", this window pops up.
 +
It allows you to choose the sprite texture and change some of its parameters.
  
 
[[Image:Inkscape24.png]]
 
[[Image:Inkscape24.png]]
  
It allows you to choose the sprite texture and change some of its parameters.
 
  
 
*Sprites can improve the visual of the level by adding a mood to it. For example this level is a Sonic one, so there's plenty of sprites inspired from the Sonic universe.
 
*Sprites can improve the visual of the level by adding a mood to it. For example this level is a Sonic one, so there's plenty of sprites inspired from the Sonic universe.
Line 256: Line 256:
  
  
*By changing the ''z'' value of a sprite you can put sprites in front or in back of the player.
+
*By changing the '''z''' value of a sprite you can put sprites in front or in back of the player.
 
[[Image:Inkscape29.png]]
 
[[Image:Inkscape29.png]]
  
*You can change the size of a sprite by changing the width and height of a sprite.
+
*By changing the '''rotation angle''' value of a sprite, you can turn you sprite in other directions.
 +
*You can also reverse the sprite on its x axis with the '''reverse the sprite''' button.
 +
[[Image:Inkscape31.png]]
 +
 
 +
*You can change the size of a sprite by changing the '''width''' and '''height''' of a sprite.
 
[[Image:Inkscape27.png]]
 
[[Image:Inkscape27.png]]
  
*When you change the size of a sprite, you can also change it collision radius to reflect its new size if it's a sprite which collides with the biker.
+
*When you change the size of a sprite, you can also change it '''collision radius''' to reflect its new size if it's a sprite which collides with the biker.
 
[[Image:Inkscape30.png]]
 
[[Image:Inkscape30.png]]
  

Revision as of 17:33, 23 August 2007

Svg made with the 0.2.0 version of svg2lvl are not compatible with this version of svg2lvl.

Windows installation

To install Inksmoto level editor 0.4.0 on a Windows box, just double-click on the Inkscape-0.45.1_svg2lvl-0.4.0_win32.exe installer.

Linux & Mac OS X installation

Required software

  • Inkscape (>= 0.45)
  • Python (>= 2.3)
  • python-tk
  • pyXML
  • Svg2lvl converter (0.4.0)

To install the required softwares on an Linux Ubuntu box (Festy Fawn):

$ sudo apt-get install inkscape python python-tk python-xml

To install the required softwares on a MacOS X box, use Fink and/or get the .dmg on the Internet. (TODO: get the exact procedure)

Installation

$ wget http://download.tuxfamily.org/xmoto/svg2lvl/0.4.0/svg2lvl-0.4.0.tar.gz
$ tar zxvf svg2lvl-0.4.0.tar.gz
$ cd ~/svg2lvl-0.4.0/
$ mkdir -p ~/.inkscape/extensions/
$ cp -f * ~/.inkscape/extensions/

Tutorial: First steps

This part of the tutorial learns the basics to be able to create a level.

Warning: This tutorial is for the release 0.4.1 which will be release soon (but not before the 20th of august...)

Warning: If you use the 0.4.0 release, this tutorial do not apply (but there's some similarities).

Quick look at inkscape

Inkscape0.png

Here is the list of useful tools from Inkscape to create Xmoto levels:

  1. The selection tool
  2. The path editing tool
  3. The zoom in/out tool
  4. The rectangle tool
  5. The circle tool
  6. The star tool
  7. The hand draw tool
  8. The bezier curves draw tool
  9. The Xmoto properties menu

To learn how to use Inkscape you can use the official Inkscape tutorials: Inkscape2.png

The Xmoto extensions

The Xmoto extensions from the Effects menu allows you to set Xmoto properties to Inkscape objects in the drawing.

Here is a description of the different entries of the Xmoto menu:

  • Blocks
    • Remove the edge around the block: Remove the upper and/or the down edge of the selected blocks.
    • Add an edge around the block: Add an edge on the upper and/or down edge of the selected blocks. The up and down side can have a different edge texture.
    • Change Block Texture: Change the texture of the selected blocks.
    • Change Block Type: Convert the selected shapes into Xmoto blocks (normal, background, dynamic, dynamic background). You can also assign them a texture.
    • Change block physic params: Change the physic parameters of the selected blocks (currently, only the block friction).
  • Entities
    • Convert into Strawberry: Convert the selected shapes into a strawberry.
    • Convert into End of level: Convert the selected shapes into a end of the level.
    • Convert into Particle Source: Convert the selected shapes into a particle source (fire or smoke).
    • Convert into Player Start: Convert the selected shapes into the start position of the player.
    • Convert into Sprite: Convert the selected shapes into a sprite (with many parameters for the sprite).
    • Convert into Wrecker: Convert the selected shapes into a wrecker.
  • Level
    • Set layers properties: Set which layers are for background and what are their scrolling parameters.
    • Set sky properties: Change the sky of the level.
    • Set level properties: Mandatory options for the level, like its name and id.
    • Set other level properties: Allow sprite replacement of the /strawberry/wrecker/end of level/. Add a music to the level.
  • Other
    • Inksmoto tutorial: Display the link of this tutorial on the wiki.
    • Launch level in X-Moto: Launch the level in Xmoto.
    • Show the object informations: Show the Xmoto properties of the selected shapes.
    • Update X-Moto menus: Get new textures and sprites from the Internet.
  • Zones
    • Convert into Zone: Convert the selected shapes into zones (currently, only rectangular zones are used).

Drawing a simple level

Let's draw a simple level using only the Rectangle, Circle and Star tools.

First, put the zoom of Inkscape to 100% (defaulted to 35% when you create a new svg), then draw your level.

Here's is a simple level drawn using the Star tool for the shapes and the Circle tool for the two little circles: Inkscape4.png

Set level properties

Now that the shapes of the level are drawn, we have to assign them Xmoto properties. For example, we want some shapes to be solid blocks, some others to be background blocks, ...

To do that, select the shapes we want to update, then go to the Xmoto effect menu and use the appropriate menu entry.

Example

  • For example, to put the ground of our tutorial level, select the ground blocks and convert them to xmoto blocks.

Inkscape5.png

  • The block properties window opens in which we choose that our blocks will be normal blocks with the texture glass1:

Inkscape6.png

  • Then the level updated in Inkscape (shapes with an Xmoto properties are colored, the color depends on the property):

Inkscape7.png

Here is the level after we put the three remaining blocks as background blocks and the two circles as the start and the end of the level: Inkscape8.png

Save the level

Now that our level is drawn and its shapes have Xmoto properties, we have to set the properties of the level, like its name, author, ...

  • Use this entry of the Xmoto menu:

Inkscape9.png

  • This windows will popup:

Inkscape10.png

  • Entries in this window (bold ones are mandatory):
    • smoothitude: The higher this parameter, the smoother the level (9 by default).
    • lua script: If your level has a lua script, enter the lua file with its full path.
    • level id: The id of the level (only letters and digits, no space).
    • level name: The real name of the level.
    • author: The author of the level (you).
    • description: A message to add to the level.
    • border texture: Choose the texture which be displayed around the level.

Test it in Xmoto

Now our level is ready to be tested in Xmoto.

  • Just use this Xmoto menu entry:

Inkscape11.png

  • This window will popup:

Inkscape12.png

  • If the Xmoto executable is present in your PATH (under Linux and MacOSX), you don't have to fill the parameter. If you're under Windows or you want to use a specific Xmoto executable, then enter your Xmoto executable with its full path.
  • Here is the level under Xmoto:

Inkscape13.png

  • When you launch the level in Xmoto, the file last.svg and last.lvl are created in the Inkscape extensions directory (~/.inkscape/extensions (Linux & MacOSX) C:\Program Files\Inkscape\share\extensions (Windows)). You can get the svg and the lvl this way. You can also save the svg and the lvl separately using 'File'->'Save As...' and choosing the appropriate file format.

Svg file of the tutorial

Here is the corresponding svg file of the level in its current state : Media:Tutorial1.svg

Tutorial: More advanced topics

In this part, we will see how to add more advanced stuffs to the level in order to create better levels.

Other blocks properties

Different block types

There's four type of blocks:

  • Normal: The blocks which collide with the biker.
  • Background: Blocks behind the biker.
  • Dynamic: Blocks which collide with the biker, they can be moved using scripting.
  • Dynamic background: Blocks behind the biker which can be moved using scripting.

You can change the type of blocks by selected them then use the appropriate menu entry:

Example

  • For example, to convert the three background blocks into dynamic background block, select them and convert them.

Inkscape15.png

  • The block properties window opens in which we choose that our blocks will be dynamic background blocks. Note that we don't update the blocks texture:

Inkscape16.png

  • The resulting level in Inkscape:

Inkscape17.png

Now we can add a script to this level in order to move the dynamic background blocks.

Block edges

In order to increase the visual quality of your level, you can add edges to the blocks. An edge is a texture which is draw on the border of the block.

  • See this screenshot of a level with edges on its blocks:

Inkscape14.png

You can add an edge texture to the upper side of a block and/or to the down side. You can add a different or the same texture to the upper and the down side of a block.

You can also remove an edge to a block after putting it.

Example

  • For example, to add some edge texture to the ground blocks, select them then use this menu entry:

Inkscape18.png

  • The block's edge properties window opens in which we choose that our blocks will have the 'bluen' texture on both their upper and down sides:

Inkscape19.png

  • The resulting level in Inkscape (note that blocks with an edge texture have a green border):

Inkscape20.png

  • The resulting level in Xmoto:

Inkscape21.png

Block physic

You can change the basic behaviour of blocks' physic. For the moment the only custom parameter is the block grip which change the grip of the bike on the block. This parameter is useful to create 'ice' blocks.

To update a block physic params use the "Effects->X-moto->Blocks->Change block physic params" menu entry after selecting the blocks you want to update.

Other entities properties

There's six different type of entities:

  • Strawberry
  • End Of Level
  • Particle Source
  • Player Start
  • Sprite
  • Wrecker

Particle Source

There's two type of particle sources:

  • Fire
  • Smoke

The particles don't interact with the bike, they are only cosmetic effects.

Example

Select the objects you want to transform into particle sources then use the "Effects->X-moto->Entities->Convert into Particle Source" menu entry.

A window will popup which allow to choose between Fire and Smoke.

  • Here is the level with particle sources in it (the orange circles):

Inkscape22.png

  • Here is the level in Xmoto:

Inkscape23.png

Sprite

When you transform an object into a sprite with the menu entry "Effects->X-moto->Entities->Convert into Sprite", this window pops up. It allows you to choose the sprite texture and change some of its parameters.

Inkscape24.png


  • Sprites can improve the visual of the level by adding a mood to it. For example this level is a Sonic one, so there's plenty of sprites inspired from the Sonic universe.

Inkscape28.png


  • By changing the z value of a sprite you can put sprites in front or in back of the player.

Inkscape29.png

  • By changing the rotation angle value of a sprite, you can turn you sprite in other directions.
  • You can also reverse the sprite on its x axis with the reverse the sprite button.

Inkscape31.png

  • You can change the size of a sprite by changing the width and height of a sprite.

Inkscape27.png

  • When you change the size of a sprite, you can also change it collision radius to reflect its new size if it's a sprite which collides with the biker.

Inkscape30.png

Others

Strawberry, End Of Level, Player Start and Wrecker have no special parameters.

Other level properties

Sky

Inkscape25.png

Theme replacement & Music

Inkscape26.png

Layers

Inkscape tricks