亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來(lái)到蟲(chóng)蟲(chóng)下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲(chóng)蟲(chóng)下載站

?? demo8_8.cpp

?? 一本外國(guó)人寫(xiě)的關(guān)于3D游戲編程的書(shū)的源碼
?? CPP
?? 第 1 頁(yè) / 共 3 頁(yè)
字號(hào):
// DEMO8_8.CPP 8-bit quad drawing demo

// INCLUDES ///////////////////////////////////////////////

#define WIN32_LEAN_AND_MEAN  // just say no to MFC

#define INITGUID

#include <windows.h>   // include important windows stuff
#include <windowsx.h> 
#include <mmsystem.h>
#include <iostream.h> // include important C/C++ stuff
#include <conio.h>
#include <stdlib.h>
#include <malloc.h>
#include <memory.h>
#include <string.h>
#include <stdarg.h>
#include <stdio.h> 
#include <math.h>
#include <io.h>
#include <fcntl.h>

#include <ddraw.h> // include directdraw

// DEFINES ////////////////////////////////////////////////

// defines for windows 
#define WINDOW_CLASS_NAME "WINCLASS1"

// default screen size
#define SCREEN_WIDTH    640  // size of screen
#define SCREEN_HEIGHT   480
#define SCREEN_BPP      8    // bits per pixel

#define BITMAP_ID            0x4D42 // universal id for a bitmap
#define MAX_COLORS_PALETTE   256

const double PI = 3.1415926535;

// fixed point mathematics constants
#define FIXP16_SHIFT     16
#define FIXP16_MAG       65536
#define FIXP16_DP_MASK   0x0000ffff
#define FIXP16_WP_MASK   0xffff0000
#define FIXP16_ROUND_UP  0x00008000

// TYPES //////////////////////////////////////////////////////

// basic unsigned types
typedef unsigned short USHORT;
typedef unsigned short WORD;
typedef unsigned char  UCHAR;
typedef unsigned char  BYTE;

// a 2D vertex
typedef struct VERTEX2DI_TYP
        {
        int x,y; // the vertex
        } VERTEX2DI, *VERTEX2DI_PTR;

// a 2D vertex
typedef struct VERTEX2DF_TYP
        {
        float x,y; // the vertex
        } VERTEX2DF, *VERTEX2DF_PTR;


// a 2D polygon
typedef struct POLYGON2D_TYP
        {
        int state;        // state of polygon
        int num_verts;    // number of vertices
        int x0,y0;        // position of center of polygon  
        int xv,yv;        // initial velocity
        DWORD color;      // could be index or PALETTENTRY
        VERTEX2DF *vlist; // pointer to vertex list
 
        } POLYGON2D, *POLYGON2D_PTR;


// PROTOTYPES  //////////////////////////////////////////////

int DDraw_Fill_Surface(LPDIRECTDRAWSURFACE7 lpdds,int color);

// 2d 8-bit triangle rendering
void Draw_Top_Tri(int x1,int y1,int x2,int y2, int x3,int y3,int color,UCHAR *dest_buffer, int mempitch);

void Draw_Bottom_Tri(int x1,int y1, int x2,int y2, int x3,int y3,int color,UCHAR *dest_buffer, int mempitch);

void Draw_Top_TriFP(int x1,int y1,int x2,int y2, int x3,int y3,int color,UCHAR *dest_buffer, int mempitch);

void Draw_Bottom_TriFP(int x1,int y1, int x2,int y2, int x3,int y3,int color,UCHAR *dest_buffer, int mempitch);

void Draw_Triangle_2D(int x1,int y1,int x2,int y2,int x3,int y3,
                      int color,UCHAR *dest_buffer, int mempitch);

void Draw_TriangleFP_2D(int x1,int y1,int x2,int y2,int x3,int y3,
                        int color,UCHAR *dest_buffer, int mempitch);

inline void Draw_QuadFP_2D(int x0,int y0,int x1,int y1,
                           int x2,int y2,int x3, int y3,
                           int color,UCHAR *dest_buffer, int mempitch);

int Translate_Polygon2D(POLYGON2D_PTR poly, int dx, int dy);

int Rotate_Polygon2D(POLYGON2D_PTR poly, int theta);

int Scale_Polygon2D(POLYGON2D_PTR poly, float sx, float sy);

