青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

天行健 君子當自強而不息

一個3D向量類

新建網頁 1 提供以下基本操作:

1.   存取向量的各分量(x, y , z)
2.   向量間的賦值操作
3.   比較兩向量是否相同
4.   將向量置為零向量
5.   向量求負
6.   求向量的模
7.   向量與標量的乘除法
8.   向量標準化
9.   向量加減法
10. 計算兩點(點用向量表示)間距離
11. 向量點乘
12. 向量叉乘

該向量的操作運算對3D點同樣適合。
    #include <math.h>
    
    
class cVector3
    {
    
public:
        
float x, y, z;
    
    
public:
        cVector3() { }
    
        cVector3(
const cVector3& v)
        {    
            x = v.x;    y = v.y;    z = v.z;    
        }
    
        cVector3(
float vx, float vy, float vz)
        {
            x = vx;        y = vy;        z = vz;
        }
    
        cVector3& 
operator=(const cVector3& v)
        {
            x = v.x;    y = v.y;    z = v.z;
    
            
return *this;
        }
    
        
bool operator==(const cVector3& v)
        {
            
return (x == v.x && y == v.y && z == v.z);
        }
    
        
bool operator!=(const cVector3& v)
        {
            
return (x != v.x || y != v.y || z != v.z);
        }
    
        
void zero()
        {
            
// set the vector to zero
    
        x = y = z = 0.0f;
        }
    
        cVector3 
operator-()
        {
            
// unary minus returns the negative of the vector
    
        return cVector3(-x, -y, -z);
        }
    
        cVector3 
operator+(const cVector3& v)
        {
            
return cVector3(x + v.x, y + v.y, z + v.z);
        }
    
        cVector3 
operator-(const cVector3& v)
        {
            
return cVector3(x - v.x, y - v.y, z - v.z);
        }
    
        cVector3 
operator*(float scale)
        {
            
// multiplication and division by scalar
    
        return cVector3(x * scale, y * scale, z * scale);
        }
    
        cVector3 
operator/(float scale)
        {
            
float temp = 1.0f / scale;    // NOTE: no check for divide by zero here
    

            
return cVector3(x * temp, y * temp, z * temp);
        }
    
        cVector3& 
operator+=(const cVector3& v)
        {
            x += v.x;    y += v.y;    z += v.z;
    
            
return *this;
        }
    
        cVector3& 
operator-=(const cVector3& v)
        {
            x -= v.x;    y -= v.y;    z -= v.z;
    
            
return *this;
        }
    
        cVector3& 
operator*=(float scale)
        {
            x *= scale;    y *= scale;    z *= scale;
    
            
return *this;
        }
    
        cVector3& 
operator/=(float scale)
        {
            
float temp = 1.0f / scale;
    
            x *= temp;    y *= temp;    z *= temp;
    
            
return *this;
        }
    
        
void normalize()
        {
            
// normalize the vector
    

            
float mag = x * x + y * y + z * z;
    
            
if(mag > 0.0f)    // check for divide-by-zero
    
        {
                
float one_over_mag = 1.0f / sqrt(mag);
    
                x *= one_over_mag;
                y *= one_over_mag;
                z *= one_over_mag;
            }
        }
    
        
float operator*(const cVector3& v)
        {
            
// vector dot product, we overload the standard multiplication symbol to do this.
    

            
return (x * v.x + y * v.y + z * v.z);
        }
    };
    
    
    /***************************************************************************************************/
    
    inline 
float vector_mag(const cVector3& v)
    {
        
// compute the magnitude of a vector
    
    return sqrt(v.x * v.x + v.y * v.y + v.z * v.z);
    }
    
    inline cVector3 cross_product(
const cVector3& a, const cVector3& b)
    {
        
// compute the cross product of two vectors
    
    return cVector3(a.y * b.z - a.z * b.y, a.z * b.x - a.x * b.z, a.x * b.y - a.y * b.x);
    }
    
    inline cVector3 
operator*(float k, const cVector3& v)
    {
        
// scalar on the left multiplication, for symmetry.
    
    return cVector3(k * v.x, k * v.y, k * v.z);
    }
    
    inline 
float distance(const cVector3& a, const cVector3& b)
    {
        
// compute the distance between two points
    

        
float dx = a.x - b.x;
        
float dy = a.y - b.y;
        
float dz = a.z - b.z;
    
        
return sqrt(dx * dx + dy * dy + dz * dz);
    }
    
    inline 
float distance_squared(const cVector3& a, const cVector3& b)
    {
        
// compute the distance between two points
    

        
float dx = a.x - b.x;
        
float dy = a.y - b.y;
        
float dz = a.z - b.z;
    
        
return (dx * dx + dy * dy + dz * dz);
    }
    
    
extern const cVector3 g_zero_vector;

posted on 2008-01-08 21:58 lovedday 閱讀(1957) 評論(0)  編輯 收藏 引用 所屬分類: ■ 3D Math Basis

公告

導航

統計

常用鏈接

隨筆分類(178)

3D游戲編程相關鏈接

搜索

