texgen_procs.adb
上传用户:xk288cn
上传日期:2007-05-28
资源大小:4876k
文件大小:4k
源码类别:

GIS编程

开发平台:

Visual C++

  1. --
  2. --  (c) Copyright 1993,1994,1995,1996 Silicon Graphics, Inc.
  3. --  ALL RIGHTS RESERVED
  4. --  Permission to use, copy, modify, and distribute this software for
  5. --  any purpose and without fee is hereby granted, provided that the above
  6. --  copyright notice appear in all copies and that both the copyright notice
  7. --  and this permission notice appear in supporting documentation, and that
  8. --  the name of Silicon Graphics, Inc. not be used in advertising
  9. --  or publicity pertaining to distribution of the software without specific,
  10. --  written prior permission.
  11. --
  12. --  THE MATERIAL EMBODIED ON THIS SOFTWARE IS PROVIDED TO YOU "AS-IS"
  13. --  AND WITHOUT WARRANTY OF ANY KIND, EXPRESS, IMPLIED OR OTHERWISE,
  14. --  INCLUDING WITHOUT LIMITATION, ANY WARRANTY OF MERCHANTABILITY OR
  15. --  FITNESS FOR A PARTICULAR PURPOSE.  IN NO EVENT SHALL SILICON
  16. --  GRAPHICS, INC.  BE LIABLE TO YOU OR ANYONE ELSE FOR ANY DIRECT,
  17. --  SPECIAL, INCIDENTAL, INDIRECT OR CONSEQUENTIAL DAMAGES OF ANY
  18. --  KIND, OR ANY DAMAGES WHATSOEVER, INCLUDING WITHOUT LIMITATION,
  19. --  LOSS OF PROFIT, LOSS OF USE, SAVINGS OR REVENUE, OR THE CLAIMS OF
  20. --  THIRD PARTIES, WHETHER OR NOT SILICON GRAPHICS, INC.  HAS BEEN
  21. --  ADVISED OF THE POSSIBILITY OF SUCH LOSS, HOWEVER CAUSED AND ON
  22. --  ANY THEORY OF LIABILITY, ARISING OUT OF OR IN CONNECTION WITH THE
  23. --  POSSESSION, USE OR PERFORMANCE OF THIS SOFTWARE.
  24. --
  25. --  US Government Users Restricted Rights
  26. --  Use, duplication, or disclosure by the Government is subject to
  27. --  restrictions set forth in FAR 52.227.19(c)(2) or subparagraph
  28. --  (c)(1)(ii) of the Rights in Technical Data and Computer Software
  29. --  clause at DFARS 252.227-7013 and/or in similar or successor
  30. --  clauses in the FAR or the DOD or NASA FAR Supplement.
  31. --  Unpublished-- rights reserved under the copyright laws of the
  32. --  United States.  Contractor/manufacturer is Silicon Graphics,
  33. --  Inc., 2011 N.  Shoreline Blvd., Mountain View, CA 94039-7311.
  34. --
  35. --  OpenGL(TM) is a trademark of Silicon Graphics, Inc.
  36. --
  37. with GL; use GL;
  38. with Glut; use Glut;
  39. package body Texgen_Procs is
  40.    stripeImage : array (0 .. 95) of aliased GLubyte;
  41.    procedure makeStripeImage is
  42.    begin
  43.       for j in 0 .. 31 loop
  44.          if j <= 4 then stripeImage (3*j) := 255;
  45.          else stripeImage (3*j) := 0;
  46.          end if;
  47.          if j > 4 then stripeImage (3*j+1) := 255;
  48.          else stripeImage (3*j+1) := 0;
  49.          end if;
  50.          stripeImage (3*j+2) := 0;
  51.       end loop;
  52.    end makeStripeImage;
  53.    sgenparams : array (0 .. 3) of aliased GLfloat :=
  54.       (1.0, 1.0, 1.0, 0.0);
  55.    procedure DoInit is
  56.    begin
  57.       glClearColor (0.0, 0.0, 0.0, 0.0);
  58.       makeStripeImage;
  59.       glPixelStorei (GL_UNPACK_ALIGNMENT, 1);
  60.       glTexEnvi (GL_TEXTURE_ENV, GL_TEXTURE_ENV_MODE, GL_MODULATE);
  61.       glTexParameteri (GL_TEXTURE_1D, GL_TEXTURE_WRAP_S, GL_REPEAT);
  62.       glTexParameteri (GL_TEXTURE_1D, GL_TEXTURE_MAG_FILTER, GL_LINEAR);
  63.       glTexParameteri (GL_TEXTURE_1D, GL_TEXTURE_MIN_FILTER, GL_LINEAR);
  64.       glTexImage1D (GL_TEXTURE_1D, 0, 3, 32, 0,
  65.          GL_RGB, GL_UNSIGNED_BYTE, stripeImage(0)'Access);
  66.       glTexGeni (GL_S, GL_TEXTURE_GEN_MODE, GL_OBJECT_LINEAR);
  67.       glTexGenfv (GL_S, GL_OBJECT_PLANE, sgenparams (0)'ACCESS);
  68.       glEnable (GL_DEPTH_TEST);
  69.       glDepthFunc (GL_LESS);
  70.       glEnable (GL_TEXTURE_GEN_S);
  71.       glEnable (GL_TEXTURE_1D);
  72.       glEnable (GL_CULL_FACE);
  73.       glEnable (GL_LIGHTING);
  74.       glEnable (GL_LIGHT0);
  75.       glEnable (GL_AUTO_NORMAL);
  76.       glEnable (GL_NORMALIZE);
  77.       glFrontFace (GL_CW);
  78.       glCullFace (GL_BACK);
  79.       glMaterialf (GL_FRONT, GL_SHININESS, 64.0);
  80.    end DoInit;
  81.    procedure DoDisplay is
  82.    begin
  83.       glClear (GL_COLOR_BUFFER_BIT or GL_DEPTH_BUFFER_BIT);
  84.       glPushMatrix;
  85.       glRotatef (45.0, 0.0, 0.0, 1.0);
  86.       glutSolidTeapot (2.0);
  87.       glPopMatrix;
  88.       glFlush;
  89.    end DoDisplay;
  90.    procedure ReshapeCallback (w : Integer; h : Integer) is
  91.    begin
  92.       glViewport (0, 0, GLsizei(w), GLsizei(h));
  93.       glMatrixMode (GL_PROJECTION);
  94.       glLoadIdentity;
  95.       if w <= h then
  96.          glOrtho (-3.5, 3.5, GLdouble (-3.5*GLdouble (h)/GLdouble (w)),
  97.             GLdouble (3.5*GLdouble (h)/GLdouble (w)), -3.5, 3.5);
  98.       else
  99.          glOrtho ((-3.5*GLdouble (w)/GLdouble (h)),
  100.             GLdouble (3.5*GLdouble (w)/GLdouble (h)), -3.5, 3.5, -3.5, 3.5);
  101.       end if;
  102.       glMatrixMode (GL_MODELVIEW);
  103.       glLoadIdentity;
  104.    end ReshapeCallback;
  105. end Texgen_Procs;