亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 學院 > 開發設計 > 正文

drawRect的繪制的使用(繪制文本字符、繪制圖片、繪制圖形)

2019-11-06 09:56:29
字體:
來源:轉載
供稿:網友

通過重寫UIView的drawRect方法進行繪制使用,如繪制文本字符、繪制圖片、繪制圖形等。

在iOS中使用drawRect繪圖一般分為以下5個步驟:1、獲取繪圖上下文CGContextRef context = UIGraphicsGetCurrentContext();2、創建并設置路徑3、將路徑添加到上下文如:線寬、線條顏色、填充顏色等4、設置上下文狀態CGContextAddLines(context, points, 2);或線CGContextAddLineToPoint(context, 10.0, 10.0);或圓CGContextAddEllipseInRect(context, CGRectZero);CGContextAddArc(context, 10.0, 10.0, (60.0 * M_PI / 180.0), (120.0 * M_PI / 180.0), 1); 或弧CGContextAddArcToPoint(context, 10.0, 200.0, 300.0, 200.0, 100.0);或二次曲線CGContextAddQuadCurveToPoint(context, 50.0, 80.0, 200.0, 10.0);或三次曲線 CGContextAddCurveToPoint(context, 250, 280, 250, 400, 280.0, 300.0);5、繪制路徑CGContextDrawPath(context, kCGPathFillStroke);或CGContextStrokePath(context);6、釋放路徑CGPathRelease(path);

注意事項:

1、設置frame的屬性,或調用setNeedsDisplay時才會調用drawRect方法。

2、在繪制過程中

(1)針對實際情況獲取圖形上下文

CGContextRef context = UIGraphicsGetCurrentContext();

(2)有時候,還需要在獲取圖形上下文之前,設置開始圖形上下文;在使用后,設置關閉圖形上下文

UIGraphicsBeginImageContextWithOptions(rect.size, NO, 0.0); // 開始圖形上下文CGContextRef context = UIGraphicsGetCurrentContext();// coding...UIGraphicsEndImageContext(); // 關閉上下文

3、

1、繪制文本

