obsolete 2D game API using OpenGL for fast 2D drawing and SDL for everything else
Go to file
2003-02-02 23:30:15 +00:00
doc 0.8.2 2003-01-28 21:33:02 +00:00
include Fixed documentation in ZEngine. 2003-02-02 23:30:15 +00:00
lib added 2003-01-02 21:05:33 +00:00
src Fixed documentation in ZEngine. 2003-02-02 23:30:15 +00:00
test added alpha and fixed toggle 2003-01-25 20:36:13 +00:00
vc6 updated files 2003-01-19 00:35:30 +00:00
vc7 fixed 2003-01-16 04:40:18 +00:00
authors.txt VC6 Files by Sean 2003-01-03 03:48:01 +00:00
changelog.txt *** empty log message *** 2003-01-28 20:51:37 +00:00
config 0.8.2 2003-01-18 22:00:52 +00:00
files.txt Added VC6 2003-01-03 03:59:10 +00:00
licensing-template.txt licensing-template info 2003-01-02 03:29:37 +00:00
licensing.txt removed extra the 2003-01-24 20:52:41 +00:00
makefile updated for new files 2003-01-19 00:52:46 +00:00
readme.txt updates 2003-01-12 04:40:51 +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 merged w/ ztodo 2003-01-24 20:57: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.
If you are having a problem building ask at 
http://www.conceptofzero.net/forums/index.php?act=SF&f=15
------------------------------------------------------------
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.  ZEngine itself has no real restrictions on use, and is
under the OSI-certified BSD license (see licensing.txt). Below are quick
guides of how you would distribute various packages 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.
    (Open-Source applications do not need to have a link to a download for
    LGPL-licensed libraries.)

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

Adding to ZEngine:
    -This can currently be done with no restrictions, but we do ask that 
    you submit your changes back to the community.
------------------------------------------------------------
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