日韩av黄I国产麻豆传媒I国产91av视频在线观看I日韩一区二区三区在线看I美女国产在线I麻豆视频国产在线观看I成人黄色短片

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

【GAMES101】作业2--三角形光栅化

發布時間:2023/12/16 编程问答 30 豆豆
生活随笔 收集整理的這篇文章主要介紹了 【GAMES101】作业2--三角形光栅化 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

文章目錄

  • 前言
  • 作業要求
    • 額外說明
    • 評分
  • 解答
    • 1 復制粘貼上節課的get_projection_matrix
    • 2 判斷像素點是否在三角形內部insideTriangle
      • 對應知識
      • 對應代碼
    • 3 光柵化
      • 步驟概覽
      • 1. 找到Bounding Box
      • 2. 在Bounding box 內遍歷所有元素,判斷是否在三角形內部
      • 3. 根據已有代碼來得到深度值,也就是z_interpolated
      • 4. 如果當前位置深度比depth_buf更小,則更新顏色值并保存深度值
  • 代碼總結
  • 結果

前言

本文為GAMES101現代計算機圖形學入門 的學習筆記系列。

我們的系列筆記將分為兩部分:

  • 課堂筆記
  • 作業
  • 原課程為2020年2月閆令琪所教授的 GAMES101 現代計算機圖形學入門

    課程主頁:https://sites.cs.ucsb.edu/~lingqi/teaching/games101.html
    (幻燈片和課程錄像均在此處)

    課程共計22節。作業共計8次。

    針對人群:計算機圖形學入門新手

    教材
    Steve Marschner and Peter Shirley的"Fundamentals of Computer Graphics"
    第三版或更新版本。目前無官方中文版。
    民間翻譯:https://www.stubbornhuang.com/1812/

    筆記目錄


    2022-6-9

    作業要求

    在上次作業中,雖然我們在屏幕上畫出一個線框三角形,但這看起來并不是那么的有趣。所以這一次我們繼續推進一步——在屏幕上畫出一個實心三角形,換言之,柵格化一個三角形。上一次作業中,在視口變化之后,我們調用了函數rasterize_wireframe(const Triangle& t)。但這一次,你需要自己填寫并調用函數 rasterize_triangle(const Triangle& t)。

    該函數的內部工作流程如下:

  • 創建三角形的 2 維 bounding box。
  • 遍歷此 bounding box 內的所有像素(使用其整數索引)。然后,使用像素中心的屏幕空間坐標來檢查中心點是否在三角形內。
  • 如果在內部,則將其位置處的插值深度值 (interpolated depth value) 與深度緩沖區 (depth buffer) 中的相應值進行比較。
  • 如果當前點更靠近相機,請設置像素顏色并更新深度緩沖區 (depth buffer)。
  • 你需要修改的函數如下:

    • rasterize_triangle(): 執行三角形柵格化算法
    • static bool insideTriangle(): 測試點是否在三角形內。你可以修改此函數的定義,這意味著,你可以按照自己的方式更新返回類型或函數參數。

    額外說明

    因為我們只知道三角形三個頂點處的深度值,所以對于三角形內部的像素,我們需要用插值的方法得到其深度值。我們已經為你處理好了這一部分,因為有關這方面的內容尚未在課程中涉及。插值的深度值被儲存在量 z_interpolated中。

    請注意我們是如何初始化 depth buffer 和注意 z values 的符號。為了方便同學們寫代碼,我們將 z 進行了反轉,保證都是正數,并且越大表示離視點越遠。

    在此次作業中,你無需處理旋轉變換,只需為模型變換返回一個單位矩陣。最后,我們提供了兩個 hard-coded 三角形來測試你的實現,如果程序實現正確,你將看到如下所示的輸出圖像:

    在你自己的計算機或虛擬機上下載并使用我們更新的框架代碼。你會注意到,在 main.cpp 下的 get_projection_matrix() 函數是空的。請復制粘貼你在第一次作業中的實現來填充該函數。

    評分

    • [5 分] 正確地提交所有必須的文件,且代碼能夠編譯運行。
    • [20 分] 正確實現三角形柵格化算法。
    • [10 分] 正確測試點是否在三角形內。
    • [10 分] 正確實現 z-buffer 算法, 將三角形按順序畫在屏幕上。
    • [提高項 5 分] 用 super-sampling 處理 Anti-aliasing : 你可能會注意到,當我們放大圖像時,圖像邊緣會有鋸齒感。我們可以用 super-sampling來解決這個問題,即對每個像素進行 2 * 2 采樣,并比較前后的結果 (這里并不需要考慮像素與像素間的樣本復用)。需要注意的點有,對于像素內的每一個樣本都需要維護它自己的深度值,即每一個像素都需要維護一個 sample list。最后,如果你實現正確的話,你得到的三角形不應該有不正常的黑邊。

    解答

    我們需要填寫的兩個函數都在rasterize.cpp當中。并且我們需要復制粘貼上一次作業寫的get_projection_matrix。

    我們首先需要寫一個判斷像素點是否在三角形內部的算法。這個函數的返回值就是一個bool變量。這個函數名為static bool insideTriangle()

    rasterize_triangle()函數是用來三角形柵格化的。它分為以下三步:

  • 創建三角形的boundingBox。
  • 在boundingBox內判斷像素點坐標是否在三角形內(利用上面寫的insideTriangle函數)
  • 通過深度插值,從三角形三個頂點的深度值找到每個像素的深度值。(這一點代碼已經被給出)
  • 如果當前位置深度比depth_buf(類rasterizer的一個成員)更小,則更新顏色值。
  • 1 復制粘貼上節課的get_projection_matrix

    我們先復制粘貼get_projection_matrix
    如下

    Eigen::Matrix4f get_projection_matrix(float eye_fov, float aspect_ratio,float zNear, float zFar) {// Students will implement this functionEigen::Matrix4f projection = Eigen::Matrix4f::Identity();// TODO: Implement this function// Create the projection matrix for the given parameters.// Then return it.// 1. 透視投影轉為正交投影矩陣float n = zNear;float f = zFar;Eigen::Matrix4f M_persp2Ortho;M_persp2Ortho << n, 0, 0, 0,0, n, 0, 0,0, 0, n + f, -n * f,0, 0, 1, 0;// 2. 正交投影轉換到正則立方體float fov = eye_fov * MY_PI / 180.0;float t = -n * tan(fov / 2.);float b = -t;float r = aspect_ratio * t;float l = -r;Eigen::Matrix4f M_ortho, trans, scale;trans << 1, 0, 0, -(r+l)/2,0, 1, 0, -(t+b)/2,0, 0, 1, -(n+f)/2,0, 0, 0, 1;scale << 2/(r-l), 0, 0, 0,0, 2/(t-b), 0, 0,0, 0, 2/(n-f), 0,0, 0, 0, 1;M_ortho = scale * trans;projection = M_ortho * M_persp2Ortho ;return projection; }

    2 判斷像素點是否在三角形內部insideTriangle

    題目中給出的API如下

    static bool insideTriangle(int x, int y, const Vector3f* _v) { // TODO : Implement this function to check if the point (x, y) is inside the triangle represented by _v[0], _v[1], _v[2] }

    我們接受一個x,接受一個y,這代表了當前點的像素編號(整數)。接受一個向量引用 _v,這代表了三角形的三個頂點坐標。

    對應知識

    課堂筆記2–向量與線性代數

    對應代碼

    static bool insideTriangle(float x, float y, const Vector3f* _v) { // TODO : Implement this function to check if the point (x, y) is inside the triangle represented by _v[0], _v[1], _v[2]const Eigen::Vector2f P(x, y);const Eigen::Vector2f A = _v[0].head(2), B = _v[1].head(2), C = _v[2].head(2);const Eigen::Vector2f AP = P - A;const Eigen::Vector2f BP = P - B;const Eigen::Vector2f CP = P - C;const Eigen::Vector2f AB = B - A;const Eigen::Vector2f BC = C - B;const Eigen::Vector2f CA = A - C;float eq1 = AB[0] * AP[1] - AB[1] * AP[0];float eq2 = BC[0] * BP[1] - BC[1] * BP[0]; float eq3 = CA[0] * CP[1] - CA[1] * CP[0];if( eq1 > 0 && eq2 > 0 && eq3>0)return true;else if(eq1 < 0 && eq2<0 && eq3<0)return true;else return false; }

    注意以下幾點:

  • 應該注意const Vector3f* _v這個參數
    這個參數是一個Vector3f指針,實際上代表的是一個數組。數組中的每個元素是一個Vector3f類型,
    也就是代表了一個頂點的坐標。每個點用_v[0],_v[1],_v[2]表示。而每個_v[0]就是一個Vector3f類型的點。整個數組代表了多個點。這里一般認為傳入的是三個點,即一個三角形。

  • 注意我們做的是2D模擬,因此只是傳入了x、y坐標。而Vector3f是一個3D的坐標,因此我們只使用它的前兩個坐標。在Eigen當中就是使用.head(2)函數

  • 二維的向量對于Eigen來說是無法做叉乘的。Eigen只支持三維叉乘。所以我們要手動寫叉乘。
    a×b=(a1,a2)T×(b1,b2)T=a1b2?a2b1a\times b = (a1, a2)^T \times (b1, b2)^T \\ = a1b2 - a2 b1 a×b=(a1,a2)T×(b1,b2)T=a1b2?a2b1
    請注意,上面的寫法是不嚴謹的,因為叉乘是不改變張量的階的。向量叉乘,得到的應該還是向量。所以這里只是表示了大小,而沒有表示方向。實際上,方向是指向垂直于紙面(向外或者內)。如果想要嚴謹地寫出來,只需要把第三個分量寫為0,然后按照3D向量叉乘公式(也就是行列式),如下,寫出來即可。你會發現只剩下了k基矢的項。

  • 3 光柵化

    步驟概覽

    上文說到

    rasterize_triangle()函數是用來三角形柵格化的。它分為以下4步:

  • 創建三角形的boundingBox。
  • 在boundingBox內判斷像素點坐標是否在三角形內(利用上面寫的insideTriangle函數)
  • 通過深度插值,從三角形三個頂點的深度值找到每個像素的深度值。(這一點代碼已經被給出)
  • 如果當前位置深度比depth_buf(類rasterizer的一個成員)更小,則更新顏色值。
  • 我們依次來做這四步(其中第三步已經被寫好了)

    1. 找到Bounding Box

    怎么找呢?其實就是找三角形的x坐標和y坐標的最大最小值而已!
    比如下面這張圖
    我們的bounding box就是所在范圍的9個格子。

    對應的代碼就是

    //1. 找到Bounding Boxfloat xmin = std::min(std::min(v[0].x(), v[1].x()), v[2].x());float ymin = std::min(std::min(v[0].y(), v[1].y()), v[2].y());float xmax = std::max(std::max(v[0].x(), v[1].x()), v[2].x());float ymax = std::max(std::max(v[0].y(), v[1].y()), v[2].y());

    注意:根據課堂筆記6–光柵化(深度測試與抗鋸齒),其實坐標值和整數編號值只是差了0.5

    我們找bounding box,是為了接下來做for循環遍歷。所以假如找到的是float類型的,不那么方便循環。因為坐標值和整數編號值只是差了0.5,所以我們就往外拓展一點點boundingbox。如下面的代碼所示。

    //我們將bounding box稍微擴大一點,得到整數值,方便循環xmin = (int)std::floor(xmin);xmax = (int)std::ceil(xmax);ymin = (int)std::floor(ymin);ymax = (int)std::ceil(ymax);

    2. 在Bounding box 內遍歷所有元素,判斷是否在三角形內部

    這一步很簡單,就是寫兩個for循環,然后再利用第一步寫了的insideTriangle函數來判斷

    //2. 在Bounding box 內遍歷所有元素,判斷是否在三角形內部for (int x = xmin; x <= xmax; x++){for (int y = ymin ; y <= ymax; y++){//像素的坐標值只是比整數編號值大0.5而已。if (insideTriangle(x + 0.5, y + 0.5, t.v)){

    我們這里唯一要注意的,就是insideTriangle函數的使用方法

    這個函數接收三個參數,前兩個就是坐標值的x,y而已。剛才已經說了,坐標值就是像素編號+0.5而已。

    第三個參數實際上是一個數組,這個數組的每個元素都是一個3維Vector3f類型的點。

    我們現在所擁有的參數,是const Triangle& t,這是一個三角形,是代碼框架自定義的類型。它的類型定義位于Triangle.hpp

    class Triangle{public:Vector3f v[3]; /*the original coordinates of the triangle, v0, v1, v2 in counter clockwise order*/... };

    我們只要看它的第一個成員變量,叫做v,它恰好是一個數組,數組的每個元素是個Vector3f的點。這就對應上我們需要的參數。

    3. 根據已有代碼來得到深度值,也就是z_interpolated

    直接取消注釋已有的代碼即可

    //3.根據已有代碼來得到深度值,也就是z_interpolated // If so, use the following code to get the interpolated z value.auto [alpha, beta, gamma] = computeBarycentric2D(x, y, t.v);float w_reciprocal = 1.0 / (alpha / v[0].w() + beta / v[1].w() + gamma / v[2].w());float z_interpolated = alpha * v[0].z() / v[0].w() + beta * v[1].z() / v[1].w() + gamma * v[2].z() / v[2].w();z_interpolated *= w_reciprocal;

    這一步的目的,就是把三角形三個頂點的深度值插值成三角形內每個像素點的深度值

    4. 如果當前位置深度比depth_buf更小,則更新顏色值并保存深度值

    很簡單,假如該點當前的深度值比buffer中的更小,就更新顏色,并且保存新的深度值。

    這就是z-buffer算法。這個算法很簡單,其實就是尋找最小值而已。找到了最小值,就覆蓋原來的最小值,并且更新顏色。depth_buf保存的就是原來的最小值。

    //4. 如果當前位置深度比depth_buf(類rasterizer的一個成員)更小,則更新顏色值。if (z_interpolated < depth_buf[get_index(x, y)]){//TODO : set the current pixel (use the set_pixel function) to the color of the triangle (use getColor function) if it should be painted.set_pixel(Vector3f(x, y, z_interpolated), t.getColor());depth_buf[get_index(x, y)] = z_interpolated;}

    我們這里要注意2點:

  • depth_buf的使用方法。
    depth_buf是自定義的Triangle類型的一個成員變量。
  • std::vector<float> depth_buf;

    它就是個一維浮點數數組而已。使用方法就是用數組下標。但是這里要注意了:我們的像素編號是兩個(x和y),所以要先把它轉換成一個。轉換的方法通俗易懂,就是一行行地排排坐,排完一行再排一行。從左到右,從上到下。

    如圖所示

    甚至代碼框架里面已經給你寫好了轉換的函數

    int rst::rasterizer::get_index(int x, int y) {return (height-1-y)*width + x; }

    這里的height和width也是整數。實際上,由于OpenCV也許是從左上到右下排列的,所以它可能用的是(height-1-y)。這里就是把數字轉換一下。

    但是這些都不用我們操心,我們只要使用get_index函數就行了。

  • set_pixel的使用方法
  • void rst::rasterizer::set_pixel(const Eigen::Vector3f& point, const Eigen::Vector3f& color)

    它接收兩個參數,第一個就是點坐標,第二個就是RGB顏色。

    第一個參數我們就給當前像素點的坐標即可,Vector3f(x, y, z_interpolated)
    第二個參數,我們就給t.getColor()

    class Triangle{public:Vector3f v[3]; /*the original coordinates of the triangle, v0, v1, v2 in counter clockwise order*//*Per vertex values*/Vector3f color[3]; //color at each vertex;...Vector3f getColor() const { return color[0]*255; } // Only one color per triangle.... };

    這個函數就是Triangle所需要繪制的顏色值。

    代碼總結

    第一個函數

    static bool insideTriangle(float x, float y, const Vector3f* _v) { // TODO : Implement this function to check if the point (x, y) is inside the triangle represented by _v[0], _v[1], _v[2]const Eigen::Vector2f P(x, y);const Eigen::Vector2f A = _v[0].head(2), B = _v[1].head(2), C = _v[2].head(2);const Eigen::Vector2f AP = P - A;const Eigen::Vector2f BP = P - B;const Eigen::Vector2f CP = P - C;const Eigen::Vector2f AB = B - A;const Eigen::Vector2f BC = C - B;const Eigen::Vector2f CA = A - C;float eq1 = AB[0] * AP[1] - AB[1] * AP[0];float eq2 = BC[0] * BP[1] - BC[1] * BP[0]; float eq3 = CA[0] * CP[1] - CA[1] * CP[0];if( eq1 > 0 && eq2 > 0 && eq3>0)return true;else if(eq1 < 0 && eq2<0 && eq3<0)return true;else return false; }

    第二個函數

    //Screen space rasterization void rst::rasterizer::rasterize_triangle(const Triangle& t) {auto v = t.toVector4();// TODO : Find out the bounding box of current triangle.// iterate through the pixel and find if the current pixel is inside the triangle//1. 找到Bounding Boxfloat xmin = std::min(std::min(v[0].x(), v[1].x()), v[2].x());float ymin = std::min(std::min(v[0].y(), v[1].y()), v[2].y());float xmax = std::max(std::max(v[0].x(), v[1].x()), v[2].x());float ymax = std::max(std::max(v[0].y(), v[1].y()), v[2].y());//我們將bounding box稍微擴大一點,得到整數值,方便循環xmin = (int)std::floor(xmin);xmax = (int)std::ceil(xmax);ymin = (int)std::floor(ymin);ymax = (int)std::ceil(ymax);//2. 在Bounding box 內遍歷所有元素,判斷是否在三角形內部for (int x = xmin; x <= xmax; x++){for (int y = ymin ; y <= ymax; y++){//像素的坐標值只是比整數編號值大0.5而已。if (insideTriangle(x + 0.5, y + 0.5, t.v)){//3.根據已有代碼來得到深度值,也就是z_interpolated // If so, use the following code to get the interpolated z value.auto [alpha, beta, gamma] = computeBarycentric2D(x, y, t.v);float w_reciprocal = 1.0 / (alpha / v[0].w() + beta / v[1].w() + gamma / v[2].w());float z_interpolated = alpha * v[0].z() / v[0].w() + beta * v[1].z() / v[1].w() + gamma * v[2].z() / v[2].w();z_interpolated *= w_reciprocal;//4. 如果當前位置深度比depth_buf(類rasterizer的一個成員)更小,則更新顏色值。if (z_interpolated < depth_buf[get_index(x, y)]){//TODO : set the current pixel (use the set_pixel function) to the color of the triangle (use getColor function) if it should be painted.set_pixel(Vector3f(x, y, z_interpolated), t.getColor());depth_buf[get_index(x, y)] = z_interpolated;}}}} }

    結果

    總結

    以上是生活随笔為你收集整理的【GAMES101】作业2--三角形光栅化的全部內容,希望文章能夠幫你解決所遇到的問題。

    如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。

    国产精品女教师 | 中文字幕二区 | 国产精品成人在线观看 | 免费视频 你懂的 | 69绿帽绿奴3pvideos | 天天曰天天曰 | 亚洲成av人电影 | 欧美精彩视频在线观看 | 高清av免费看| 婷婷在线色| 欧美孕妇视频 | 高清色免费 | 在线看一区二区 | 91视频国产免费 | 国产亚洲一区二区在线观看 | 久久综合九色综合欧美狠狠 | 日本乱码在线 | 在线观看黄网站 | 欧美日韩久久不卡 | 午夜国产在线观看 | 国产一级片网站 | 日韩激情第一页 | 久久久首页 | 成人午夜电影久久影院 | 在线va网站 | 在线看国产 | 日本美女xx | 天天天天综合 | 免费看的av片 | 九九在线高清精品视频 | 日本精品va在线观看 | 精品久久久久免费极品大片 | 国产96在线观看 | 91福利视频网站 | 婷婷色综合 | 天天av在线播放 | 国产精品毛片网 | 九九九电影免费看 | 亚洲成人av影片 | 丁香六月婷婷激情 | 综合五月| www.91成人 | 日本最大色倩网站www | 婷婷电影在线观看 | 中文字幕观看在线 | 亚洲精品字幕 | 欧美日韩免费一区二区三区 | 国产免费又爽又刺激在线观看 | 99热这里只有精品在线观看 | 四虎最新域名 | 欧美日韩高清不卡 | 精品亚洲男同gayvideo网站 | 91精品视频在线 | 国产成人黄色网址 | 玖玖色在线观看 | 亚洲最大成人网4388xx | 久久久久久久久网站 | 国产一区二区在线精品 | 99久国产| 欧美激情精品久久久久久免费 | avove黑丝| 视频在线观看入口黄最新永久免费国产 | 欧洲在线免费视频 | 国产精品成人在线观看 | 国产99久久久精品 | 97麻豆视频 | 久久艹免费 | 中文字幕一区在线 | 亚洲1区在线| 国产美女视频免费 | 日韩欧美在线一区 | 丁香六月天 | 亚洲精品国产日韩 | 中文字幕在线网 | 久久免费激情视频 | 福利视频网址 | 亚洲日韩中文字幕 | 精品一区在线 | 91在线文字幕 | 国产69精品久久99不卡的观看体验 | 日本久久久久久久久久久 | 中文字幕 国产视频 | 中国黄色一级大片 | 中文字幕日本在线 | 在线精品视频在线观看高清 | 中文字幕一区二区三区久久蜜桃 | 欧美色图亚洲图片 | 狠狠操.com | 亚洲欧美视频 | 9999精品视频 | 亚洲伊人av | 国产精品成人aaaaa网站 | 欧美精品三级在线观看 | 天天爱天天操天天干 | 国产精品久久久久久久久大全 | 91精品视屏 | 黄色大片入口 | 91麻豆.com | 不卡国产在线 | 国产高清不卡 | 国产在线精品播放 | 天天操天天干天天综合网 | 亚洲精品视频在线观看网站 | 毛片永久新网址首页 | 99色网站| 久久久久女教师免费一区 | 欧美日韩在线精品 | 四虎在线观看精品视频 | 国产三级在线播放 | 精品一区二区免费在线观看 | 视频一区亚洲 | 香蕉网在线观看 | 狠狠色丁香久久婷婷综合五月 | 丰满少妇麻豆av | 首页av在线 | 婷婷性综合 | 日日干天天干 | 人人狠狠综合久久亚洲 | 国产婷婷视频在线 | 99热在线这里只有精品 | 久久久亚洲麻豆日韩精品一区三区 | 亚洲综合色丁香婷婷六月图片 | 一区二区三区四区在线免费观看 | 国产专区欧美专区 | 深爱激情五月婷婷 | 日本精品免费看 | 欧美analxxxx| www免费看片com | 91色在线观看 | 一区二区三区四区五区在线视频 | 欧美五月婷婷 | 人人爽久久涩噜噜噜网站 | av超碰免费在线 | 奇米影视在线99精品 | 黄色小网站免费看 | avwww在线 | 国产一级高清视频 | 色综合久久天天 | 日日夜夜天天综合 | 狠狠干我| 国产精彩视频一区二区 | 五月婷婷中文网 | 久久看片 | 国产在线精品一区二区三区 | 亚洲第一伊人 | 六月丁香婷婷网 | 色哟哟国产精品 | 96精品视频 | 一区二区中文字幕在线播放 | 91精品伦理| av中文字幕网 | 不卡av在线| 久久视精品 | 尤物一区二区三区 | 久久免费a| 亚洲黄色av | 久久国产精品影视 | 91av资源在线| 欧美久草在线 | 国产福利一区二区三区视频 | 国产亚洲视频在线 | 黄p在线播放 | 网址你懂的在线观看 | 午夜影视一区 | 2019精品手机国产品在线 | 免费观看一级成人毛片 | 日韩在线观看不卡 | www.com.黄| 成人网在线免费视频 | 欧美日韩视频在线 | 亚洲午夜精品久久久久久久久久久久 | 免费a网 | 色资源在线观看 | 午夜电影一区 | 免费亚洲视频在线观看 | 国产精品原创视频 | www.com在线观看 | 国产黄色精品在线 | 久久精品麻豆 | 亚洲成a人片在线观看网站口工 | 午夜电影av | 久久精品国产免费看久久精品 | 2019天天干天天色 | 91综合久久一区二区 | 中文在线a∨在线 | 成人免费在线观看av | 最新av在线网站 | 深夜成人av| 婷婷久久一区二区三区 | 日韩大片免费观看 | 国产精品 中文字幕 亚洲 欧美 | 天天爽人人爽夜夜爽 | av大全在线免费观看 | 国产大陆亚洲精品国产 | 成人丁香花 | 不卡的av中文字幕 | 久久九九久久精品 | 伊人色综合网 | 四虎影视成人永久免费观看亚洲欧美 | 日日夜夜精品 | 激情综合啪啪 | 又黄又爽又无遮挡的视频 | 欧美日韩国产一区二区在线观看 | 亚洲视频 中文字幕 | 国产精品久久久久久a | 大片网站久久 | 中文字幕在线看人 | 99久久精品免费看 | 亚洲一区视频免费观看 | 美女黄频在线观看 | 成人av观看 | 中文在线字幕免 | 亚洲91视频 | 91av小视频| 国产拍在线 | 欧美日韩在线网站 | 深爱五月激情网 | 色天天 | 欧美日韩国产网站 | 狠狠狠色丁香综合久久天下网 | 国产精品涩涩屋www在线观看 | 婷婷丁香综合 | 九九热在线精品 | 亚洲成免费 | 丁香花在线视频观看免费 | 精品国产成人 | 日韩精品免费在线播放 | 国产精品久久久久久久久久久久午夜片 | 日韩特黄一级欧美毛片特黄 | 欧美乱淫视频 | 超碰99人人| 在线成人短视频 | 看国产黄色大片 | 国产美女精品 | 日韩美女久久 | 国产精品一区二区在线观看 | 国产日韩视频在线 | 92国产精品久久久久首页 | 午夜精品一区二区三区免费 | 久久成人毛片 | 国产视频在线观看一区 | 日韩精品无 | 青草视频在线 | www.久草.com | 国际精品网 | 91自拍视频在线 | 97成人精品区在线播放 | 亚洲精品一区二区在线观看 | 中文字幕久久亚洲 | 成人在线播放视频 | 激情开心色 | 一级性视频 | 91亚洲免费 | 日韩成人免费观看 | 亚洲欧洲精品一区二区精品久久久 | 一级淫片在线观看 | 天天插天天射 | 在线观看韩日电影免费 | 在线播放精品一区二区三区 | 久久精品3 | 精品免费一区二区三区 | 日本护士三级少妇三级999 | 一区二区视频在线免费观看 | 日韩另类在线 | 一区二区三区精品在线 | 久久精品播放 | 91福利试看 | 激情婷婷综合 | 精品欧美一区二区三区久久久 | 中文成人字幕 | 少妇bbw揉bbb欧美 | 国产精品网在线观看 | 精品国产一区二区三区久久久蜜月 | 精品视频在线播放 | 99久久精品久久久久久动态片 | 九九久久视频 | 亚洲成人av一区二区 | 99精品国产在热久久 | 狠狠狠色丁香婷婷综合久久五月 | 国产精品美女www爽爽爽视频 | 国产在线资源 | 亚洲永久精品视频 | 欧美一区免费在线观看 | 天天色影院 | 久久三级视频 | 国产精品一区二区电影 | 天天色 天天 | 一级全黄毛片 | 国产成人亚洲在线观看 | 日韩精品在线看 | 日韩免费在线网站 | 狠狠做六月爱婷婷综合aⅴ 日本高清免费中文字幕 | 黄色电影网站在线观看 | 成人精品福利 | 爱爱一区| 国产特级毛片 | 久久久国产精品麻豆 | 欧美精品一区二区三区四区在线 | 中文久草 | 六月婷操 | 精品国产资源 | 激情片av| 夜色.com| 成人在线播放免费观看 | 日韩欧美成 | 国产一级大片免费看 | 91精品视频免费看 | 免费看的国产视频网站 | 免费麻豆 | 一级黄色片网站 | 日韩免费视频网站 | 精品国产综合区久久久久久 | 伊香蕉大综综综合久久啪 | 国产999免费视频 | 激情av五月婷婷 | 欧美亚洲精品一区 | 国产精品永久免费视频 | 免费视频一区二区 | 国产精品男女啪啪 | 国产高清av免费在线观看 | 国产一级电影免费观看 | 九九热免费观看 | 五月开心婷婷网 | 欧美午夜寂寞影院 | 婷婷网五月天 | 亚洲国产精品资源 | 国产精品99久久久久久武松影视 | 天天拍天天操 | 色婷婷成人网 | 亚洲一级理论片 | 日韩黄色在线观看 | 久草亚洲视频 | 日韩a级免费视频 | 国产在线视频在线观看 | 精品伦理一区二区三区 | 99视频99| 久久国产精品一区二区 | 992tv在线成人免费观看 | 亚洲综合小说电影qvod | 人人干人人草 | 国产精品一区二区三区四 | 国产不卡毛片 | 天天天干天天射天天天操 | 91大神在线观看视频 | 日本在线观看一区二区 | 亚州精品天堂中文字幕 | 三级黄色片在线观看 | 色婷婷久久久综合中文字幕 | av观看网站| 高清中文字幕av | 国产精品黄色影片导航在线观看 | 日韩色综合网 | 丰满少妇对白在线偷拍 | 91最新网址 | 91视频高清 | 国产最新视频在线 | 91精品导航 | 日韩激情精品 | 91在线最新| 91成人在线免费观看 | 亚洲精品免费在线播放 | 国内精品久久久久久久久 | 国产美女无遮挡永久免费 | 91.精品高清在线观看 | 综合色伊人 | 欧美日韩在线免费观看 | 国产精品久久久久国产精品日日 | 亚洲精品国产品国语在线 | 中文av不卡 | 天天爽夜夜爽精品视频婷婷 | 精品视频99 | 国产精品一区在线观看你懂的 | 在线观看中文字幕av | 免费在线91 | 色中文字幕在线观看 | 国产免费人人看 | 亚洲免费在线播放视频 | 国产少妇在线观看 | 久久最新视频 | 香蕉97视频观看在线观看 | 国产精品免费久久 | 国产一区免费视频 | 国产免费又爽又刺激在线观看 | 国产美女精品视频免费观看 | 日韩精品不卡在线 | 久久精品高清视频 | 99亚洲国产 | 91精品无人成人www | 午夜视频在线观看一区二区三区 | 日韩理论影院 | 狠狠操狠狠插 | 综合网伊人| 97成人在线观看视频 | 欧美老女人xx | 久久久久久久久网站 | 天天干天天怕 | 国产精品欧美日韩 | 欧洲色吧| 激情综合网天天干 | 亚洲国产一区二区精品专区 | 激情五月综合 | 黄网站www | 欧美精品一区二区三区四区在线 | 91视频最新网址 | 国产在线精品一区二区 | 亚洲欧美国产精品18p | 久草在线高清视频 | 欧美激情h | 久久精品日本啪啪涩涩 | 91九色最新 | 91av视频网站 | 久爱精品在线 | 992tv在线观看 | 亚洲黄色一级电影 | 久久午夜精品视频 | 超碰在线观看99 | av中文字幕在线免费观看 | 成人免费xxx在线观看 | 91在线蜜桃臀| 在线亚洲天堂网 | 丁香国产视频 | 波多野结衣一区二区 | 黄污视频网站大全 | 色爽网站 | 久草视频在线新免费 | 不卡电影免费在线播放一区 | 午夜免费电影院 | 韩国在线视频一区 | 欧美日韩精品在线观看 | 亚洲电影av在线 | 色五丁香| 中文字幕欧美日韩va免费视频 | 中文字幕人成乱码在线观看 | 亚洲欧洲一区二区在线观看 | 日本99干网 | 欧美色精品天天在线观看视频 | 麻豆传媒精品 | 国产精品久久久久永久免费 | 亚洲国产中文字幕 | 久久99久国产精品黄毛片入口 | 天天爽夜夜爽精品视频婷婷 | 日本丰满少妇免费一区 | 在线蜜桃视频 | 午夜.dj高清免费观看视频 | 超碰人人在线观看 | 玖玖在线精品 | 91麻豆精品国产自产在线 | 1000部国产精品成人观看 | 人人爽人人舔 | 精品国自产在线观看 | 欧美亚洲成人免费 | 天天插天天爱 | 在线免费黄色av | 6080yy精品一区二区三区 | 夜夜躁日日躁狠狠久久av | 在线欧美最极品的av | 91麻豆精品国产自产在线游戏 | 精品国产观看 | 在线成人观看 | 久久久久久高潮国产精品视 | 4p变态网欧美系列 | 97在线观看免费 | 久久亚洲私人国产精品 | 日韩91在线 | 99久久9 | 欧美一级小视频 | a级成人毛片 | 人人涩 | 亚洲国产欧美在线人成大黄瓜 | 亚洲最新视频在线 | 黄色片网站大全 | 免费看国产精品 | 久久综合成人 | 亚洲亚洲精品在线观看 | 午夜精品一区二区三区四区 | 少妇bbw揉bbb欧美 | 东方av免费在线观看 | 日韩av成人在线观看 | 91精品国产91久久久久久三级 | 国产黄在线看 | 国产成a人亚洲精v品在线观看 | 日韩欧美在线免费观看 | av三区在线 | 欧美精品国产精品 | 丁香婷婷激情国产高清秒播 | 国产一区高清在线观看 | 欧美另类z0zx | 国产99色 | 麻花豆传媒mv在线观看 | 国产精品 中文字幕 亚洲 欧美 | 99久久精品免费看国产麻豆 | 黄色a级片在线观看 | 成人久久| 日韩免费福利 | 国产尤物在线 | 视色网站| 欧美精品久久久久久久久老牛影院 | 亚洲国产欧美在线人成大黄瓜 | 中文字幕亚洲不卡 | 国产精品久99 | 在线国产黄色 | 男女精品久久 | 麻豆视频国产 | 最近中文字幕高清字幕免费mv | 97超碰成人在线 | 亚洲最新在线视频 | 色婷婷影视 | 日批在线看 | 欧美一二区在线 | 国产视频精品在线 | a特级毛片 | 97色婷婷| 亚洲理论电影 | 91精品国产91 | 99精品国产福利在线观看免费 | 91欧美日韩国产 | 国产成人一区二区三区久久精品 | 亚洲欧美精品一区二区 | 久久久久久毛片精品免费不卡 | 奇米网在线观看 | 日本精品视频在线播放 | 成人av电影在线 | 天天色播 | 国偷自产视频一区二区久 | 成人福利在线观看 | 欧美亚洲免费在线一区 | 激情五月六月婷婷 | 久久草视频 | 成人h动漫在线看 | 波多野结衣日韩 | 午夜视频一区二区三区 | av电影在线免费观看 | 五月天亚洲综合 | av在线免费观看不卡 | 国产日韩精品一区二区三区在线 | 97超级碰碰碰碰久久久久 | 91在线一区二区 | 手机版av在线 | 欧美一级欧美一级 | 亚洲精选在线观看 | 在线欧美中文字幕 | 伊人久久国产 | 97超级碰| 一区二区三区电影大全 | 久久久久国产精品免费免费搜索 | 在线成人国产 | 日韩videos高潮hd | 97在线视 | 国精产品满18岁在线 | 国产精品大片在线观看 | 97在线观看免费视频 | 久久精品亚洲 | 国产在线成人 | 成人小视频在线观看免费 | 91在线国产观看 | 狠狠色丁香婷婷综合橹88 | 亚洲精品国产精品国 | 综合中文字幕 | 91资源在线免费观看 | 在线 影视 一区 | 91视频在线免费看 | av片子在线观看 | 欧美电影黄色 | 日韩视频中文字幕 | 国产一区精品在线 | 黄色一级大片在线免费看国产一 | 久久精久久精 | 久久九九精品 | 国产传媒中文字幕 | 国产+日韩欧美 | 一级黄色电影网站 | 欧美成人免费在线 | 99视频在线观看一区三区 | 色婷婷综合激情 | 国产日本高清 | 国产精品va在线 | 欧美一区二区三区激情视频 | 婷婷九月丁香 | 91亚洲欧美激情 | 四虎成人免费影院 | 一级一片免费看 | 天天综合网 天天 | 中文字幕在线观看亚洲 | 9999精品 | 99视频在线看 | av免费片 | 在线中文字幕av观看 | 欧美激情操 | 国产免费视频一区二区裸体 | 国产成人一区二区三区在线观看 | 99国产一区| 一级片免费观看视频 | 五月婷婷另类国产 | 成人av地址| 婷婷夜夜 | 超碰免费观看 | 精品在线播放 | 日韩中文字幕网站 | 亚洲区二区 | 亚州精品视频 | 天天操夜| 久久99国产精品自在自在app | 国产一区二区不卡视频 | 久草视频一区 | 97在线观看免费视频 | 久久电影国产免费久久电影 | 国产精品成久久久久 | 日本中文字幕电影在线免费观看 | www天天干com| 天天爱天天插 | 国内小视频| av网站大全免费 | 五月天久久激情 | 日日碰狠狠添天天爽超碰97久久 | 日韩欧美精品在线 | 精品久久久久一区二区国产 | 国内三级在线观看 | 精品久久精品 | 国产在线播放一区二区三区 | 国产精品久久久久久久电影 | 在线观看黄网 | 欧美亚洲一级片 | 久草视频在线资源站 | 91精品国自产在线 | 天天插天天干 | 天天曰 | 91精品人成在线观看 | 久久久这里有精品 | 99精品免费久久久久久久久 | 欧美在线你懂的 | 国产精品黄网站在线观看 | 久草视频在线免费 | 久久精品国产亚洲 | 99久久精品视频免费 | 国产高清黄| 免费视频成人 | 91免费国产在线观看 | 亚洲精品视频网站在线观看 | av一区二区在线观看中文字幕 | 丁香电影小说免费视频观看 | 国产精品色婷婷视频 | 日日干激情五月 | 亚洲高清国产视频 | 国产精品69av | 在线探花| 狠狠色狠狠色综合系列 | 国产一区在线免费 | 久久综合久久综合这里只有精品 | 亚洲jizzjizz日本少妇 | 一区三区在线欧 | 91精品老司机久久一区啪 | 欧美国产一区在线 | 精品视频免费在线 | 国产精品不卡在线播放 | 三级免费黄 | 国产精品久久久久久久7电影 | 亚洲一区 影院 | 91爱爱免费观看 | 日韩av在线网站 | 亚洲精品伦理在线 | 在线视频 日韩 | 在线草| 国产精品视频线看 | 91九色精品女同系列 | 成人久久亚洲 | 日韩高清av | 肉色欧美久久久久久久免费看 | 精品在线观看免费 | 精品国产一区二区三区久久久 | 日韩精品一区二区三区中文字幕 | 日韩在线视频观看免费 | 九九热在线观看视频 | 福利一区视频 | 伊人黄色网 | 国产精品欧美久久 | 日韩一级电影网站 | 国产精品一区二区在线观看 | 久久九九影视 | 亚洲一区尤物 | 人人草在线视频 | 天天干天天操天天做 | 久久只精品99品免费久23小说 | 成年人免费在线观看网站 | 久草精品电影 | 久久国产精品99精国产 | 国产69精品久久99的直播节目 | 99视频+国产日韩欧美 | 91字幕| 黄色精品网站 | 久久久精品久久 | 国产1区在线 | 日批网站免费观看 | 99资源网 | 一区二区三区国产欧美 | 日韩欧美一区二区在线播放 | 欧美黑人性爽 | 不卡精品| 五月天中文字幕 | 中文字幕一区三区 | 91.dizhi永久地址最新 | 天天射天天色天天干 | 91完整版观看 | 天天久久综合 | 免费高清在线一区 | 中文字幕在线一二 | a极黄色片| 中日韩免费视频 | 三上悠亚一区二区在线观看 | 欧美污污视频 | 中文字幕有码在线观看 | 欧美美女视频在线观看 | 久久黄色免费视频 | 免费男女羞羞的视频网站中文字幕 | 一本色道久久精品 | 国产一区二区三区在线 | 99久久国产免费看 | 久久精品视频在线观看免费 | 日韩在线视频不卡 | 欧美一级特黄aaaaaa大片在线观看 | 九九九九热精品免费视频点播观看 | www.黄色片.com | 在线观看成人网 | 丁香六月婷婷开心 | 久久国产成人午夜av影院宅 | 狠狠狠色 | 国产成人精品亚洲a | 丁香五月亚洲综合在线 | 国产精品一区二区三区在线看 | 992tv在线成人免费观看 | 日韩欧美精品在线观看 | 最新国产在线观看 | 婷婷久久丁香 | 国产在线97 | 色综合久久88色综合天天人守婷 | 中文字幕日韩伦理 | 一本一道久久a久久精品蜜桃 | 五月花激情 | 色狠狠综合天天综合综合 | 国产成人亚洲在线观看 | 美女啪啪图片 | 欧美一区免费在线观看 | 亚洲专区免费观看 | 91九色成人| 91av在线国产 | 福利视频 | 精品999 | 97超碰中文字幕 | 午夜在线国产 | 亚洲天堂va | 欧美日韩精品免费观看 | 日本在线中文在线 | 日韩精品视频免费在线观看 | 国产日本在线播放 | 国产手机在线精品 | 亚洲在线网址 | 精品国产一区二区三区久久久蜜月 | 色之综合网 | 在线观看成人一级片 | 成人h在线播放 | 日韩av视屏在线观看 | 日本中文字幕在线 | 中文字幕在线观看网 | 日本成人中文字幕在线观看 | 国产精品99久久久久 | 日韩欧美一区二区不卡 | 国产亚洲片 | 97在线视| 精品国产不卡 | 欧美在线91 | 国产又粗又猛又色 | 这里只有精彩视频 | 国产精品免费久久久久久 | 婷婷丁香久久五月婷婷 | 久久久久久综合 | 最新国产中文字幕 | 日批视频在线 | 人人玩人人添人人澡超碰 | 狠狠操狠狠干2017 | 欧洲黄色片 | 丁香激情五月婷婷 | 97香蕉久久国产在线观看 | 麻豆传媒在线视频 | 久久夜夜夜 | 国产精品欧美久久 | 国产精品va最新国产精品视频 | 超碰97在线看| 美国av片在线观看 | 欧美电影在线观看 | 欧美日韩中文字幕在线视频 | 国产在线国偷精品产拍免费yy | 国产成人香蕉 | 亚洲欧美日韩在线一区二区 | 成人一区二区在线 | 国产精品精品久久久久久 | 日韩精品一区二区免费视频 | 中文字幕在线看视频国产中文版 | 狠狠色狠狠色合久久伊人 | 手机看片久久 | 久久这里只有精品23 | 国内免费久久久久久久久久久 | 综合色中文 | 色一级片| 婷婷九月丁香 | 欧美一级片在线 | 国产真实在线 | 久久99国产精品免费网站 | 欧美三级在线播放 | 天天射天天干天天插 | 久久艹综合 | 国产精久久久久久久 | 中文字幕乱偷在线 | 国产精品免费大片视频 | 久久福利国产 | 日韩另类在线 | 日韩三级免费观看 | 99成人在线视频 | 伊人午夜 | 久久久久久高清 | 玖操| 久久久国产网站 | 在线视频 影院 | 日韩精品一区在线播放 | 日韩乱色精品一区二区 | 欧美有色| 久久久久久久久久久电影 | 欧美国产精品一区二区 | 午夜av色| 久久久综合 | 久久网站av| 色偷偷88888欧美精品久久 | 国产精品毛片一区视频播不卡 | 99视频在线精品 | 国产三级午夜理伦三级 | 亚洲综合激情网 | 99久久99 | 久草成人在线 | 精品亚洲视频在线观看 | japanesexxxxfreehd乱熟 | 亚洲欧美国产日韩在线观看 | 欧美成人a在线 | 欧美日韩国产精品爽爽 | 婷婷久久网 | av高清不卡| 成年人在线免费看 | 中文字幕av一区二区三区四区 | 色国产精品 | 不卡的av电影在线观看 | 亚洲国产丝袜在线观看 | 高清av中文字幕 | 91免费试看| 欧美日韩国产免费视频 | 国产成人av一区二区三区在线观看 | 一区二区久久 | 色婷婷视频| 国产精品久久久久久久午夜片 | 日日夜夜天天干 | 最新av电影网址 | 亚洲热久久 | 久久国产二区 | 特级西西人体444是什么意思 | 毛片888 | 深爱五月激情五月 | 欧美有色| 在线观看国产麻豆 | 免费观看一区二区三区视频 | 久久久久久久久黄色 | 精品一区精品二区高清 | 国产精品久久久久久妇 | 免费视频黄 | 亚洲六月丁香色婷婷综合久久 | 免费看污在线观看 | 人人爽人人爽人人 | 欧洲亚洲国产视频 | 欧美日韩高清一区二区 国产亚洲免费看 | 黄色一级影院 | 欧美日韩一区二区视频在线观看 | 婷婷成人在线 | 日韩理论电影在线 | 色av资源网| 天天操天天射天天爽 | 日本久热| 在线观看www. | 中文字幕国产亚洲 | 999国产 | 四虎国产精品免费观看视频优播 | 久久国际影院 | 成 人 黄 色视频免费播放 | 毛片永久新网址首页 | 国产在线观看午夜 | 中文字幕文字幕一区二区 | 国产精品国产精品 | 超级碰碰免费视频 | 91精品国自产在线观看欧美 | 成人a视频在线观看 | 国产99久久九九精品 | 888av| 天天操天天色天天 | 久久国产色 | 五月天中文在线 | 91视频在线播放视频 | 亚洲 中文 欧美 日韩vr 在线 | 日韩欧美有码在线 | 免费影视大全推荐 | 美女网站在线免费观看 | 激情婷婷色 | 在线观看岛国 | 一区二区视频在线观看免费 | 午夜影院一级片 | av免费在线网站 | 久草在线这里只有精品 | 国产精品欧美一区二区三区不卡 | 日韩com| 久久久受www免费人成 | 999成人 | 国产99久久精品一区二区300 | 69av久久 | 久久久久久久久久久久久9999 | 丁香婷婷电影 | 久久久久久免费网 | 免费国产在线观看 | 久久激情小视频 | 色老板在线 | 久久视精品| 丁香婷婷久久久综合精品国产 | 国产一级精品绿帽视频 | 色婷婷色| 91视频在线看 | 亚洲精品在线看 | 久久久久福利视频 | 超级碰碰视频 | 又大又硬又黄又爽视频在线观看 | 成人国产精品一区 | 日韩av不卡播放 | 手机av在线网站 | 激情亚洲综合在线 | 中文字幕黄网 | 97免费在线观看视频 | 99久久精品日本一区二区免费 | 精品国产一二三 | 久久伦理电影网 | 偷拍精品一区二区三区 | 欧美精品一区在线 | 国产精品美女久久 | 天天色天天搞 | 久久久久久久久久毛片 | 国产精品99免视看9 国产精品毛片一区视频 | 午夜 久久 tv | 国产中文字幕国产 | 久久日韩精品 | 成年人国产精品 | 成人av免费在线观看 | 国产色婷婷在线 | 毛片基地黄久久久久久天堂 | 亚洲精品视频在线 | 91亚洲影院 | www.五月天激情 | 综合久久婷婷 | 狠狠躁夜夜躁人人爽视频 | 久久婷亚洲五月一区天天躁 | 人人看人人做人人澡 | 亚洲专区 国产精品 | 亚洲一级性 | 1024手机看片国产 | 九九久久久久久久久激情 | 欧美日韩精品电影 | 中文久久精品 | 嫩草av在线 | 欧美 日韩 国产 成人 在线 | 中文字幕在线观看网 | 成人黄色毛片视频 | 超碰999 | av电影不卡在线 | 99国产精品久久久久久久久久 | 国产黄色片网站 | 中文字幕电影网 | 成人毛片久久 | av片中文| 午夜久久久久久久久久影院 | 香蕉久草 | 超碰电影在线观看 | av色图天堂网 | 日韩和的一区二在线 | 一级性视频| 国产成人黄色网址 | 日韩在线视频一区 | 99av国产精品欲麻豆 | 91视频免费网址 | www.夜夜草 | 欧美不卡视频在线 | 二区三区毛片 | 91香蕉视频黄色 | 成人国产在线 | 国产香蕉视频在线观看 | 国产成人免费观看久久久 | 免费黄色网址大全 | 国产精品一区一区三区 | 成人在线电影观看 | 玖玖视频在线 |