- (void)drawRect:(CGRect)rect{    NSString *text = @"devZhang is an iOS developer.iOS開發者 iOS開發者 iOS開發者 iOS開發者 iOS開發者";    // 文本段落樣式    NSMutableParagraphStyle *textStyle = [[NSMutableParagraphStyle alloc] init];    textStyle.lineBreakMode = NSLineBreakByWordWrapping; // 結尾部分的內容以……方式省略 ( "...wxyz" ,"abcd..." ,"ab...yz")    textStyle.alignment = NSTextAlignmentLeft; //(兩端對齊的)文本對齊方式:(左,中,右,兩端對齊,自然)    textStyle.lineSpacing = 5; // 字體的行間距    textStyle.firstLineHeadIndent = 5.0; // 首行縮進    textStyle.headIndent = 0.0; // 整體縮進(首行除外)    textStyle.tailIndent = 0.0; //    textStyle.minimumLineHeight = 20.0; // 最低行高    textStyle.maximumLineHeight = 20.0; // 最大行高    textStyle.paragraphSpacing = 15; // 段與段之間的間距    textStyle.paragraphSpacingBefore = 22.0f; // 段首行空白空間/* Distance between the bottom of the PRevious paragraph (or the end of its paragraphSpacing, if any) and the top of this paragraph. */    textStyle.baseWritingDirection = NSWritingDirectionLeftToRight; // 從左到右的書寫方向(一共??三種)    textStyle.lineHeightMultiple = 15; /* Natural line height is multiplied by this factor (if positive) before being constrained by minimum and maximum line height. */    textStyle.hyphenationFactor = 1; //連字屬性 在iOS,唯一支持的值分別為0和1    // 文本屬性    NSMutableDictionary *textAttributes = [[NSMutableDictionary alloc] init];    // NSParagraphStyleAttributeName 段落樣式    [textAttributes setValue:textStyle forKey:NSParagraphStyleAttributeName];    // NSFontAttributeName 字體名稱和大小    [textAttributes setValue:[UIFont systemFontOfSize:12.0] forKey:NSFontAttributeName];    // NSForegroundColorAttributeNam 顏色    [textAttributes setValue:[UIColor redColor] forKey:NSForegroundColorAttributeName];    // 繪制文字    [text drawInRect:rect withAttributes:textAttributes];}

2、繪制圖片

// 繪制圖片- (void)drawRect:(CGRect)rect{    CGContextRef context = UIGraphicsGetCurrentContext();    // 保存初始狀態    CGContextSaveGState(context);    // 圖形上下文移動{x,y}    CGContextTranslateCTM(context, 50.0, 30.0);    // 圖形上下文縮放{x,y}    CGContextScaleCTM(context, 0.8, 0.8);    // 旋轉    CGContextRotateCTM(context, M_PI_4 / 4);         // 繪制圖片    NSString *imagePath = [[NSBundle mainBundle] pathForResource:@"girl" ofType:@"jpg"];    UIImage *image = [[UIImage alloc] initWithContentsOfFile:imagePath];        CGRect rectImage = CGRectMake(0.0, 0.0, rect.size.width, (rect.size.width * image.size.height / image.size.width));        // 圓角圖片設置//    UIGraphicsBeginImageContextWithOptions(rect.size, NO, 0.0); // 開始圖形上下文//    CGContextRef ctx = UIGraphicsGetCurrentContext(); // 獲得圖形上下文//    CGRect rectNew = CGRectMake(0, 0, rect.size.width, rect.size.height); // 設置一個范圍//    CGContextAddEllipseInRect(ctx, rect); // 根據一個rect創建一個橢圓//    CGContextClip(ctx); // 裁剪//    [image drawInRect:rectNew]; // 將原照片畫到圖形上下文//    image = UIGraphicsGetImageFromCurrentImageContext(); // 從上下文上獲取剪裁后的照片//    UIGraphicsEndImageContext(); // 關閉上下文        // 繪制圖片    // 1 圖片可能顯示不完整//    [image drawAtPoint:CGPointMake(0, 0)];        // 2 在rect范圍內完整顯示圖片-正常使用    [image drawInRect:rectImage];        // 3 圖片上下顛倒了//    CGContextRef context = UIGraphicsGetCurrentContext();//    CGContextDrawImage(context, rectImage, image.CGImage);        // 4 圖片上下顛倒了-n個顯示//    CGContextRef context = UIGraphicsGetCurrentContext();//    CGContextDrawTiledImage(context, rectImage, image.CGImage);        // 恢復到初始狀態    CGContextRestoreGState(context);}

3、繪制圖形

(1)菱形、矩形、正方形

- (void)drawRect:(CGRect)rect{        CGContextRef context = UIGraphicsGetCurrentContext();        // 畫一個菱形-實線帶邊框,帶填充    // 邊框    CGContextSetLineWidth(context, 2.0);    CGContextSetStrokeColorWithColor(context, [UIColor magentaColor].CGColor);    // 方法1 菱形起點-終點//    CGContextMoveToPoint(context, 10.0, 80.0);//    CGContextAddLineToPoint(context, 60.0, 10.0);//    CGContextAddLineToPoint(context, 110.0, 80.0);//    CGContextAddLineToPoint(context, 60.0, 150.0);//    CGContextAddLineToPoint(context, 10.0, 80.0);    // 方法2 菱形起點-終點    CGPoint points[5] = {CGPointMake(10.0, 80.0), CGPointMake(60.0, 10.0), CGPointMake(110.0, 80.0), CGPointMake(60.0, 150.0), CGPointMake(10.0, 80.0)};    CGContextAddLines(context, points, 5);    // 填充    CGContextSetFillColorWithColor(context, [UIColor greenColor].CGColor);    // 繪制路徑及填充模式    CGContextDrawPath(context, kCGPathFillStroke);        // 畫一個菱形-虛線帶邊框,無填充    CGContextSetLineWidth(context, 1.0);    CGContextSetStrokeColorWithColor(context, [UIColor redColor].CGColor);    CGFloat dashArray[] = {4, 4}; // 表示先畫1個點再畫4個點(前者小后者大時,虛線點小且間隔大;前者大后者小時,虛線點大且間隔?。?   CGContextSetLineDash(context, 1, dashArray, 2); // 其中的2表示dashArray中的值的個數    // 菱形起點-終點    CGPoint pointsStroke[5] = {CGPointMake(120.0, 80.0), CGPointMake(170.0, 10.0), CGPointMake(220.0, 80.0), CGPointMake(170.0, 150.0), CGPointMake(120.0, 80.0)};    CGContextAddLines(context, pointsStroke, 5);    // 方法1 繪制路徑及填充模式//    CGContextDrawPath(context, kCGPathStroke);    // 方法2 繪制路徑    CGContextStrokePath(context);        // 畫一個菱形-無邊框,帶填充    CGContextSetFillColorWithColor(context, [UIColor yellowColor].CGColor);    // 菱形起點-終點    CGPoint pointsFill[5] = {CGPointMake(230.0, 80.0), CGPointMake(260.0, 10.0), CGPointMake(290.0, 80.0), CGPointMake(260.0, 150.0), CGPointMake(230.0, 80.0)};    CGContextAddLines(context, pointsFill, 5);    // 方法1 繪制路徑及填充模式    CGContextDrawPath(context, kCGPathFill);        // 通過frame的寬高區分正方形,矩形    // 畫一個正方形-帶邊框,帶填充    // 邊框    CGContextSetLineWidth(context, 2.0);    CGContextSetStrokeColorWithColor(context, [UIColor redColor].CGColor);    // 正方形起點-終點    CGPoint pointsRect[5] = {CGPointMake(10.0, 160.0), CGPointMake(60.0, 160.0), CGPointMake(60.0, 210.0), CGPointMake(10.0, 210.0), CGPointMake(10.0, 160.0)};    CGContextAddLines(context, pointsRect, 5);    // 填充    CGContextSetFillColorWithColor(context, [UIColor yellowColor].CGColor);    // 繪制路徑及填充模式    CGContextDrawPath(context, kCGPathFillStroke);        // 畫一個正方形-帶邊框,無填充    // 邊框    CGContextSetLineWidth(context, 1.0);    CGContextSetStrokeColorWithColor(context, [UIColor blueColor].CGColor);    // 方法1 正方形起點-終點//    CGPoint pointsRect2[5] = {CGPointMake(70.0, 160.0), CGPointMake(120.0, 160.0), CGPointMake(120.0, 210.0), CGPointMake(70.0, 210.0), CGPointMake(70.0, 160.0)};//    CGContextAddLines(context, pointsRect2, 5);    // 方法2//    CGContextAddRect(context, CGRectMake(70.0, 160.0, 50.0, 50.0));    // 方法3    CGContextStrokeRect(context, CGRectMake(70.0, 160.0, 50.0, 50.0));    // 方法1 繪制路徑及填充模式//    CGContextDrawPath(context, kCGPathStroke);    // 方法2 繪制路徑    CGContextStrokePath(context);        // 畫一個正方形-無邊框,帶填充    CGContextSetFillColorWithColor(context, [UIColor yellowColor].CGColor);    // 方法1 填充//    CGContextFillRect(context, CGRectMake(130.0, 160.0, 50.0, 50.0));    // 方法2    CGContextAddRect(context, CGRectMake(130.0, 160.0, 50.0, 50.0));    CGContextDrawPath(context, kCGPathFill);            // 畫一個矩形-帶邊框,帶填充    // 邊框    CGContextSetLineWidth(context, 2.0);    CGContextSetStrokeColorWithColor(context, [UIColor brownColor].CGColor);    // 矩形起點-終點    CGPoint pointsRectangle[5] = {CGPointMake(10.0, 220.0), CGPointMake(80.0, 220.0), CGPointMake(80.0, 270.0), CGPointMake(10.0, 270.0), CGPointMake(10.0, 220.0)};    CGContextAddLines(context, pointsRectangle, 5);    // 填充    CGContextSetFillColorWithColor(context, [UIColor orangeColor].CGColor);    // 繪制路徑及填充模式    CGContextDrawPath(context, kCGPathFillStroke);        // 畫一個矩形-帶邊框,無填充    // 邊框    CGContextSetLineWidth(context, 1.0);    CGContextSetStrokeColorWithColor(context, [UIColor greenColor].CGColor);    // 方法1 正方形起點-終點//    CGPoint pointsRect2[5] = {CGPointMake(90.0, 220.0), CGPointMake(160.0, 220.0), CGPointMake(160.0, 270.0), CGPointMake(90.0, 270.0), CGPointMake(90.0, 220.0)};//    CGContextAddLines(context, pointsRect2, 5);    // 方法2//    CGContextAddRect(context, CGRectMake(90.0, 220.0, 70.0, 50.0));    // 方法3    CGContextStrokeRect(context, CGRectMake(90.0, 220.0, 70.0, 50.0));    // 方法1 繪制路徑及填充模式//    CGContextDrawPath(context, kCGPathStroke);    // 方法2 繪制路徑    CGContextStrokePath(context);            // 畫一個矩形-無邊框,帶填充    CGContextSetFillColorWithColor(context, [UIColor purpleColor].CGColor);    // 方法1 填充//    CGContextFillRect(context, CGRectMake(170.0, 220.0, 70.0, 50.0));    // 方法2    CGContextAddRect(context, CGRectMake(170.0, 220.0, 70.0, 50.0));    CGContextDrawPath(context, kCGPathFill);}

(2)圓形、橢圓形、扇形

// 橢圓形,或圓形,扇形- (void)drawRect:(CGRect)rect{    CGContextRef context = UIGraphicsGetCurrentContext();        // 背景顏色設置    [[UIColor yellowColor] set];    CGContextFillRect(context, rect);            // 設置長寬,區分橢圓或圓    CGRect rectRing = CGRectMake(10.0, 10.0, (rect.size.width - 10.0 * 2), 100.0);        // 實線橢圓    CGContextSetLineWidth(context, 1.0);    CGContextSetStrokeColorWithColor(context, [UIColor blueColor].CGColor);    CGContextAddEllipseInRect(context, rectRing);    CGContextDrawPath(context, kCGPathStroke);        // 虛線橢圓    rectRing = CGRectMake(10.0, 120.0, (rect.size.width - 10.0 * 2), 100.0);    CGFloat dashArray[] = {2, 6};    CGContextSetLineDash(context, 1, dashArray, 2);    CGContextSetLineWidth(context, 1.0);    CGContextSetStrokeColorWithColor(context, [UIColor redColor].CGColor);    CGContextAddEllipseInRect(context, rectRing);    CGContextDrawPath(context, kCGPathStroke);        // 實線圓-有邊框,無填充    rectRing = CGRectMake(10.0, 230.0, 80.0, 80.0);    CGContextSetLineWidth(context, 1.0);    CGContextSetStrokeColorWithColor(context, [UIColor blueColor].CGColor);    CGContextAddEllipseInRect(context, rectRing);    CGContextDrawPath(context, kCGPathStroke);        // 實線圓-有邊框,有填充    // 邊框    CGContextSetLineWidth(context, 2.0);    CGContextSetStrokeColorWithColor(context, [UIColor greenColor].CGColor);    // 填充    CGContextSetFillColorWithColor(context, [UIColor purpleColor].CGColor);// 填充顏色    CGContextAddArc(context, 140.0, 270.0, 40.0, 0, 2 * M_PI, 0); // 添加一個圓{x,y}中心點位置    // kCGPathFill填充非零繞數規則,kCGPathEOFill表示用奇偶規則,kCGPathStroke路徑,kCGPathFillStroke路徑填充,kCGPathEOFillStroke描線    CGContextDrawPath(context, kCGPathFillStroke);        // 實線圓-無邊框,有填充    rectRing = CGRectMake(190.0, 230.0, 80.0, 80.0);    CGContextAddEllipseInRect(context, rectRing);    [[UIColor orangeColor] set];    CGContextFillPath(context);                // 扇形    // 實線-有邊框,有填充    // 邊框    CGContextSetLineWidth(context, 2.0);    CGContextSetStrokeColorWithColor(context, [UIColor greenColor].CGColor);    CGContextMoveToPoint(context, 50.0, 380.0);    // 填充    CGContextSetFillColorWithColor(context, [UIColor purpleColor].CGColor);// 填充顏色    CGContextAddArc(context, 50.0, 380.0, 60.0, (-60 * M_PI / 180), (-120 * M_PI / 180), 1); // 添加一個圓{x,y}中心點位置    CGContextClosePath(context);    // kCGPathFill填充非零繞數規則,kCGPathEOFill表示用奇偶規則,kCGPathStroke路徑,kCGPathFillStroke路徑填充,kCGPathEOFillStroke描線    CGContextDrawPath(context, kCGPathFillStroke);}

(3)實線、虛線

- (void)drawRect:(CGRect)rect{    CGContextRef context = UIGraphicsGetCurrentContext();        // 畫實線 方法1    // 線條寬    CGContextSetLineWidth(context, 1.0);    // 線條顏色    CGContextSetRGBStrokeColor(context, 1.5, 0.0, 0.0, 1.0); // 方法1//    CGContextSetStrokeColorWithColor(context, [UIColor blueColor].CGColor); // 方法2    // 坐標點數組    CGPoint aPoints[2];    aPoints[0] = CGPointMake(10.0, 20.0);    aPoints[1] = CGPointMake((rect.size.width - 10.0), 20.0);    // 添加線 points[]坐標數組,和count大小    CGContextAddLines(context, aPoints, 2);    // 根據坐標繪制路徑    CGContextDrawPath(context, kCGPathStroke);            // 畫實線 方法2    // 線條寬    CGContextSetLineWidth(context, 5.0);    // 線條顏色    CGContextSetStrokeColorWithColor(context, [UIColor blueColor].CGColor);    // 起點坐標    CGContextMoveToPoint(context, 10.0, 40.0);    // 終點坐標    CGContextAddLineToPoint(context, (rect.size.width - 10.0), 40.0);    // 繪制路徑    CGContextStrokePath(context);        // 畫虛線    // 線條寬    CGContextSetLineWidth(context, 2.0);    // 線條顏色    CGContextSetStrokeColorWithColor(context, [UIColor greenColor].CGColor);    // 虛線    CGFloat dashArray[] = {1, 4}; // 表示先畫1個點再畫4個點(前者小后者大時,虛線點小且間隔大;前者大后者小時,虛線點大且間隔?。?   CGContextSetLineDash(context, 1, dashArray, 2); // 其中的2表示dashArray中的值的個數    // 起點    CGContextMoveToPoint(context, 10.0, 60.0);    // 終點    CGContextAddLineToPoint(context, (rect.size.width - 10.0), 60.0);    // 繪制路徑    CGContextStrokePath(context);}

(4)曲線、弧線

- (void)drawRect:(CGRect)rect{    CGContextRef context = UIGraphicsGetCurrentContext();        // 繪制貝塞爾曲線    // 二次曲線    CGContextSetLineWidth(context, 2.0);    CGContextSetStrokeColorWithColor(context, [UIColor orangeColor].CGColor);    // 起點    CGContextMoveToPoint(context, 10.0, 10.0);    // 設置貝塞爾曲線的控制點坐標{cp1x,cp1y} 終點坐標{x,y}    CGContextAddQuadCurveToPoint(context, (rect.size.width / 2), 80.0, (rect.size.width - 10.0), 10.0);    // 繪制前設置顏色    // 方法1-只有邊框顏色//    [[UIColor blueColor] setStroke];//    CGContextStrokePath(context);    // 方法2-邊框和填充顏色    [[UIColor blueColor] setStroke];    [[UIColor yellowColor] setFill];    CGContextDrawPath(context, kCGPathFillStroke);                // 三次曲線    CGContextSetLineWidth(context, 2.0);    CGContextSetStrokeColorWithColor(context, [UIColor greenColor].CGColor);    // 起點    CGContextMoveToPoint(context, 10.0, 200.0);    // 設置貝塞爾曲線的控制點坐標{cp1x,cp1y} 控制點坐標{cp2x,cp2y} 終點坐標{x,y}    CGContextAddCurveToPoint(context, 100.0, 0.0, 200.0, 300.0, (rect.size.width - 10.0), 100.0);    // 繪制前設置顏色    // 方法1-只有邊框顏色//    [[UIColor blueColor] setStroke];//    CGContextStrokePath(context);    // 方法2-邊框和填充顏色    [[UIColor greenColor] setStroke];    [[UIColor yellowColor] setFill];    CGContextDrawPath(context, kCGPathFillStroke);}

(5)漸變背景顏色

// 漸變- (void)drawRect:(CGRect)rect{    CGContextRef context = UIGraphicsGetCurrentContext();        CGContextClip(context);    CGColorSpaceRef rgb = CGColorSpaceCreateDeviceRGB();    CGFloat colors[] = {        204.0 / 255.0, 224.0 / 255.0, 244.0 / 255.0, 1.00,        29.0 / 255.0, 156.0 / 255.0, 215.0 / 255.0, 1.00,        0.0 / 255.0,  50.0 / 255.0, 126.0 / 255.0, 1.00,    };    CGGradientRef gradient = CGGradientCreateWithColorComponents(rgb, colors, NULL, sizeof(colors) / (sizeof(colors[0]) * 4));    CGColorSpaceRelease(rgb);    CGContextDrawLinearGradient(context, gradient, CGPointMake(0.0,0.0), CGPointMake(0.0, rect.size.height),    kCGGradientDrawsBeforeStartLocation);}


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
欧美激情视频三区| 亚洲综合中文字幕在线观看| 精品国产91乱高清在线观看| 亚洲精品有码在线| 中文字幕亚洲情99在线| 欧美在线影院在线视频| 欧美日韩第一页| 国产精品尤物福利片在线观看| 国内成人精品视频| 国产精品av电影| 欧美裸身视频免费观看| 久久人人爽国产| 国产一区二区丝袜| 亚洲国产精品va在线| 日韩欧美在线播放| 国产成人精品国内自产拍免费看| xxxxxxxxx欧美| 日韩av在线看| 欧美成人网在线| 久国内精品在线| 国产手机视频精品| 国产91精品在线播放| 丝袜一区二区三区| 欧美在线视频一二三| 亚洲精品综合久久中文字幕| 精品国产91久久久久久老师| 91视频国产精品| 久久久精品国产一区二区| 国产精品最新在线观看| 久久97精品久久久久久久不卡| 国产精品视频午夜| 国产精品男人的天堂| 日韩在线www| 在线观看欧美日韩| 亚洲石原莉奈一区二区在线观看| 亚洲少妇激情视频| 国产精品一区二区久久精品| 97婷婷大伊香蕉精品视频| 亚洲国产精品久久| 国产免费一区二区三区在线观看| 国产欧美亚洲视频| 91久久国产婷婷一区二区| 国产精品吴梦梦| 欧美性色19p| 在线电影中文日韩| 日韩av网站在线| 最近2019免费中文字幕视频三| 国产成人精品在线| 久久精品视频va| 亚洲欧美制服中文字幕| 欧美激情亚洲综合一区| 国产综合福利在线| 国产精品爱啪在线线免费观看| 国产成人综合久久| 日韩a**中文字幕| 亚洲欧美在线播放| 成人精品网站在线观看| 国产性色av一区二区| www日韩中文字幕在线看| 欧美成人午夜剧场免费观看| 国产亚洲a∨片在线观看| 亚洲午夜久久久影院| 国产91色在线| 91国产精品视频在线| 亚洲欧美国产精品| 最近更新的2019中文字幕| 亚洲色图日韩av| 黑人精品xxx一区| 自拍偷拍亚洲一区| 亚洲人成77777在线观看网| 亚洲国产精品久久久久秋霞蜜臀| 精品少妇v888av| 久久91精品国产| 91夜夜未满十八勿入爽爽影院| 国产精品中文字幕在线| 色无极亚洲影院| 国产亚洲精品va在线观看| 久久久久久久色| 久久精品国产亚洲7777| 国产成人一区二区三区电影| 久久精品中文字幕一区| 国产亚洲精品日韩| 久久久久久国产免费| 国产精品美女久久| 97在线观看免费| 欧美电影在线播放| 亚洲美女喷白浆| 国外日韩电影在线观看| 国语自产精品视频在线看抢先版图片| 亚洲精品日韩激情在线电影| 日韩一区二区三区在线播放| 成人美女av在线直播| 亚洲欧美日韩国产成人| 日韩久久免费电影| 在线免费观看羞羞视频一区二区| 国产精品一区二区久久国产| 91亚洲精品一区| 国产亚洲aⅴaaaaaa毛片| 国产精品九九久久久久久久| 精品呦交小u女在线| 夜色77av精品影院| 国产91精品高潮白浆喷水| 久久精品人人做人人爽| 高清欧美一区二区三区| 欧美激情久久久| 亚洲天堂免费观看| 中文字幕亚洲无线码在线一区| 国产精品免费网站| 91久久久久久久久久| 青青青国产精品一区二区| 国产美女精品视频| 日韩精品在线观看视频| 亚洲乱码国产乱码精品精天堂| 两个人的视频www国产精品| 久久久久久噜噜噜久久久精品| 亚洲国产精品热久久| 欧美专区在线视频| 一区二区福利视频| 538国产精品一区二区在线| 国产精品一区二区久久| 亚洲精品日韩在线| 亚洲精品日韩欧美| 欧美国产日韩一区二区三区| 成人中文字幕+乱码+中文字幕| 国产综合香蕉五月婷在线| 92看片淫黄大片欧美看国产片| 亚洲欧美制服丝袜| xxxxxxxxx欧美| 国产国语videosex另类| 国产91精品高潮白浆喷水| 中文字幕亚洲欧美在线| 欧美激情精品久久久久| 清纯唯美亚洲综合| 久久精品国产免费观看| 中文字幕国产精品久久| 日韩精品视频在线免费观看| 欧美成人午夜激情在线| 蜜月aⅴ免费一区二区三区| 色在人av网站天堂精品| 97久久国产精品| 青青a在线精品免费观看| 国产精品久久9| 欧美专区日韩视频| 欧美裸体男粗大视频在线观看| 欧美激情按摩在线| 国外成人免费在线播放| 精品国产31久久久久久| 精品无人区乱码1区2区3区在线| 亚洲精品久久久久久久久久久久久| 亚洲性无码av在线| 国产精品美乳在线观看| 日韩免费观看视频| 国产精品第一第二| 精品丝袜一区二区三区| 亚洲影院高清在线| 欧美综合在线观看| 日韩电影中文字幕一区| 九九久久综合网站| 最近的2019中文字幕免费一页| 亚洲视频网站在线观看| 情事1991在线| 91精品国产免费久久久久久| 国产日韩视频在线观看| 九九精品在线视频|