int Set_Palette_Entry(int color_index, LPPALETTEENTRY color);

int Draw_Text_GDI(char *text, int x,int y,int color, LPDIRECTDRAWSURFACE7 lpdds);

// MACROS /////////////////////////////////////////////////

// tests if a key is up or down
#define KEYDOWN(vk_code) ((GetAsyncKeyState(vk_code) & 0x8000) ? 1 : 0)
#define KEYUP(vk_code)   ((GetAsyncKeyState(vk_code) & 0x8000) ? 0 : 1)

// initializes a direct draw struct
#define DDRAW_INIT_STRUCT(ddstruct) { memset(&ddstruct,0,sizeof(ddstruct)); ddstruct.dwSize=sizeof(ddstruct); }

// some math macros
#define DEG_TO_RAD(ang) ((ang)*PI/180)
#define RAD_TO_DEG(rads) ((rads)*180/PI)

// GLOBALS ////////////////////////////////////////////////

HWND      main_window_handle = NULL; // globally track main window
int       window_closed      = 0;    // tracks if window is closed
HINSTANCE hinstance_app      = NULL; // globally track hinstance

// directdraw stuff
LPDIRECTDRAW7         lpdd         = NULL;   // dd object
LPDIRECTDRAWSURFACE7  lpddsprimary = NULL;   // dd primary surface
LPDIRECTDRAWSURFACE7  lpddsback    = NULL;   // dd back surface
LPDIRECTDRAWPALETTE   lpddpal      = NULL;   // a pointer to the created dd palette
LPDIRECTDRAWCLIPPER   lpddclipper  = NULL;   // dd clipper
PALETTEENTRY          palette[256];          // color palette
PALETTEENTRY          save_palette[256];     // used to save palettes
DDSURFACEDESC2        ddsd;                  // a direct draw surface description struct
DDBLTFX               ddbltfx;               // used to fill
DDSCAPS2              ddscaps;               // a direct draw surface capabilities struct
HRESULT               ddrval;                // result back from dd calls
DWORD                 start_clock_count = 0; // used for timing


// global clipping region

int min_clip_x = 0,      // clipping rectangle 
    max_clip_x = SCREEN_WIDTH - 1,
    min_clip_y = 0,
    max_clip_y = SCREEN_HEIGHT - 1;

char buffer[80];                             // general printing buffer

// storage for our lookup tables
float cos_look[360];
float sin_look[360];

POLYGON2D object; // the polygon object

// FUNCTIONS ////////////////////////////////////////////////

inline void Draw_QuadFP_2D(int x0,int y0,
                    int x1,int y1,
                    int x2,int y2,
                    int x3, int y3,
                    int color,
                    UCHAR *dest_buffer, int mempitch)
{
// this function draws a 2D quadrilateral

// simply call the triangle function 2x, let it do all the work
Draw_TriangleFP_2D(x0,y0,x1,y1,x3,y3,color,dest_buffer,mempitch);
Draw_TriangleFP_2D(x1,y1,x2,y2,x3,y3,color,dest_buffer,mempitch);

} // end Draw_QuadFP_2D

////////////////////////////////////////////////////////////////////////////////

