XCodeiPhoneOS/Demos/README
author Holmes Futrell <hfutrell@umail.ucsb.edu>
Fri, 15 Aug 2008 23:51:11 +0000
branchgsoc2008_iphone
changeset 2442 ce6623e28015
parent 2421 1bf1cb413ead
child 2461 f8cd2eecde64
permissions -rw-r--r--
renamed and moved up one directory
hfutrell@2421
     1
==============================================================================
hfutrell@2421
     2
About the iPhone OS Demo Applications
hfutrell@2421
     3
==============================================================================
hfutrell@2421
     4
hfutrell@2421
     5
DemosiPhoneOS.xcodeproj contains several targets for iPhone oriented SDL demos.  These demos are written strictly using SDL 1.3 calls.  All the demos except for Fireworks (which requires OpenGL ES) should work on platforms other than iPhone OS, though you'll need to write your own compile script.  To run them on your favorite platform, you may wish to set the macros SCREEN_WIDTH and SCREEN_HEIGHT, located in common.h.
hfutrell@2421
     6
hfutrell@2421
     7
Common files:
hfutrell@2421
     8
hfutrell@2421
     9
	common.c and common.h contain code common to all demo applications.  This includes macros about the screen dimensions (in pixels), simple error handling, and functions for generating random numbers.
hfutrell@2421
    10
hfutrell@2421
    11
Rectangles (rectangles.c):
hfutrell@2421
    12
hfutrell@2421
    13
	Draws randomly sized and colored rectangles all over the screen by using SDL_RenderFill.  This is the simplest of all the demos.
hfutrell@2421
    14
hfutrell@2421
    15
Happy (happy.c):
hfutrell@2421
    16
hfutrell@2421
    17
	Loads the classic happy-face bitmap and draws a large number of happy faces bouncing around the screen.  Shows how you can load a bitmap into an SDL_Texture.
hfutrell@2421
    18
hfutrell@2421
    19
Accelerometer (accelerometer.c):
hfutrell@2421
    20
hfutrell@2421
    21
	Uses the iPhone's accelerometer as a joystick device to move a spaceship around the screen.  Note the use of the macro SDL_IPHONE_MAX_GFORCE (normally defined in SDL_config_iphoneos.h) which converts between the Sint16 number returned by SDL_JoystickGetAxis, and the floating point units of g-force reported natively by the iPhone. 
hfutrell@2421
    22
hfutrell@2421
    23
Touch (touch.c):
hfutrell@2421
    24
hfutrell@2421
    25
	Acts as a finger-paint type program.  Demonstrates how you can use SDL mouse input to accept touch input from the iPhone.  If SDL for iPhone is compiled with multitouch as multiple mouse emulation (SDL_IPHONE_MULTIPLE_MICE in SDL_config_iphoneos.h) then the program will accept multiple finger inputs simultaneously. 
hfutrell@2421
    26
hfutrell@2421
    27
Mixer (mixer.c):
hfutrell@2421
    28
hfutrell@2421
    29
	Displays several rectangular buttons which can be used as a virtual drumset.  Demonstrates how you can play .wav sounds in SDL and how you can use SDL_MixAudioFormat to build a software mixer that can play multiple sounds at once.
hfutrell@2421
    30
hfutrell@2421
    31
Keyboard (keyboard.c):
hfutrell@2421
    32
hfutrell@2421
    33
	Loads a bitmap font and let's the user type words, numbers, and symbols using the iPhone's virtual keyboard.  The iPhone's onscreen keyboard visibility is toggled when the user taps the screen.  If the user types ':)' a happy face is displayed.  Demonstrates how to use functions added to the iPhone implementation of SDL to toggle keyboard onscreen visibility.
hfutrell@2421
    34
hfutrell@2421
    35
Fireworks (fireworks.c):
hfutrell@2421
    36
hfutrell@2421
    37
	Displays a fireworks show.  When you tap the iPhone's screen, fireworks fly from the bottom of the screen and explode at the point that you tapped.  Demonstrates how you can use SDL on iPhone to build an OpenGL ES based application. Shows you how you can use SDL_LoadBMP to load a bmp image and convert it to an OpenGL ES texture.  Of lesser importance, shows how you can use OpenGL ES point sprites to build an efficient particle system.
hfutrell@2421
    38
hfutrell@2421
    39
==============================================================================
hfutrell@2421
    40
Building and Running the demos
hfutrell@2421
    41
==============================================================================
hfutrell@2421
    42
hfutrell@2421
    43
Before building the demos you must first build SDL as a static library for BOTH the iPhone Simulator and the iPhone itself.  See the iPhone SDL main README file for directions on how to do this.  Once this is done, simply launch XCode, select the target you'd like to build, select the active SDK (simulator or device), and then build and go.