Designing a level in Elma is very easy. A level consists of a number of polygons, and start and exit (flower) objects. There can also be the optional objects:
So to make a level all you need to do is open the editor and draw some polygons and put markers where the objects and pictures should be drawn. Then the Elma graphics engine will do the rest.
This is what the buttons in the left-side menu do, some of them are obvious:
- Exit - Exits the editor and returns to Elma.
- New - Closes current level and resets the contents of the editor.
- Open - Opens another level.
- Save As - Save the level with a new name.
- Save - Save the level.
- Save and Play - Save the level and test it. Also checks the topology (see below).
- Check Topology - Checks if there are any errors in the level. Possible errors are:
- Two lines (of non-grass polygon(s)) are intersecting each other.
- The start or exit objects are in the ground.
- Properties - Set the level properties:
- Foreground texture
- Background texture
- Level Name
- LGR File - Which set of graphics to use for the current level.
- Zoom Out - Zooms out a bit to show more of the level.
- View Options - Choose what to display in the level:
- View Polygons
- View Grass
- View Pictures
- Help - Displays some basic help.
- Move - Move a vertex, start, exit, apple, killer or picture.
- Zoom In - Lets you draw a rectangle over the part you want to zoom in on.
- Create Vertex - Start drawing a polygon, or add to an existing one.
- Delete Vertex - Delete a point of a polygon.
- Delete Polygon - Delete an entire polygon. Be careful with this!
- Create Food - Place an apple in the level.
- Create Killer - Place a killer object in the level.
- Delete Object - Delete apples or killers.
- Create Picture - Place a picture or texture element in the level.
- Delete Picture - Delete a picture or texture element.
New features from EOLEdit
With the new version of EOL, some limits were increased of various things. Here's the comparison with old and new:
- 52 to 252 objects (apple, killer, flower and start)
- 300 to 1200 polygons (grass and normal)
- 5000 to 20000 total vertices (over 5130 is buggy at the moment though)
But there are some things that still the same:
- 1000 vertices per polygon
- 5000 pictures (textures and pictures)
GrassEditWhen you have drawn the polygon that should have grass on it, draw a new polygon under the edge of the first polygon in the shape you want the grass to have, like on the picture.
In this case the shape of the grass polygon follows the shape of the normal polygon, which is the most common way to do it.
What has been drawn in the image is all you should draw, it's a common beginner mistake to also draw above the original polygon. The editor draws the grass texture between the lines of the grass polygon and the normal polygon, and draws the tiny "edges" of the grass under the grass polygon's lines. There is one exception though; nothing is drawn around the longest line (in the horizontal direction) of the grass polygon.
This means that if you draw parts of the grass polygon above the normal polygon, Elma will put grass there too if there's any ground nearby. And the longest line might be one of the lines in the ground where you wanted the grass, but since it's the longest line Elma will ignore it and not put any grass there.
When you have drawn the grass polygon properly, turn it into grass by clicking the "Move" button and then right-clicking any point on the grass polygon. Then you will get a dialog where you can choose "Grass polygon". Done!
Gravity is made by modifying apples (food). Select "Move" and right-click on an apple. Now you get a menu where you can choose the direction of the gravity the apple should set.
The "Food anim number" option doesn't change the gravity, it just sets which angle the apple has.
There are a few external editors available.
- ALE (Advanced Level Editor) by Nicolas is the oldest external level editor.
- NEW! by Totem.
- SLE by Smibu (a part of Elmanager).
- vectrast (a.k.a. Rad's Levmaker), not really an editor per se, instead it takes images and converts them to levels, or levels to images. Useful for including "pictures" and text in levels easily.