Sophie

Sophie

distrib > Fedora > 15 > i386 > by-pkgid > d8d513c6dd5a26793ebd36a9f6865487 > files > 81

ocaml-lablgl-devel-1.04-5.fc15.i686.rpm

(*
 * This code was created by Jeff Molofee '99 
 * If you've found this code useful, please let me know.
 *
 * Visit Jeff at http://nehe.gamedev.net/
 * 
 * Ported to O'Caml/lablglut by Jeffrey Palmer 8/02
 * For port-specific issues, comments, etc., please
 * contact jeffrey.palmer@acm.org
 *)

let init_gl width height =
    GlDraw.shade_model `smooth;
    GlClear.color (0.0, 0.0, 0.0);
    GlClear.depth 1.0;
    GlClear.clear [`color; `depth];
    Gl.enable `depth_test;
    GlFunc.depth_func `lequal;
    GlMisc.hint `perspective_correction `nicest

let draw_gl_scene () =
  GlClear.clear [`color; `depth];
  GlMat.load_identity ();
  (* Draw the triangle *)
  GlMat.translate3 (-1.5, 0.0, -6.0);
  GlDraw.begins `triangles;
  GlDraw.color   ( 1.0,  0.0, 0.0);
  GlDraw.vertex3 ( 0.0,  1.0, 0.0);
  GlDraw.color   ( 0.0,  1.0, 0.0);
  GlDraw.vertex3 (-1.0, -1.0, 0.0);
  GlDraw.color   ( 0.0,  0.0, 1.0);
  GlDraw.vertex3 ( 1.0, -1.0, 0.0);
  GlDraw.ends ();
  (* Draw the square *)
  GlMat.translate3 (3.0, 0.0, 0.0);
  GlDraw.begins `quads;
  GlDraw.color   ( 0.5,  0.5, 1.0);
  GlDraw.vertex3 (-1.0,  1.0, 0.0);
  GlDraw.vertex3 ( 1.0,  1.0, 0.0);
  GlDraw.vertex3 ( 1.0, -1.0, 0.0);
  GlDraw.vertex3 (-1.0, -1.0, 0.0);
  GlDraw.ends ();
  Glut.swapBuffers ()

(* Handle window reshape events *)
let reshape_cb ~w ~h =
  let 
    ratio = (float_of_int w) /. (float_of_int h) 
  in
    GlDraw.viewport 0 0 w h;
    GlMat.mode `projection;
    GlMat.load_identity ();
    GluMat.perspective 45.0 ratio (0.1, 100.0);
    GlMat.mode `modelview;
    GlMat.load_identity ()

(* Handle keyboard events *)
let keyboard_cb ~key ~x ~y =
  match key with
    | 27 (* ESC *) -> exit 0
    | _ -> ()

let main () =
  let 
    width = 640 and
    height = 480
  in
    ignore (Glut.init Sys.argv);
    Glut.initDisplayMode ~alpha:true ~depth:true ~double_buffer:true ();
    Glut.initWindowSize width height;
    ignore (Glut.createWindow "O'Caml OpenGL Lesson 3");
    Glut.displayFunc draw_gl_scene;
    Glut.keyboardFunc keyboard_cb;
    Glut.reshapeFunc reshape_cb;
    init_gl width height;
    Glut.mainLoop ()

let _ = main ()