obsolete 2D game API using OpenGL for fast 2D drawing and SDL for everything else
Go to file
2003-07-12 09:22:13 +00:00
doc pre 0.8.4 2003-07-11 20:51:44 +00:00
include g++ fixes 2003-07-12 01:25:42 +00:00
lib added 2003-01-02 21:05:33 +00:00
src dependencies documentation 2003-07-12 09:22:13 +00:00
test g++ fixes 2003-07-12 01:25:42 +00:00
vc6 rand 2003-04-27 22:49:14 +00:00
vc7 pre 0.8.4 2003-07-11 20:51:44 +00:00
authors.txt Added Kevin Watters 2003-02-12 02:25:01 +00:00
changelog.txt dependencies documentation 2003-07-12 09:22:13 +00:00
config updated for g++ build 2003-07-11 23:06:20 +00:00
dependencies.txt dependencies documentation 2003-07-12 09:22:13 +00:00
files.txt Added VC6 2003-01-03 03:59:10 +00:00
LGPL.txt dependencies documentation 2003-07-12 09:22:13 +00:00
licensing-template.txt licensing-template info 2003-01-02 03:29:37 +00:00
licensing.txt dependencies documentation 2003-07-12 09:22:13 +00:00
makefile updated for g++ build 2003-07-11 23:06:20 +00:00
readme.txt dependencies documentation 2003-07-12 09:22:13 +00:00
tab2space.py Initial revision 2002-11-21 05:40:49 +00:00
thanks.txt added nehe + gt 2003-01-13 05:46:42 +00:00
todo.txt heading towards 0.8.4 2003-07-11 00:07:49 +00:00

Index
------------------------------------------------------------
I.   About ZEngine
II.  Getting ZEngine
III. Building ZEngine
IV.  Using ZEngine
V.   Legal Overview
VI.  History of ZEngine
------------------------------------------------------------
I. About ZEngine 0.8

ZEngine is a game library which is designed to compile that SDL and OpenGL
are available on.  ZEngine is a set of classes and a main ZEngine class which
are designed to make game development easier and more organized.  As of 0.7.7
ZEngine uses OpenGL to do the 2D display, so it is much faster and can take
advantage of hardware accelerated features.   This file provides a simple
overview of using it, more on the subject can be found in the docs and at
http://conceptofzero.net/tutorials/zengine/.
------------------------------------------------------------
II. Getting ZEngine:

Support comes from: http://conceptofzero.net/
The sourceforge page: http://zengine.sourceforge.net/
The project page: http://sourceforge.net/projects/zengine/
The CVS page: http://sourceforge.net/cvs/?group_id=62098
------------------------------------------------------------
III. Building ZEngine:

ZEngine can be built on any system that has SDL and OpenGL available.  It is
currently being developed on Redhat 8.0 and Windows 2000/XP.  If you are in
VC++ the folders vc6 and vc7 contains project files for use, and if you are 
in mingw or cygwin you can change the linux makefile to suit your needs.
-If you are using VC++ you will need to add the path to the dependencies (SDL 
and others) as well as the path to ZEngine before building.
-If you are using gcc on any OS you need to change configure (not the
makefile) to meet your needs then run make.

See dependencies.txt for information on obtaining the dependencies.

If you are having a problem building ask at 
http://www.conceptofzero.net/index.php?name=PNphpBB2&file=viewforum&f=4
------------------------------------------------------------
IV. Using ZEngine:

Using ZEngine is as easy as having a look at the sample programs and nice
documentation provided and setting the compiler to link with the ZEngine lib
and include the ZEngine include files.  ZEngine allows you to decide what 
external libraries (other than SDL and OpenGL which are required) you want
to use when you build the library file.  Depending on which libraries you are
using you will need to distribute various files with your program, but none
are part of ZEngine, but instead are files in use by the dependencies.
------------------------------------------------------------
V. Legal Overview:

The world of open source licenses can be confusing, if you are not familiar 
with the LGPL I recommend reading it, as most libraries ZEngine makes use of
are licensed under it. (LGPL.txt is included) ZEngine itself has no real 
restrictions on use, and is under the OSI-certified BSD license 
(see licensing.txt). Below is a quick guide to how you would distribute 
a package making use of ZEngine.

Closed-Source Application using ZEngine:
    (see licensing-template.txt)
    -Include required DLLs or dynamic modules
    -Include notice of which libraries you used, and have a place for user to
    dowload them from your website.
    -If you are using non-LGPL libraries there may be other requirements.

(licensing-template.txt is included to help you comply with the LGPL)

See dependencies.txt for information on source to the dependencies.

Adding to ZEngine:
    -This can currently be done with no restrictions, but I do ask that 
    you submit your changes back to the community if possible.
------------------------------------------------------------
History of ZEngine:
    The changelog may not show it but 0.1 to 0.6 were some of the biggest 
changes, often I'd rewrite massive portions of code, I wasn't keeping the 
changelog, and I wasn't testing for compatibility. ZEngine was still 
designed to be an engine that only CoZ members used, hardly clean but useful
enough to speed up the process of making games, even if it was going to be 
open source, I figured I'd put it out there as example code, but never really
 make it an open source project.
    By 0.5 and 0.6 I really got the idea that this could become something that
some other people may want to use, so I started to document everything and I 
began to prepare for the Linux version.  During 0.6.x I was struggling with 
organizing the code as well as licensing, and SDL 1.2.5 was released which
turned into an unnecessary rewrite.  (Honestly nothing changed in SDL that 
affected ZEngine, but for some reason I felt ZEngine would be much better if 
the code was cleaner and I tried to reduce the amount of legacy code left from
the early versions.)
    0.6.3 made the jump to 0.7.0 because there really was a change in ZEngine, 
the target audience as well as the code base.  With ZConfigFile, ZEngine 
started to gain features that SDL didn't have, so it wasn't just a SDL wrapper
anymore. 0.7.x turned into a series of major releases, with some major changes
including 0.7.3, 0.7.4, and the major 0.7.7, which almost became 0.8.0.
    0.8.0 is a whole new ZEngine, I estimate that no more than 2% of the 
original code remains, almost everything I added in 0.3.0 is still there, but
other than that, nothing stuck until 0.7 for example the ZEngine class itself
has gone 2 complete rewrites since 0.1.  I used to work in DirectX a lot, and
ZEngine addresses a lot of grieviances I had with DirectX, ZEngine code is a 
lot shorter, and is a good deal easier to read, everything is integrated, 
unlike DirectX where Input and Graphics were entirely separate things. ZEngine
runs a lot faster on most systems now, due to the OpenGL rendering, and as a
little treat I threw in just in time for the 0.8.0 release, ZEngine attempts 
to detect surface loss, and even provides methods to restore it.

    -James Turk james@conceptofzero.net