void Draw_Top_TriFP(int x1,int y1,
                    int x2,int y2, 
                    int x3,int y3,
                    int color, 
                    UCHAR *dest_buffer, int mempitch)
{
// this function draws a triangle that has a flat top using fixed point math

int dx_right,    // the dx/dy ratio of the right edge of line
    dx_left,     // the dx/dy ratio of the left edge of line
    xs,xe,       // the starting and ending points of the edges
    height;      // the height of the triangle

int temp_x,        // used during sorting as temps
    temp_y,
    right,         // used by clipping
    left;

UCHAR  *dest_addr;

// test for degenerate
if (y1==y3 || y2==y3)
	return;

// test order of x1 and x2
if (x2 < x1)
   {
   temp_x = x2;
   x2     = x1;
   x1     = temp_x;
   } // end if swap

// compute delta's
height = y3-y1;

dx_left  = ((x3-x1)<<FIXP16_SHIFT)/height;
dx_right = ((x3-x2)<<FIXP16_SHIFT)/height;

// set starting points
xs = (x1<<FIXP16_SHIFT);
xe = (x2<<FIXP16_SHIFT);

// perform y clipping
if (y1<min_clip_y)
   {
   // compute new xs and ys
   xs = xs+dx_left*(-y1+min_clip_y);
   xe = xe+dx_right*(-y1+min_clip_y);

   // reset y1
   y1=min_clip_y;

   } // end if top is off screen

if (y3>max_clip_y)
   y3=max_clip_y;

// compute starting address in video memory
dest_addr = dest_buffer+y1*mempitch;

// test if x clipping is needed
if (x1>=min_clip_x && x1<=max_clip_x &&
    x2>=min_clip_x && x2<=max_clip_x &&
    x3>=min_clip_x && x3<=max_clip_x)
    {
    // draw the triangle
    for (temp_y=y1; temp_y<=y3; temp_y++,dest_addr+=mempitch)
        {
        memset((UCHAR *)dest_addr+((xs+FIXP16_ROUND_UP)>>FIXP16_SHIFT),
               color, (((xe-xs+FIXP16_ROUND_UP)>>FIXP16_SHIFT)+1));

        // adjust starting point and ending point
        xs+=dx_left;
        xe+=dx_right;

        } // end for

    } // end if no x clipping needed
else
   {
   // clip x axis with slower version

   // draw the triangle
   for (temp_y=y1; temp_y<=y3; temp_y++,dest_addr+=mempitch)
       {
       // do x clip
       left  = ((xs+FIXP16_ROUND_UP)>>16);
       right = ((xe+FIXP16_ROUND_UP)>>16);

       // adjust starting point and ending point
       xs+=dx_left;
       xe+=dx_right;

       // clip line
       if (left < min_clip_x)
          {
          left = min_clip_x;

          if (right < min_clip_x)
             continue;
          }

       if (right > max_clip_x)
          {
          right = max_clip_x;

          if (left > max_clip_x)
             continue;
          }

       memset((UCHAR  *)dest_addr+(unsigned int)left,
              color,(unsigned int)(right-left+1));

       } // end for

   } // end else x clipping needed

} // end Draw_Top_TriFP

/////////////////////////////////////////////////////////////////////////////

void Draw_Bottom_TriFP(int x1,int y1, 
                       int x2,int y2, 
                       int x3,int y3,
                       int color,
                       UCHAR *dest_buffer, int mempitch)
{

// this function draws a triangle that has a flat bottom using fixed point math

int dx_right,    // the dx/dy ratio of the right edge of line
    dx_left,     // the dx/dy ratio of the left edge of line
    xs,xe,       // the starting and ending points of the edges
    height;      // the height of the triangle

int temp_x,        // used during sorting as temps
    temp_y,
    right,         // used by clipping
    left;

UCHAR  *dest_addr;

if (y1==y2 || y1==y3)
	return;

// test order of x1 and x2
if (x3 < x2)
   {
   temp_x = x2;
   x2     = x3;
   x3     = temp_x;

   } // end if swap

// compute delta's
height = y3-y1;

dx_left  = ((x2-x1)<<FIXP16_SHIFT)/height;
dx_right = ((x3-x1)<<FIXP16_SHIFT)/height;

// set starting points
xs = (x1<<FIXP16_SHIFT);
xe = (x1<<FIXP16_SHIFT); 

// perform y clipping
if (y1<min_clip_y)
   {
   // compute new xs and ys
   xs = xs+dx_left*(-y1+min_clip_y);
   xe = xe+dx_right*(-y1+min_clip_y);

   // reset y1
   y1=min_clip_y;

   } // end if top is off screen

if (y3>max_clip_y)
   y3=max_clip_y;

// compute starting address in video memory
dest_addr = dest_buffer+y1*mempitch;

// test if x clipping is needed
if (x1>=min_clip_x && x1<=max_clip_x &&
    x2>=min_clip_x && x2<=max_clip_x &&
    x3>=min_clip_x && x3<=max_clip_x)
    {
    // draw the triangle
    for (temp_y=y1; temp_y<=y3; temp_y++,dest_addr+=mempitch)
        {
        memset((UCHAR *)dest_addr+((xs+FIXP16_ROUND_UP)>>FIXP16_SHIFT),
                color, (((xe-xs+FIXP16_ROUND_UP)>>FIXP16_SHIFT)+1));

        // adjust starting point and ending point
        xs+=dx_left;
        xe+=dx_right;

        } // end for

    } // end if no x clipping needed
else
   {
   // clip x axis with slower version

   // draw the triangle
   for (temp_y=y1; temp_y<=y3; temp_y++,dest_addr+=mempitch)
       {
       // do x clip
       left  = ((xs+FIXP16_ROUND_UP)>>FIXP16_SHIFT);
       right = ((xe+FIXP16_ROUND_UP)>>FIXP16_SHIFT);

       // adjust starting point and ending point
       xs+=dx_left;
       xe+=dx_right;

       // clip line
       if (left < min_clip_x)
          {
          left = min_clip_x;

          if (right < min_clip_x)
             continue;
          }

       if (right > max_clip_x)
          {
          right = max_clip_x;

          if (left > max_clip_x)
             continue;
          }

       memset((UCHAR *)dest_addr+left,
              color, (right-left+1));

       } // end for

   } // end else x clipping needed

} // end Draw_Bottom_TriFP