最新評論

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            99精品久久免费看蜜臀剧情介绍| 国产精品视频网址| 欧美激情aⅴ一区二区三区| 一区二区成人精品| 亚洲福利视频免费观看| 韩国成人精品a∨在线观看| 国产精品一区二区三区四区| 欧美黑人国产人伦爽爽爽| 日韩性生活视频| 亚洲综合精品自拍| 亚洲无限av看| 亚洲视频电影图片偷拍一区| 日韩天堂在线视频| 亚洲九九爱视频| 亚洲毛片在线| 亚洲一区二区三区午夜| 亚洲一区日韩| 欧美亚洲在线| 久久精品免费电影| 老**午夜毛片一区二区三区| 久久午夜羞羞影院免费观看| 久久在线视频| 欧美韩日亚洲| 日韩亚洲在线观看| 亚洲欧美日韩天堂| 久久成人免费日本黄色| 久久久久综合一区二区三区| 久久视频国产精品免费视频在线| 亚洲国产日韩欧美在线图片| 久久人人爽国产| 久久久人成影片一区二区三区| 久久国产精品久久久久久电车| 久久久噜噜噜久久久| 欧美国产日韩一区二区在线观看 | 一区二区三区高清在线| 亚洲视频在线视频| 午夜精品视频| 免费在线亚洲欧美| av成人福利| 欧美在线免费视屏| 欧美jizzhd精品欧美巨大免费| 欧美日韩天堂| 一区免费视频| 1024亚洲| 国产亚洲欧洲一区高清在线观看| 国产亚洲一区二区在线观看| 亚洲国产高潮在线观看| 一区二区三区精品视频| 亚洲在线视频| 欧美国产一区二区| 亚洲欧美日韩一区二区三区在线观看 | 亚洲理论在线观看| 亚洲欧美日韩中文在线制服| 久久精品91久久久久久再现| 欧美精品色网| 精品1区2区3区4区| 欧美亚洲综合久久| 亚洲黄色影院| 午夜视频久久久| 久久综合五月天婷婷伊人| 欧美日韩一级黄| 亚洲国产精品美女| 久久国产精品亚洲va麻豆| 亚洲高清在线播放| 久久精品久久综合| 国产精品少妇自拍| 一区二区三区久久精品| 牛牛精品成人免费视频| 亚洲视频在线观看免费| 欧美精品午夜视频| 亚洲区免费影片| 免费欧美日韩国产三级电影| 欧美亚洲在线| 农村妇女精品| 欧美天堂在线观看| 亚洲精品久久久久久久久| 亚洲精品国产精品国产自| 香蕉久久久久久久av网站| 欧美午夜在线视频| 日韩网站免费观看| 欧美电影电视剧在线观看| 欧美激情视频给我| 久久夜色精品| 狠狠色狠狠色综合日日91app| 亚洲自拍电影| 宅男噜噜噜66国产日韩在线观看| 欧美激情精品久久久久久久变态| 亚洲国产精品久久久久秋霞影院 | 久久在线视频在线| 亚洲高清不卡在线| 欧美在线高清视频| 欧美激情中文字幕一区二区| 久久久精品五月天| 在线免费日韩片| 欧美大片一区二区| 欧美国产免费| 亚洲视频网在线直播| 一区二区三区日韩在线观看 | 99热免费精品| 亚洲老司机av| 国产精品久久午夜夜伦鲁鲁| 性欧美超级视频| 欧美在线播放| 最新高清无码专区| 亚洲乱码精品一二三四区日韩在线 | 亚洲综合视频1区| 亚洲精品一区二区在线| 久久久久久久一区二区三区| 亚洲国产激情| 亚洲日本电影| 国产欧美一区二区在线观看| 久久久精品国产免费观看同学| 久久精品亚洲精品| 亚洲精品老司机| 欧美黄色一区| 国产精品第13页| 久久久777| 欧美精品二区| 久久精品二区亚洲w码| 免费观看30秒视频久久| 精品1区2区3区4区| 一区二区三区视频观看| 黄色成人在线| 亚洲特级毛片| 亚洲黑丝一区二区| 亚洲中字在线| 亚洲美女av电影| 国产欧美日韩一区二区三区在线观看 | 99国产精品自拍| 国产在线乱码一区二区三区| 亚洲国产欧洲综合997久久| 国产精品美女久久久久久2018 | 国产一区二区三区久久 | 影音先锋亚洲视频| 欧美午夜在线| 免费观看一级特黄欧美大片| 国产视频亚洲| 亚洲欧美日韩精品久久久久| 亚洲一区二区三区视频| 欧美日韩一区二区三区在线观看免| 亚洲电影一级黄| 亚洲黄色有码视频| 欧美黑人多人双交| 亚洲精品永久免费精品| 一本色道久久综合亚洲精品高清 | 国产综合亚洲精品一区二| 亚洲欧美电影院| 欧美在线亚洲综合一区| 国产视频自拍一区| 久久精品论坛| 欧美大片在线看免费观看| 亚洲欧洲在线免费| 欧美日韩国产大片| 亚洲性夜色噜噜噜7777| 欧美在线观看网址综合| 国产视频欧美| 欧美h视频在线| 一本色道综合亚洲| 久久九九99| 亚洲人成在线播放| 国产精品久久久久久久久借妻 | 欧美一区二区三区四区高清 | 国产一区二区三区四区在线观看| 欧美一区二区三区视频| 女人天堂亚洲aⅴ在线观看| 亚洲黄色成人久久久| 欧美伦理a级免费电影| 亚洲香蕉伊综合在人在线视看| 免费中文日韩| 久久久91精品| 亚洲精品在线视频| 国产精品jizz在线观看美国| 亚洲欧美日韩国产中文| 欧美国产欧美亚洲国产日韩mv天天看完整 | 欧美有码视频| 1024亚洲| 国产精品sm| 久久免费高清| 亚洲视频狠狠| 欧美xx视频| 午夜精品久久久久| 亚洲黄色成人网| 国产欧美精品在线| 欧美激情亚洲国产| 欧美一区二区视频观看视频| 亚洲精品美女| 另类图片国产| 亚洲女人av| 亚洲免费观看| 在线精品视频免费观看| 国产精品毛片在线看| 免费中文日韩| 欧美专区第一页| 夜夜爽av福利精品导航 | 狠狠网亚洲精品| 国产精品热久久久久夜色精品三区 | 欧美影院久久久| 中文国产成人精品| 亚洲精品中文在线| 在线观看成人av电影|