Advertisement
Kojima0502

textureMAP_raw_texture

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