////////////////////////////////////////////////////////////////

void Draw_Top_Tri(int x1,int y1, 
                  int x2,int y2, 
                  int x3,int y3,
                  int color, 
                  UCHAR *dest_buffer, int mempitch)
{
// this function draws a triangle that has a flat top

float dx_right,    // the dx/dy ratio of the right edge of line
      dx_left,     // the dx/dy ratio of the left edge of line
      xs,xe,       // the starting and ending points of the edges
      height;      // the height of the triangle

int temp_x,        // used during sorting as temps
    temp_y,
    right,         // used by clipping
    left;

// destination address of next scanline
UCHAR  *dest_addr = NULL;

// test order of x1 and x2
if (x2 < x1)
   {
   temp_x = x2;
   x2     = x1;
   x1     = temp_x;

?? 快捷鍵說(shuō)明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
日韩精品在线看片z| 久久精品国产秦先生| 国产精品久久久久一区二区三区共| 欧美一区二视频| 91麻豆精品国产91久久久 | 精品剧情v国产在线观看在线| 3d动漫精品啪啪1区2区免费| 欧美精品一卡两卡| 欧美一区二区三区在| 精品少妇一区二区三区免费观看| 精品少妇一区二区三区| 国产色婷婷亚洲99精品小说| 国产欧美日韩视频一区二区| 国产精品美女久久久久aⅴ国产馆| 国产精品久久久一区麻豆最新章节| 国产精品欧美精品| 亚洲人成在线播放网站岛国 | 成人动漫在线一区| 99这里都是精品| 日本韩国一区二区| 91精品午夜视频| 26uuu亚洲综合色| 国产精品久久久久一区| 一区二区三区在线影院| 日日摸夜夜添夜夜添国产精品| 免费成人av在线| 成人免费视频一区| 色先锋aa成人| 日韩欧美一二三| 国产精品国产精品国产专区不蜜| 亚洲一区二区三区精品在线| 日本成人在线视频网站| 国产高清精品久久久久| 色视频欧美一区二区三区| 欧美猛男男办公室激情| 久久中文字幕电影| 亚洲色图19p| 男女男精品视频| 成人免费av网站| 欧美一区二区视频在线观看2020| 国产亚洲人成网站| 亚洲国产精品一区二区www在线| 久久成人精品无人区| 99精品国产热久久91蜜凸| 欧美一级专区免费大片| 国产精品高清亚洲| 美国十次综合导航| 91麻豆高清视频| 精品噜噜噜噜久久久久久久久试看| 中文字幕亚洲一区二区av在线 | 久久精品国产精品亚洲红杏| 99这里都是精品| 日韩欧美一级二级三级| 亚洲免费观看高清完整版在线观看 | 不卡的av电影在线观看| 7777精品久久久大香线蕉| 国产农村妇女毛片精品久久麻豆| 亚洲福利视频三区| 国产成人午夜视频| 538在线一区二区精品国产| 欧美国产精品久久| 男人的天堂亚洲一区| 色94色欧美sute亚洲线路一久| 欧美精品一区二区三区蜜桃 | 亚洲色图制服诱惑| 加勒比av一区二区| 欧美日韩日日摸| 亚洲欧洲无码一区二区三区| 九色porny丨国产精品| 在线观看日韩一区| ...xxx性欧美| 国产精品69毛片高清亚洲| 欧美久久婷婷综合色| 亚洲图片另类小说| 国产馆精品极品| 2022国产精品视频| 奇米影视在线99精品| 欧美性做爰猛烈叫床潮| 亚洲视频综合在线| 99久久精品免费| 国产欧美日韩视频一区二区| 精品午夜一区二区三区在线观看| 欧美精品亚洲一区二区在线播放| 亚洲精品日日夜夜| 97se亚洲国产综合自在线观| 国产精品欧美一区喷水| 国产精品一区二区不卡| 欧美成人激情免费网| 日本中文一区二区三区| 欧美日韩亚洲综合一区| 一区二区三区在线不卡| 91偷拍与自偷拍精品| 欧美国产成人在线| 成人动漫一区二区三区| 国产精品色呦呦| 高清不卡在线观看| 欧美激情一区二区| 国产馆精品极品| 日本一区二区三区免费乱视频| 国产经典欧美精品| 国产日韩欧美综合一区| 国产成人免费在线观看| 国产欧美日韩在线观看| 成人一级视频在线观看| 国产精品久线观看视频| 成人av网站免费观看| 国产精品乱人伦一区二区| av一区二区三区| 亚洲欧美国产三级| 在线国产电影不卡| 午夜精品国产更新| 51精品久久久久久久蜜臀| 强制捆绑调教一区二区| 日韩三级av在线播放| 国产一区视频网站| 国产精品嫩草影院av蜜臀| 91视频免费播放| 亚洲国产一区二区在线播放| 在线电影一区二区三区| 国内精品视频666| 国产精品久久久一区麻豆最新章节| 99re这里只有精品首页| 亚洲国产日韩精品| 日韩女优av电影| 懂色av中文一区二区三区| 亚洲欧洲美洲综合色网| 欧美午夜免费电影| 奇米综合一区二区三区精品视频| 26uuu另类欧美| 成人app网站| 亚洲午夜久久久| 日韩精品最新网址| 成人免费精品视频| 五月综合激情婷婷六月色窝| 久久综合狠狠综合| 欧美综合一区二区三区| 麻豆精品一二三| 最近日韩中文字幕| 欧美另类高清zo欧美| 国产精选一区二区三区| 亚洲欧美日本在线| 精品久久久久99| 97精品国产露脸对白| 天堂在线一区二区| 国产区在线观看成人精品| 色婷婷狠狠综合| 久久国产视频网| 亚洲人妖av一区二区| 日韩一区二区三区高清免费看看| 粉嫩绯色av一区二区在线观看| 亚洲午夜国产一区99re久久| 国产午夜亚洲精品羞羞网站| 欧美中文字幕一区二区三区亚洲| 激情另类小说区图片区视频区| 亚洲视频一区二区在线| 日韩欧美区一区二| 在线观看免费亚洲| 国产成人综合网| 日韩影院在线观看| 亚洲精品水蜜桃| 精品欧美黑人一区二区三区| 色综合久久九月婷婷色综合| 精品亚洲国内自在自线福利| 一级日本不卡的影视| 国产女人18水真多18精品一级做| 在线播放欧美女士性生活| 99久久免费视频.com| 久久精品国产一区二区三区免费看| 亚洲精品国产无套在线观| 国产日韩欧美不卡在线| 337p亚洲精品色噜噜狠狠| 91小视频免费看| 国产高清不卡二三区| 日韩av二区在线播放| 一区二区三区在线视频播放| 国产精品午夜春色av| 久久蜜桃av一区精品变态类天堂| 欧美疯狂性受xxxxx喷水图片| 91麻豆123| 成人视屏免费看| 国产馆精品极品| 韩国v欧美v日本v亚洲v| 免费在线观看一区二区三区| 亚洲一区二区高清| 亚洲乱码一区二区三区在线观看| 国产欧美一区视频| 久久午夜老司机| 欧美成人bangbros| 日韩美一区二区三区| 9191精品国产综合久久久久久| 色婷婷激情久久| 91免费国产在线| 97精品久久久久中文字幕 | 久久这里只有精品首页| 日韩欧美在线123| 欧美一区二区在线看| 777亚洲妇女| 日韩一区二区中文字幕| 91精品国产91久久久久久最新毛片| 欧美日韩国产美女|