Advertisement
Kojima0502

OpenGL_GL_FLOAT

Jan 21st, 2014
70
0
Never
Not a member of Pastebin yet? Sign Up, it unlocks many cool features!
C++ 3.80 KB | None | 0 0
  1. #include <stdio.h>
  2. #include <stdlib.h>
  3. #include <GLUT/glut.h>
  4.  
  5.  
  6. /* 画像についての情報を保存しておく変数・定数 */
  7. #define  IMGFILE  "depth_0010-01.raw"
  8. #define  CHANNEL  1  // 画像の色数(R, G, B)
  9. int width;           // 画像の幅
  10. int height;          // 画像の高さ
  11. GLuint texture;      // テクスチャの識別番号
  12. GLfloat* image;      // ビットマップ画像データを格納
  13.  
  14. /* 関数のプロトタイプ宣言 */
  15. void loadImage(const char* filepath, int widht, int height);  // BMP 画像を読み込む
  16.  
  17.  
  18. void display(void)
  19. {
  20.     glClear(GL_COLOR_BUFFER_BIT);
  21.     glClearColor (1.0, 1.0, 1.0, 1.0);
  22.    
  23.     /* 画像の表示 */
  24.     glRasterPos2i(0, 0);
  25.     glDrawPixels(width, height, GL_LUMINANCE, GL_FLOAT, image);
  26.     glEnable(GL_TEXTURE_2D);
  27.     glBindTexture(GL_TEXTURE_2D, texture);
  28.     glBegin(GL_QUADS);
  29.     glTexCoord2f(1.0, 0.0);  glVertex2f(1.0, 0.0);
  30.     glTexCoord2f(1.0, 1.0);  glVertex2f(1.0, 1.0);
  31.     glTexCoord2f(0.0, 1.0);  glVertex2f(0.0, 1.0);
  32.     glTexCoord2f(0.0, 0.0);  glVertex2f(0.0, 0.0);
  33.     glEnd();
  34.     glDisable(GL_TEXTURE_2D);
  35.    
  36.     glutSwapBuffers();
  37. }
  38.  
  39.  
  40. /* 個々のプログラム独自に行なうべき初期化 */
  41. void myInit(void)
  42. {
  43.     loadImage(IMGFILE,width,height);
  44.    
  45.     /* ウィンドウ生成前に行なうべき設定 */
  46.     glutInitWindowSize(800, 600);                  // ウィンドウサイズの設定
  47.     glutInitWindowPosition(200, 200);              // 表示位置の設定
  48.     glutInitDisplayMode(GLUT_RGBA | GLUT_DOUBLE);  // ディスプレイモードの設定
  49.     glutCreateWindow("OpenGL");                    // ウィンドウを生成
  50.     glClearColor (0.0, 0.0, 0.0, 1.0);             // ウィンドウの背景色
  51.    
  52.     /* イベント発生時に呼び出される関数の登録 */
  53.     glutDisplayFunc(display);// 描画関数(自分自身で定義)を登録
  54.    
  55.    
  56.     /* テクスチャの作成 */
  57.    
  58.     glPixelStoref(GL_UNPACK_ALIGNMENT, 8);
  59.     glGenTextures(1, &texture);
  60.     glBindTexture(GL_TEXTURE_2D, texture);
  61.     glTexParameterf(GL_TEXTURE_2D, GL_TEXTURE_MAG_FILTER, GL_LINEAR);
  62.     glTexParameterf(GL_TEXTURE_2D, GL_TEXTURE_MIN_FILTER, GL_LINEAR);
  63.     glTexImage2D(GL_TEXTURE_2D, 0, GL_LUMINANCE,
  64.                  width, height, 0, GL_LUMINANCE,
  65.                  GL_FLOAT, image);
  66.     free(image);
  67.    
  68. }
  69.  
  70. int main(int argc, char* argv[])
  71. {
  72.     /* 初期化 */
  73.     width = atoi(argv[1]);
  74.     height = atoi(argv[2]);
  75.     glutInit(&argc, argv);
  76.     myInit();
  77.    
  78.     /* イベント待機状態に入る */
  79.     glutMainLoop();
  80.    
  81.     return 0;
  82. }
  83.  
  84.  
  85. /* BMP画像の場所を引数にとり、image配列に画像データを格納していく */
  86. void loadImage(const char* filepath, int widht, int height)
  87. {
  88.     int i;
  89.     int size;  // 画像のサイズ(幅 * 高さ * 色数)
  90.     FILE* fp;
  91.    
  92.     /* ファイルの読込 */
  93.     fp = fopen("depth_0010-01.raw", "rb");
  94.     if (fp == NULL)
  95.     {
  96.         fprintf(stderr, "%sのロードに失敗\n", filepath);
  97.         exit(EXIT_FAILURE);
  98.     }
  99.    
  100.     /* 画像の幅, 高さを取得 */
  101.     //fseek(fp, 18, SEEK_SET);  // 画像の幅が格納されている場所までfpを移動
  102.     //fread(&width, 4, 1, fp);
  103.     //fread(&height, 4, 1, fp);
  104.    
  105.     /* 画像データの読み込み */
  106.     // fseek(fp, 54, SEEK_SET);  // 画像データが格納されている場所までfpを移動
  107.     size = width * height * CHANNEL;
  108.     image = (GLfloat *) malloc(size*sizeof(float));
  109.     if (image == NULL)
  110.     {
  111.         fprintf(stderr, "メモリ確保に失敗\n");
  112.         exit(EXIT_FAILURE);
  113.     }
  114.    
  115.     for (i = 0; i < size; ++i)
  116.         fread(&image[i], sizeof(GLfloat), 1, fp);
  117.    
  118.     /* 作業が終わったのでファイルを閉じる */
  119.     fclose(fp);
  120. }
Advertisement
Add Comment
Please, Sign In to add comment
Advertisement