3atv精品不卡视频,97人人超碰国产精品最新,中文字幕av一区二区三区人妻少妇,久久久精品波多野结衣,日韩一区二区三区精品

歡迎訪問(wèn) 生活随笔!

生活随笔

當(dāng)前位置: 首頁(yè) > 编程语言 > python >内容正文

python

Python实现替换照片人物背景,精细到头发丝(附上代码) | 机器学习

發(fā)布時(shí)間:2023/12/8 python 29 豆豆
生活随笔 收集整理的這篇文章主要介紹了 Python实现替换照片人物背景,精细到头发丝(附上代码) | 机器学习 小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

目錄

前言

項(xiàng)目說(shuō)明

項(xiàng)目結(jié)構(gòu)

數(shù)據(jù)準(zhǔn)備

替換背景圖代碼

總結(jié)


前言

根據(jù)我另一篇文章:如何將照片或者視頻中的背景圖摳掉,機(jī)器學(xué)習(xí)開(kāi)源項(xiàng)目使用 | 機(jī)器學(xué)習(xí)_阿良的博客-CSDN博客

發(fā)現(xiàn)BackgroundMattingV2項(xiàng)目的一些使用上的小缺陷,但是他卻可以做到頭發(fā)絲精細(xì)的摳圖效果。所以我將項(xiàng)目稍微魔改了一下,讓他在可以選擇單一圖片的基礎(chǔ)上,可以把摳好的圖片貼在自定義的背景圖上,這樣就可以讓照片中的人物,出現(xiàn)在任何背景上。是不是很有意思?

本文的github倉(cāng)庫(kù)地址為:?替換照片人物背景項(xiàng)目(模型文件過(guò)大,不在倉(cāng)庫(kù)中)

由于模型文件過(guò)大,沒(méi)放在倉(cāng)庫(kù)中,本文下面有模型下載地址。

項(xiàng)目說(shuō)明

項(xiàng)目結(jié)構(gòu)

我們先看一下項(xiàng)目的結(jié)構(gòu),如圖:

其中,model文件夾放的是模型文件,模型文件的下載地址為:模型下載地址

下載該模型放到model文件夾下。

依賴文件-requirements.txt,說(shuō)明一下,pytorch的安裝需要使用官網(wǎng)給出的,避免顯卡驅(qū)動(dòng)對(duì)應(yīng)不上。可以參考我的另一篇文章關(guān)于pytorch的安裝:Pycharm代碼docker容器運(yùn)行調(diào)試 | 機(jī)器學(xué)習(xí)系列_阿良的博客-CSDN博客介紹常規(guī)的本地化運(yùn)行機(jī)器學(xué)習(xí)代碼,安裝Anaconda+cuda顯卡驅(qū)動(dòng)支持,許多文章都有介紹,不在此多做贅述了。本文主要是為了解決在工作環(huán)境中,本機(jī)電腦沒(méi)有顯卡,需要將程序運(yùn)行在帶顯卡的遠(yuǎn)程服務(wù)器上。本文會(huì)介紹如何部署使用顯卡的docker容器、如何使用pycharm連接docker容器運(yùn)行機(jī)器學(xué)習(xí)代碼。版本Pycharm: 2020.1.3docker:19.03.12python: 3.6.13demo算法: BackgroundMattingV2部署下面我會(huì)按照.https://huyi-aliang.blog.csdn.net/article/details/120556923

依賴文件如下:

kornia==0.4.1 tensorboard==2.3.0 torch==1.7.0 torchvision==0.8.1 tqdm==4.51.0 opencv-python==4.4.0.44 onnxruntime==1.6.0

數(shù)據(jù)準(zhǔn)備

我們需要準(zhǔn)備一張照片以及照片的背景圖,和你需要替換的圖片。我這邊選擇的是BackgroundMattingV2給出的一些參考圖,原始圖與背景圖如下:

?新的背景圖(我隨便找的)如下:

替換背景圖代碼

不廢話了,上核心代碼。

#!/usr/bin/env python # -*- coding: utf-8 -*- # @Time : 2021/11/14 21:24 # @Author : 劍客阿良_ALiang # @Site : # @File : inferance_hy.py import argparse import torch import osfrom torch.nn import functional as F from torch.utils.data import DataLoader from torchvision import transforms as T from torchvision.transforms.functional import to_pil_image from threading import Thread from tqdm import tqdm from torch.utils.data import Dataset from PIL import Image from typing import Callable, Optional, List, Tuple import glob from torch import nn from torchvision.models.resnet import ResNet, Bottleneck from torch import Tensor import torchvision import numpy as np import cv2 import uuid# --------------- hy --------------- class HomographicAlignment:"""Apply homographic alignment on background to match with the source image."""def __init__(self):self.detector = cv2.ORB_create()self.matcher = cv2.DescriptorMatcher_create(cv2.DESCRIPTOR_MATCHER_BRUTEFORCE)def __call__(self, src, bgr):src = np.asarray(src)bgr = np.asarray(bgr)keypoints_src, descriptors_src = self.detector.detectAndCompute(src, None)keypoints_bgr, descriptors_bgr = self.detector.detectAndCompute(bgr, None)matches = self.matcher.match(descriptors_bgr, descriptors_src, None)matches.sort(key=lambda x: x.distance, reverse=False)num_good_matches = int(len(matches) * 0.15)matches = matches[:num_good_matches]points_src = np.zeros((len(matches), 2), dtype=np.float32)points_bgr = np.zeros((len(matches), 2), dtype=np.float32)for i, match in enumerate(matches):points_src[i, :] = keypoints_src[match.trainIdx].ptpoints_bgr[i, :] = keypoints_bgr[match.queryIdx].ptH, _ = cv2.findHomography(points_bgr, points_src, cv2.RANSAC)h, w = src.shape[:2]bgr = cv2.warpPerspective(bgr, H, (w, h))msk = cv2.warpPerspective(np.ones((h, w)), H, (w, h))# For areas that is outside of the background,# We just copy pixels from the source.bgr[msk != 1] = src[msk != 1]src = Image.fromarray(src)bgr = Image.fromarray(bgr)return src, bgrclass Refiner(nn.Module):# For TorchScript export optimization.__constants__ = ['kernel_size', 'patch_crop_method', 'patch_replace_method']def __init__(self,mode: str,sample_pixels: int,threshold: float,kernel_size: int = 3,prevent_oversampling: bool = True,patch_crop_method: str = 'unfold',patch_replace_method: str = 'scatter_nd'):super().__init__()assert mode in ['full', 'sampling', 'thresholding']assert kernel_size in [1, 3]assert patch_crop_method in ['unfold', 'roi_align', 'gather']assert patch_replace_method in ['scatter_nd', 'scatter_element']self.mode = modeself.sample_pixels = sample_pixelsself.threshold = thresholdself.kernel_size = kernel_sizeself.prevent_oversampling = prevent_oversamplingself.patch_crop_method = patch_crop_methodself.patch_replace_method = patch_replace_methodchannels = [32, 24, 16, 12, 4]self.conv1 = nn.Conv2d(channels[0] + 6 + 4, channels[1], kernel_size, bias=False)self.bn1 = nn.BatchNorm2d(channels[1])self.conv2 = nn.Conv2d(channels[1], channels[2], kernel_size, bias=False)self.bn2 = nn.BatchNorm2d(channels[2])self.conv3 = nn.Conv2d(channels[2] + 6, channels[3], kernel_size, bias=False)self.bn3 = nn.BatchNorm2d(channels[3])self.conv4 = nn.Conv2d(channels[3], channels[4], kernel_size, bias=True)self.relu = nn.ReLU(True)def forward(self,src: torch.Tensor,bgr: torch.Tensor,pha: torch.Tensor,fgr: torch.Tensor,err: torch.Tensor,hid: torch.Tensor):H_full, W_full = src.shape[2:]H_half, W_half = H_full // 2, W_full // 2H_quat, W_quat = H_full // 4, W_full // 4src_bgr = torch.cat([src, bgr], dim=1)if self.mode != 'full':err = F.interpolate(err, (H_quat, W_quat), mode='bilinear', align_corners=False)ref = self.select_refinement_regions(err)idx = torch.nonzero(ref.squeeze(1))idx = idx[:, 0], idx[:, 1], idx[:, 2]if idx[0].size(0) > 0:x = torch.cat([hid, pha, fgr], dim=1)x = F.interpolate(x, (H_half, W_half), mode='bilinear', align_corners=False)x = self.crop_patch(x, idx, 2, 3 if self.kernel_size == 3 else 0)y = F.interpolate(src_bgr, (H_half, W_half), mode='bilinear', align_corners=False)y = self.crop_patch(y, idx, 2, 3 if self.kernel_size == 3 else 0)x = self.conv1(torch.cat([x, y], dim=1))x = self.bn1(x)x = self.relu(x)x = self.conv2(x)x = self.bn2(x)x = self.relu(x)x = F.interpolate(x, 8 if self.kernel_size == 3 else 4, mode='nearest')y = self.crop_patch(src_bgr, idx, 4, 2 if self.kernel_size == 3 else 0)x = self.conv3(torch.cat([x, y], dim=1))x = self.bn3(x)x = self.relu(x)x = self.conv4(x)out = torch.cat([pha, fgr], dim=1)out = F.interpolate(out, (H_full, W_full), mode='bilinear', align_corners=False)out = self.replace_patch(out, x, idx)pha = out[:, :1]fgr = out[:, 1:]else:pha = F.interpolate(pha, (H_full, W_full), mode='bilinear', align_corners=False)fgr = F.interpolate(fgr, (H_full, W_full), mode='bilinear', align_corners=False)else:x = torch.cat([hid, pha, fgr], dim=1)x = F.interpolate(x, (H_half, W_half), mode='bilinear', align_corners=False)y = F.interpolate(src_bgr, (H_half, W_half), mode='bilinear', align_corners=False)if self.kernel_size == 3:x = F.pad(x, (3, 3, 3, 3))y = F.pad(y, (3, 3, 3, 3))x = self.conv1(torch.cat([x, y], dim=1))x = self.bn1(x)x = self.relu(x)x = self.conv2(x)x = self.bn2(x)x = self.relu(x)if self.kernel_size == 3:x = F.interpolate(x, (H_full + 4, W_full + 4))y = F.pad(src_bgr, (2, 2, 2, 2))else:x = F.interpolate(x, (H_full, W_full), mode='nearest')y = src_bgrx = self.conv3(torch.cat([x, y], dim=1))x = self.bn3(x)x = self.relu(x)x = self.conv4(x)pha = x[:, :1]fgr = x[:, 1:]ref = torch.ones((src.size(0), 1, H_quat, W_quat), device=src.device, dtype=src.dtype)return pha, fgr, refdef select_refinement_regions(self, err: torch.Tensor):"""Select refinement regions.Input:err: error map (B, 1, H, W)Output:ref: refinement regions (B, 1, H, W). FloatTensor. 1 is selected, 0 is not."""if self.mode == 'sampling':# Sampling mode.b, _, h, w = err.shapeerr = err.view(b, -1)idx = err.topk(self.sample_pixels // 16, dim=1, sorted=False).indicesref = torch.zeros_like(err)ref.scatter_(1, idx, 1.)if self.prevent_oversampling:ref.mul_(err.gt(0).float())ref = ref.view(b, 1, h, w)else:# Thresholding mode.ref = err.gt(self.threshold).float()return refdef crop_patch(self,x: torch.Tensor,idx: Tuple[torch.Tensor, torch.Tensor, torch.Tensor],size: int,padding: int):"""Crops selected patches from image given indices.Inputs:x: image (B, C, H, W).idx: selection indices Tuple[(P,), (P,), (P,),], where the 3 values are (B, H, W) index.size: center size of the patch, also stride of the crop.padding: expansion size of the patch.Output:patch: (P, C, h, w), where h = w = size + 2 * padding."""if padding != 0:x = F.pad(x, (padding,) * 4)if self.patch_crop_method == 'unfold':# Use unfold. Best performance for PyTorch and TorchScript.return x.permute(0, 2, 3, 1) \.unfold(1, size + 2 * padding, size) \.unfold(2, size + 2 * padding, size)[idx[0], idx[1], idx[2]]elif self.patch_crop_method == 'roi_align':# Use roi_align. Best compatibility for ONNX.idx = idx[0].type_as(x), idx[1].type_as(x), idx[2].type_as(x)b = idx[0]x1 = idx[2] * size - 0.5y1 = idx[1] * size - 0.5x2 = idx[2] * size + size + 2 * padding - 0.5y2 = idx[1] * size + size + 2 * padding - 0.5boxes = torch.stack([b, x1, y1, x2, y2], dim=1)return torchvision.ops.roi_align(x, boxes, size + 2 * padding, sampling_ratio=1)else:# Use gather. Crops out patches pixel by pixel.idx_pix = self.compute_pixel_indices(x, idx, size, padding)pat = torch.gather(x.view(-1), 0, idx_pix.view(-1))pat = pat.view(-1, x.size(1), size + 2 * padding, size + 2 * padding)return patdef replace_patch(self,x: torch.Tensor,y: torch.Tensor,idx: Tuple[torch.Tensor, torch.Tensor, torch.Tensor]):"""Replaces patches back into image given index.Inputs:x: image (B, C, H, W)y: patches (P, C, h, w)idx: selection indices Tuple[(P,), (P,), (P,)] where the 3 values are (B, H, W) index.Output:image: (B, C, H, W), where patches at idx locations are replaced with y."""xB, xC, xH, xW = x.shapeyB, yC, yH, yW = y.shapeif self.patch_replace_method == 'scatter_nd':# Use scatter_nd. Best performance for PyTorch and TorchScript. Replacing patch by patch.x = x.view(xB, xC, xH // yH, yH, xW // yW, yW).permute(0, 2, 4, 1, 3, 5)x[idx[0], idx[1], idx[2]] = yx = x.permute(0, 3, 1, 4, 2, 5).view(xB, xC, xH, xW)return xelse:# Use scatter_element. Best compatibility for ONNX. Replacing pixel by pixel.idx_pix = self.compute_pixel_indices(x, idx, size=4, padding=0)return x.view(-1).scatter_(0, idx_pix.view(-1), y.view(-1)).view(x.shape)def compute_pixel_indices(self,x: torch.Tensor,idx: Tuple[torch.Tensor, torch.Tensor, torch.Tensor],size: int,padding: int):"""Compute selected pixel indices in the tensor.Used for crop_method == 'gather' and replace_method == 'scatter_element', which crop and replace pixel by pixel.Input:x: image: (B, C, H, W)idx: selection indices Tuple[(P,), (P,), (P,),], where the 3 values are (B, H, W) index.size: center size of the patch, also stride of the crop.padding: expansion size of the patch.Output:idx: (P, C, O, O) long tensor where O is the output size: size + 2 * padding, P is number of patches.the element are indices pointing to the input x.view(-1)."""B, C, H, W = x.shapeS, P = size, paddingO = S + 2 * Pb, y, x = idxn = b.size(0)c = torch.arange(C)o = torch.arange(O)idx_pat = (c * H * W).view(C, 1, 1).expand([C, O, O]) + (o * W).view(1, O, 1).expand([C, O, O]) + o.view(1, 1,O).expand([C, O, O])idx_loc = b * W * H + y * W * S + x * Sidx_pix = idx_loc.view(-1, 1, 1, 1).expand([n, C, O, O]) + idx_pat.view(1, C, O, O).expand([n, C, O, O])return idx_pixdef load_matched_state_dict(model, state_dict, print_stats=True):"""Only loads weights that matched in key and shape. Ignore other weights."""num_matched, num_total = 0, 0curr_state_dict = model.state_dict()for key in curr_state_dict.keys():num_total += 1if key in state_dict and curr_state_dict[key].shape == state_dict[key].shape:curr_state_dict[key] = state_dict[key]num_matched += 1model.load_state_dict(curr_state_dict)if print_stats:print(f'Loaded state_dict: {num_matched}/{num_total} matched')def _make_divisible(v: float, divisor: int, min_value: Optional[int] = None) -> int:"""This function is taken from the original tf repo.It ensures that all layers have a channel number that is divisible by 8It can be seen here:https://github.com/tensorflow/models/blob/master/research/slim/nets/mobilenet/mobilenet.py"""if min_value is None:min_value = divisornew_v = max(min_value, int(v + divisor / 2) // divisor * divisor)# Make sure that round down does not go down by more than 10%.if new_v < 0.9 * v:new_v += divisorreturn new_vclass ConvNormActivation(torch.nn.Sequential):def __init__(self,in_channels: int,out_channels: int,kernel_size: int = 3,stride: int = 1,padding: Optional[int] = None,groups: int = 1,norm_layer: Optional[Callable[..., torch.nn.Module]] = torch.nn.BatchNorm2d,activation_layer: Optional[Callable[..., torch.nn.Module]] = torch.nn.ReLU,dilation: int = 1,inplace: bool = True,) -> None:if padding is None:padding = (kernel_size - 1) // 2 * dilationlayers = [torch.nn.Conv2d(in_channels, out_channels, kernel_size, stride, padding,dilation=dilation, groups=groups, bias=norm_layer is None)]if norm_layer is not None:layers.append(norm_layer(out_channels))if activation_layer is not None:layers.append(activation_layer(inplace=inplace))super().__init__(*layers)self.out_channels = out_channelsclass InvertedResidual(nn.Module):def __init__(self,inp: int,oup: int,stride: int,expand_ratio: int,norm_layer: Optional[Callable[..., nn.Module]] = None) -> None:super(InvertedResidual, self).__init__()self.stride = strideassert stride in [1, 2]if norm_layer is None:norm_layer = nn.BatchNorm2dhidden_dim = int(round(inp * expand_ratio))self.use_res_connect = self.stride == 1 and inp == ouplayers: List[nn.Module] = []if expand_ratio != 1:# pwlayers.append(ConvNormActivation(inp, hidden_dim, kernel_size=1, norm_layer=norm_layer,activation_layer=nn.ReLU6))layers.extend([# dwConvNormActivation(hidden_dim, hidden_dim, stride=stride, groups=hidden_dim, norm_layer=norm_layer,activation_layer=nn.ReLU6),# pw-linearnn.Conv2d(hidden_dim, oup, 1, 1, 0, bias=False),norm_layer(oup),])self.conv = nn.Sequential(*layers)self.out_channels = oupself._is_cn = stride > 1def forward(self, x: Tensor) -> Tensor:if self.use_res_connect:return x + self.conv(x)else:return self.conv(x)class MobileNetV2(nn.Module):def __init__(self,num_classes: int = 1000,width_mult: float = 1.0,inverted_residual_setting: Optional[List[List[int]]] = None,round_nearest: int = 8,block: Optional[Callable[..., nn.Module]] = None,norm_layer: Optional[Callable[..., nn.Module]] = None) -> None:"""MobileNet V2 main classArgs:num_classes (int): Number of classeswidth_mult (float): Width multiplier - adjusts number of channels in each layer by this amountinverted_residual_setting: Network structureround_nearest (int): Round the number of channels in each layer to be a multiple of this numberSet to 1 to turn off roundingblock: Module specifying inverted residual building block for mobilenetnorm_layer: Module specifying the normalization layer to use"""super(MobileNetV2, self).__init__()if block is None:block = InvertedResidualif norm_layer is None:norm_layer = nn.BatchNorm2dinput_channel = 32last_channel = 1280if inverted_residual_setting is None:inverted_residual_setting = [# t, c, n, s[1, 16, 1, 1],[6, 24, 2, 2],[6, 32, 3, 2],[6, 64, 4, 2],[6, 96, 3, 1],[6, 160, 3, 2],[6, 320, 1, 1],]# only check the first element, assuming user knows t,c,n,s are requiredif len(inverted_residual_setting) == 0 or len(inverted_residual_setting[0]) != 4:raise ValueError("inverted_residual_setting should be non-empty ""or a 4-element list, got {}".format(inverted_residual_setting))# building first layerinput_channel = _make_divisible(input_channel * width_mult, round_nearest)self.last_channel = _make_divisible(last_channel * max(1.0, width_mult), round_nearest)features: List[nn.Module] = [ConvNormActivation(3, input_channel, stride=2, norm_layer=norm_layer,activation_layer=nn.ReLU6)]# building inverted residual blocksfor t, c, n, s in inverted_residual_setting:output_channel = _make_divisible(c * width_mult, round_nearest)for i in range(n):stride = s if i == 0 else 1features.append(block(input_channel, output_channel, stride, expand_ratio=t, norm_layer=norm_layer))input_channel = output_channel# building last several layersfeatures.append(ConvNormActivation(input_channel, self.last_channel, kernel_size=1, norm_layer=norm_layer,activation_layer=nn.ReLU6))# make it nn.Sequentialself.features = nn.Sequential(*features)# building classifierself.classifier = nn.Sequential(nn.Dropout(0.2),nn.Linear(self.last_channel, num_classes),)# weight initializationfor m in self.modules():if isinstance(m, nn.Conv2d):nn.init.kaiming_normal_(m.weight, mode='fan_out')if m.bias is not None:nn.init.zeros_(m.bias)elif isinstance(m, (nn.BatchNorm2d, nn.GroupNorm)):nn.init.ones_(m.weight)nn.init.zeros_(m.bias)elif isinstance(m, nn.Linear):nn.init.normal_(m.weight, 0, 0.01)nn.init.zeros_(m.bias)def _forward_impl(self, x: Tensor) -> Tensor:# This exists since TorchScript doesn't support inheritance, so the superclass method# (this one) needs to have a name other than `forward` that can be accessed in a subclassx = self.features(x)# Cannot use "squeeze" as batch-size can be 1x = nn.functional.adaptive_avg_pool2d(x, (1, 1))x = torch.flatten(x, 1)x = self.classifier(x)return xdef forward(self, x: Tensor) -> Tensor:return self._forward_impl(x)class MobileNetV2Encoder(MobileNetV2):"""MobileNetV2Encoder inherits from torchvision's official MobileNetV2. It is modified touse dilation on the last block to maintain output stride 16, and deleted theclassifier block that was originally used for classification. The forward methodadditionally returns the feature maps at all resolutions for decoder's use."""def __init__(self, in_channels, norm_layer=None):super().__init__()# Replace first conv layer if in_channels doesn't match.if in_channels != 3:self.features[0][0] = nn.Conv2d(in_channels, 32, 3, 2, 1, bias=False)# Remove last blockself.features = self.features[:-1]# Change to use dilation to maintain output stride = 16self.features[14].conv[1][0].stride = (1, 1)for feature in self.features[15:]:feature.conv[1][0].dilation = (2, 2)feature.conv[1][0].padding = (2, 2)# Delete classifierdel self.classifierdef forward(self, x):x0 = x # 1/1x = self.features[0](x)x = self.features[1](x)x1 = x # 1/2x = self.features[2](x)x = self.features[3](x)x2 = x # 1/4x = self.features[4](x)x = self.features[5](x)x = self.features[6](x)x3 = x # 1/8x = self.features[7](x)x = self.features[8](x)x = self.features[9](x)x = self.features[10](x)x = self.features[11](x)x = self.features[12](x)x = self.features[13](x)x = self.features[14](x)x = self.features[15](x)x = self.features[16](x)x = self.features[17](x)x4 = x # 1/16return x4, x3, x2, x1, x0class Decoder(nn.Module):def __init__(self, channels, feature_channels):super().__init__()self.conv1 = nn.Conv2d(feature_channels[0] + channels[0], channels[1], 3, padding=1, bias=False)self.bn1 = nn.BatchNorm2d(channels[1])self.conv2 = nn.Conv2d(feature_channels[1] + channels[1], channels[2], 3, padding=1, bias=False)self.bn2 = nn.BatchNorm2d(channels[2])self.conv3 = nn.Conv2d(feature_channels[2] + channels[2], channels[3], 3, padding=1, bias=False)self.bn3 = nn.BatchNorm2d(channels[3])self.conv4 = nn.Conv2d(feature_channels[3] + channels[3], channels[4], 3, padding=1)self.relu = nn.ReLU(True)def forward(self, x4, x3, x2, x1, x0):x = F.interpolate(x4, size=x3.shape[2:], mode='bilinear', align_corners=False)x = torch.cat([x, x3], dim=1)x = self.conv1(x)x = self.bn1(x)x = self.relu(x)x = F.interpolate(x, size=x2.shape[2:], mode='bilinear', align_corners=False)x = torch.cat([x, x2], dim=1)x = self.conv2(x)x = self.bn2(x)x = self.relu(x)x = F.interpolate(x, size=x1.shape[2:], mode='bilinear', align_corners=False)x = torch.cat([x, x1], dim=1)x = self.conv3(x)x = self.bn3(x)x = self.relu(x)x = F.interpolate(x, size=x0.shape[2:], mode='bilinear', align_corners=False)x = torch.cat([x, x0], dim=1)x = self.conv4(x)return xclass ASPPPooling(nn.Sequential):def __init__(self, in_channels: int, out_channels: int) -> None:super(ASPPPooling, self).__init__(nn.AdaptiveAvgPool2d(1),nn.Conv2d(in_channels, out_channels, 1, bias=False),nn.BatchNorm2d(out_channels),nn.ReLU())def forward(self, x: torch.Tensor) -> torch.Tensor:size = x.shape[-2:]for mod in self:x = mod(x)return F.interpolate(x, size=size, mode='bilinear', align_corners=False)class ASPPConv(nn.Sequential):def __init__(self, in_channels: int, out_channels: int, dilation: int) -> None:modules = [nn.Conv2d(in_channels, out_channels, 3, padding=dilation, dilation=dilation, bias=False),nn.BatchNorm2d(out_channels),nn.ReLU()]super(ASPPConv, self).__init__(*modules)class ASPP(nn.Module):def __init__(self, in_channels: int, atrous_rates: List[int], out_channels: int = 256) -> None:super(ASPP, self).__init__()modules = []modules.append(nn.Sequential(nn.Conv2d(in_channels, out_channels, 1, bias=False),nn.BatchNorm2d(out_channels),nn.ReLU()))rates = tuple(atrous_rates)for rate in rates:modules.append(ASPPConv(in_channels, out_channels, rate))modules.append(ASPPPooling(in_channels, out_channels))self.convs = nn.ModuleList(modules)self.project = nn.Sequential(nn.Conv2d(len(self.convs) * out_channels, out_channels, 1, bias=False),nn.BatchNorm2d(out_channels),nn.ReLU(),nn.Dropout(0.5))def forward(self, x: torch.Tensor) -> torch.Tensor:_res = []for conv in self.convs:_res.append(conv(x))res = torch.cat(_res, dim=1)return self.project(res)class ResNetEncoder(ResNet):layers = {'resnet50': [3, 4, 6, 3],'resnet101': [3, 4, 23, 3],}def __init__(self, in_channels, variant='resnet101', norm_layer=None):super().__init__(block=Bottleneck,layers=self.layers[variant],replace_stride_with_dilation=[False, False, True],norm_layer=norm_layer)# Replace first conv layer if in_channels doesn't match.if in_channels != 3:self.conv1 = nn.Conv2d(in_channels, 64, 7, 2, 3, bias=False)# Delete fully-connected layerdel self.avgpooldel self.fcdef forward(self, x):x0 = x # 1/1x = self.conv1(x)x = self.bn1(x)x = self.relu(x)x1 = x # 1/2x = self.maxpool(x)x = self.layer1(x)x2 = x # 1/4x = self.layer2(x)x3 = x # 1/8x = self.layer3(x)x = self.layer4(x)x4 = x # 1/16return x4, x3, x2, x1, x0class Base(nn.Module):"""A generic implementation of the base encoder-decoder network inspired by DeepLab.Accepts arbitrary channels for input and output."""def __init__(self, backbone: str, in_channels: int, out_channels: int):super().__init__()assert backbone in ["resnet50", "resnet101", "mobilenetv2"]if backbone in ['resnet50', 'resnet101']:self.backbone = ResNetEncoder(in_channels, variant=backbone)self.aspp = ASPP(2048, [3, 6, 9])self.decoder = Decoder([256, 128, 64, 48, out_channels], [512, 256, 64, in_channels])else:self.backbone = MobileNetV2Encoder(in_channels)self.aspp = ASPP(320, [3, 6, 9])self.decoder = Decoder([256, 128, 64, 48, out_channels], [32, 24, 16, in_channels])def forward(self, x):x, *shortcuts = self.backbone(x)x = self.aspp(x)x = self.decoder(x, *shortcuts)return xdef load_pretrained_deeplabv3_state_dict(self, state_dict, print_stats=True):# Pretrained DeepLabV3 models are provided by <https://github.com/VainF/DeepLabV3Plus-Pytorch>.# This method converts and loads their pretrained state_dict to match with our model structure.# This method is not needed if you are not planning to train from deeplab weights.# Use load_state_dict() for normal weight loading.# Convert state_dict naming for aspp modulestate_dict = {k.replace('classifier.classifier.0', 'aspp'): v for k, v in state_dict.items()}if isinstance(self.backbone, ResNetEncoder):# ResNet backbone does not need change.load_matched_state_dict(self, state_dict, print_stats)else:# Change MobileNetV2 backbone to state_dict format, then change back after loading.backbone_features = self.backbone.featuresself.backbone.low_level_features = backbone_features[:4]self.backbone.high_level_features = backbone_features[4:]del self.backbone.featuresload_matched_state_dict(self, state_dict, print_stats)self.backbone.features = backbone_featuresdel self.backbone.low_level_featuresdel self.backbone.high_level_featuresclass MattingBase(Base):def __init__(self, backbone: str):super().__init__(backbone, in_channels=6, out_channels=(1 + 3 + 1 + 32))def forward(self, src, bgr):x = torch.cat([src, bgr], dim=1)x, *shortcuts = self.backbone(x)x = self.aspp(x)x = self.decoder(x, *shortcuts)pha = x[:, 0:1].clamp_(0., 1.)fgr = x[:, 1:4].add(src).clamp_(0., 1.)err = x[:, 4:5].clamp_(0., 1.)hid = x[:, 5:].relu_()return pha, fgr, err, hidclass MattingRefine(MattingBase):def __init__(self,backbone: str,backbone_scale: float = 1 / 4,refine_mode: str = 'sampling',refine_sample_pixels: int = 80_000,refine_threshold: float = 0.1,refine_kernel_size: int = 3,refine_prevent_oversampling: bool = True,refine_patch_crop_method: str = 'unfold',refine_patch_replace_method: str = 'scatter_nd'):assert backbone_scale <= 1 / 2, 'backbone_scale should not be greater than 1/2'super().__init__(backbone)self.backbone_scale = backbone_scaleself.refiner = Refiner(refine_mode,refine_sample_pixels,refine_threshold,refine_kernel_size,refine_prevent_oversampling,refine_patch_crop_method,refine_patch_replace_method)def forward(self, src, bgr):assert src.size() == bgr.size(), 'src and bgr must have the same shape'assert src.size(2) // 4 * 4 == src.size(2) and src.size(3) // 4 * 4 == src.size(3), \'src and bgr must have width and height that are divisible by 4'# Downsample src and bgr for backbonesrc_sm = F.interpolate(src,scale_factor=self.backbone_scale,mode='bilinear',align_corners=False,recompute_scale_factor=True)bgr_sm = F.interpolate(bgr,scale_factor=self.backbone_scale,mode='bilinear',align_corners=False,recompute_scale_factor=True)# Basex = torch.cat([src_sm, bgr_sm], dim=1)x, *shortcuts = self.backbone(x)x = self.aspp(x)x = self.decoder(x, *shortcuts)pha_sm = x[:, 0:1].clamp_(0., 1.)fgr_sm = x[:, 1:4]err_sm = x[:, 4:5].clamp_(0., 1.)hid_sm = x[:, 5:].relu_()# Refinerpha, fgr, ref_sm = self.refiner(src, bgr, pha_sm, fgr_sm, err_sm, hid_sm)# Clamp outputspha = pha.clamp_(0., 1.)fgr = fgr.add_(src).clamp_(0., 1.)fgr_sm = src_sm.add_(fgr_sm).clamp_(0., 1.)return pha, fgr, pha_sm, fgr_sm, err_sm, ref_smclass ImagesDataset(Dataset):def __init__(self, root, mode='RGB', transforms=None):self.transforms = transformsself.mode = modeself.filenames = sorted([*glob.glob(os.path.join(root, '**', '*.jpg'), recursive=True),*glob.glob(os.path.join(root, '**', '*.png'), recursive=True)])def __len__(self):return len(self.filenames)def __getitem__(self, idx):with Image.open(self.filenames[idx]) as img:img = img.convert(self.mode)if self.transforms:img = self.transforms(img)return imgclass NewImagesDataset(Dataset):def __init__(self, root, mode='RGB', transforms=None):self.transforms = transformsself.mode = modeself.filenames = [root]print(self.filenames)def __len__(self):return len(self.filenames)def __getitem__(self, idx):with Image.open(self.filenames[idx]) as img:img = img.convert(self.mode)if self.transforms:img = self.transforms(img)return imgclass ZipDataset(Dataset):def __init__(self, datasets: List[Dataset], transforms=None, assert_equal_length=False):self.datasets = datasetsself.transforms = transformsif assert_equal_length:for i in range(1, len(datasets)):assert len(datasets[i]) == len(datasets[i - 1]), 'Datasets are not equal in length.'def __len__(self):return max(len(d) for d in self.datasets)def __getitem__(self, idx):x = tuple(d[idx % len(d)] for d in self.datasets)print(x)if self.transforms:x = self.transforms(*x)return xclass PairCompose(T.Compose):def __call__(self, *x):for transform in self.transforms:x = transform(*x)return xclass PairApply:def __init__(self, transforms):self.transforms = transformsdef __call__(self, *x):return [self.transforms(xi) for xi in x]# --------------- Arguments ---------------parser = argparse.ArgumentParser(description='hy-replace-background')parser.add_argument('--model-type', type=str, required=False, choices=['mattingbase', 'mattingrefine'],default='mattingrefine') parser.add_argument('--model-backbone', type=str, required=False, choices=['resnet101', 'resnet50', 'mobilenetv2'],default='resnet50') parser.add_argument('--model-backbone-scale', type=float, default=0.25) parser.add_argument('--model-checkpoint', type=str, required=False, default='model/pytorch_resnet50.pth') parser.add_argument('--model-refine-mode', type=str, default='sampling', choices=['full', 'sampling', 'thresholding']) parser.add_argument('--model-refine-sample-pixels', type=int, default=80_000) parser.add_argument('--model-refine-threshold', type=float, default=0.7) parser.add_argument('--model-refine-kernel-size', type=int, default=3)parser.add_argument('--device', type=str, choices=['cpu', 'cuda'], default='cuda') parser.add_argument('--num-workers', type=int, default=0,help='number of worker threads used in DataLoader. Note that Windows need to use single thread (0).') parser.add_argument('--preprocess-alignment', action='store_true')parser.add_argument('--output-dir', type=str, required=False, default='content/output') parser.add_argument('--output-types', type=str, required=False, nargs='+',choices=['com', 'pha', 'fgr', 'err', 'ref', 'new'],default=['new']) parser.add_argument('-y', action='store_true')def handle(image_path: str, bgr_path: str, new_bg: str):parser.add_argument('--images-src', type=str, required=False, default=image_path)parser.add_argument('--images-bgr', type=str, required=False, default=bgr_path)args = parser.parse_args()assert 'err' not in args.output_types or args.model_type in ['mattingbase', 'mattingrefine'], \'Only mattingbase and mattingrefine support err output'assert 'ref' not in args.output_types or args.model_type in ['mattingrefine'], \'Only mattingrefine support ref output'# --------------- Main ---------------device = torch.device(args.device)# Load modelif args.model_type == 'mattingbase':model = MattingBase(args.model_backbone)if args.model_type == 'mattingrefine':model = MattingRefine(args.model_backbone,args.model_backbone_scale,args.model_refine_mode,args.model_refine_sample_pixels,args.model_refine_threshold,args.model_refine_kernel_size)model = model.to(device).eval()model.load_state_dict(torch.load(args.model_checkpoint, map_location=device), strict=False)# Load imagesdataset = ZipDataset([NewImagesDataset(args.images_src),NewImagesDataset(args.images_bgr),], assert_equal_length=True, transforms=PairCompose([HomographicAlignment() if args.preprocess_alignment else PairApply(nn.Identity()),PairApply(T.ToTensor())]))dataloader = DataLoader(dataset, batch_size=1, num_workers=args.num_workers, pin_memory=True)# # Create output directory# if os.path.exists(args.output_dir):# if args.y or input(f'Directory {args.output_dir} already exists. Override? [Y/N]: ').lower() == 'y':# shutil.rmtree(args.output_dir)# else:# exit()for output_type in args.output_types:if os.path.exists(os.path.join(args.output_dir, output_type)) is False:os.makedirs(os.path.join(args.output_dir, output_type))# Worker functiondef writer(img, path):img = to_pil_image(img[0].cpu())img.save(path)# Worker functiondef writer_hy(img, new_bg, path):img = to_pil_image(img[0].cpu())img_size = img.sizenew_bg_img = Image.open(new_bg).convert('RGBA')new_bg_img.resize(img_size, Image.ANTIALIAS)out = Image.alpha_composite(new_bg_img, img)out.save(path)result_file_name = str(uuid.uuid4())# Conversion loopwith torch.no_grad():for i, (src, bgr) in enumerate(tqdm(dataloader)):src = src.to(device, non_blocking=True)bgr = bgr.to(device, non_blocking=True)if args.model_type == 'mattingbase':pha, fgr, err, _ = model(src, bgr)elif args.model_type == 'mattingrefine':pha, fgr, _, _, err, ref = model(src, bgr)pathname = dataset.datasets[0].filenames[i]pathname = os.path.relpath(pathname, args.images_src)pathname = os.path.splitext(pathname)[0]if 'new' in args.output_types:new = torch.cat([fgr * pha.ne(0), pha], dim=1)Thread(target=writer_hy,args=(new, new_bg, os.path.join(args.output_dir, 'new', result_file_name + '.png'))).start()if 'com' in args.output_types:com = torch.cat([fgr * pha.ne(0), pha], dim=1)Thread(target=writer, args=(com, os.path.join(args.output_dir, 'com', pathname + '.png'))).start()if 'pha' in args.output_types:Thread(target=writer, args=(pha, os.path.join(args.output_dir, 'pha', pathname + '.jpg'))).start()if 'fgr' in args.output_types:Thread(target=writer, args=(fgr, os.path.join(args.output_dir, 'fgr', pathname + '.jpg'))).start()if 'err' in args.output_types:err = F.interpolate(err, src.shape[2:], mode='bilinear', align_corners=False)Thread(target=writer, args=(err, os.path.join(args.output_dir, 'err', pathname + '.jpg'))).start()if 'ref' in args.output_types:ref = F.interpolate(ref, src.shape[2:], mode='nearest')Thread(target=writer, args=(ref, os.path.join(args.output_dir, 'ref', pathname + '.jpg'))).start()return os.path.join(args.output_dir, 'new', result_file_name + '.png')if __name__ == '__main__':handle("data/img2.png", "data/bg.png", "data/newbg.jpg")

代碼說(shuō)明

1、handle方法的參數(shù)一次為:原始圖路徑、原始背景圖路徑、新背景圖路徑。

1、我將原項(xiàng)目中inferance_images使用的類(lèi)都移到一個(gè)文件中,精簡(jiǎn)一下項(xiàng)目結(jié)構(gòu)。

2、ImagesDateSet我重新構(gòu)造了一個(gè)新的NewImagesDateSet,,主要是因?yàn)槲抑淮蛩闾幚硪粡垐D片。

3、最終圖片都存在相同目錄下,避免重復(fù)使用uuid作為文件名。

4、本文給出的代碼沒(méi)有對(duì)文件格式做嚴(yán)格校正,不是很關(guān)鍵,如果需要補(bǔ)充就行。

驗(yàn)證一下效果

怎么樣?還是很炫吧!

總結(jié)

研究這個(gè)開(kāi)源項(xiàng)目以及編寫(xiě)替換背景的功能,花了我兩天的時(shí)間,需要對(duì)項(xiàng)目本身的很多設(shè)置需要了解。以后有機(jī)會(huì),我會(huì)把yolov5開(kāi)源項(xiàng)目也魔改一下,基于作者給出的效果實(shí)現(xiàn)作出自己想要的東西,會(huì)非常有意思。本文的項(xiàng)目功能只是臨時(shí)做的,不是很健壯,想用的話自己再發(fā)揮發(fā)揮自己的想象力吧。

分享:

????????天上劍仙三百萬(wàn),見(jiàn)我也須盡低眉。——《雪中悍刀行》

如果本文對(duì)你有幫助的話,請(qǐng)不要吝嗇你的贊,謝謝!

總結(jié)

以上是生活随笔為你收集整理的Python实现替换照片人物背景,精细到头发丝(附上代码) | 机器学习的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。

如果覺(jué)得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。

欧美激情综合亚洲一二区 | 国产综合久久久久鬼色 | 欧美第一黄网免费网站 | 国精产品一品二品国精品69xx | 国产成人无码av一区二区 | 女高中生第一次破苞av | 欧美一区二区三区视频在线观看 | 国产人妻精品一区二区三区不卡 | 免费观看的无遮挡av | 97精品人妻一区二区三区香蕉 | 51国偷自产一区二区三区 | 国产精品多人p群无码 | 亚洲成色在线综合网站 | 日本护士xxxxhd少妇 | 国产精品久久久久9999小说 | 大肉大捧一进一出好爽视频 | 亚洲精品成人福利网站 | 国产成人精品优优av | 一本无码人妻在中文字幕免费 | 国产成人精品三级麻豆 | 奇米影视7777久久精品人人爽 | 无码午夜成人1000部免费视频 | 丝袜美腿亚洲一区二区 | 亚洲自偷自偷在线制服 | 狠狠色丁香久久婷婷综合五月 | 人妻互换免费中文字幕 | 日本www一道久久久免费榴莲 | 久热国产vs视频在线观看 | 午夜丰满少妇性开放视频 | 欧美色就是色 | 亚洲另类伦春色综合小说 | 蜜桃臀无码内射一区二区三区 | 牛和人交xxxx欧美 | 亚洲国产精品久久久天堂 | 国产日产欧产精品精品app | 日韩亚洲欧美精品综合 | 欧美肥老太牲交大战 | 国产成人精品一区二区在线小狼 | 国产成人无码av一区二区 | 日本护士xxxxhd少妇 | 欧美人与禽zoz0性伦交 | 少妇性荡欲午夜性开放视频剧场 | 精品国产麻豆免费人成网站 | 丰满肥臀大屁股熟妇激情视频 | 国产成人综合色在线观看网站 | 亚洲国产精品无码久久久久高潮 | 精品偷拍一区二区三区在线看 | 亚洲精品综合五月久久小说 | 中文字幕人成乱码熟女app | 国产超级va在线观看视频 | 娇妻被黑人粗大高潮白浆 | 4hu四虎永久在线观看 | 无码人妻av免费一区二区三区 | 午夜不卡av免费 一本久久a久久精品vr综合 | 国产精品久久国产三级国 | 中文字幕中文有码在线 | 亚洲熟妇色xxxxx欧美老妇y | 国产又爽又黄又刺激的视频 | 亚洲综合伊人久久大杳蕉 | 国产乱人伦app精品久久 国产在线无码精品电影网 国产国产精品人在线视 | 伊人久久大香线蕉午夜 | 成人aaa片一区国产精品 | 天堂亚洲免费视频 | 人人澡人人妻人人爽人人蜜桃 | 久久精品国产一区二区三区肥胖 | 国产人妻久久精品二区三区老狼 | 乱码午夜-极国产极内射 | 国产日产欧产精品精品app | 欧美成人午夜精品久久久 | 精品亚洲韩国一区二区三区 | 日本肉体xxxx裸交 | 丰满少妇熟乱xxxxx视频 | 激情爆乳一区二区三区 | 亚洲一区二区三区国产精华液 | 久久精品一区二区三区四区 | 日本又色又爽又黄的a片18禁 | 免费男性肉肉影院 | 免费网站看v片在线18禁无码 | 无套内谢老熟女 | 美女张开腿让人桶 | 国产成人无码午夜视频在线观看 | 在线精品亚洲一区二区 | 亚洲男女内射在线播放 | 中文精品无码中文字幕无码专区 | 亚洲欧洲无卡二区视頻 | 亚洲乱码日产精品bd | 特黄特色大片免费播放器图片 | 亚洲国产成人av在线观看 | 久久人人97超碰a片精品 | 蜜臀av在线播放 久久综合激激的五月天 | 国产国产精品人在线视 | 午夜免费福利小电影 | 国色天香社区在线视频 | 日韩精品一区二区av在线 | 色 综合 欧美 亚洲 国产 | 久久久中文字幕日本无吗 | 午夜精品一区二区三区在线观看 | 未满小14洗澡无码视频网站 | 99久久精品无码一区二区毛片 | 国产真实乱对白精彩久久 | a在线观看免费网站大全 | 久久精品人人做人人综合 | 国产精品人妻一区二区三区四 | 欧美xxxxx精品 | 一个人免费观看的www视频 | 成人aaa片一区国产精品 | 色欲人妻aaaaaaa无码 | 欧美日韩综合一区二区三区 | 99精品国产综合久久久久五月天 | 日韩无码专区 | 日韩 欧美 动漫 国产 制服 | 玩弄少妇高潮ⅹxxxyw | 日本一本二本三区免费 | 国产无套内射久久久国产 | 人人爽人人澡人人高潮 | 综合激情五月综合激情五月激情1 | 久精品国产欧美亚洲色aⅴ大片 | 日本饥渴人妻欲求不满 | 日韩人妻系列无码专区 | 午夜无码区在线观看 | 国产乡下妇女做爰 | 欧美第一黄网免费网站 | 真人与拘做受免费视频 | 国产综合久久久久鬼色 | 亚洲欧洲中文日韩av乱码 | 亚洲一区二区三区偷拍女厕 | 亚洲欧美国产精品专区久久 | 日本免费一区二区三区最新 | 欧美日韩人成综合在线播放 | 高清无码午夜福利视频 | 无码人妻精品一区二区三区不卡 | 亚洲伊人久久精品影院 | 国产免费久久精品国产传媒 | 老头边吃奶边弄进去呻吟 | 国产性猛交╳xxx乱大交 国产精品久久久久久无码 欧洲欧美人成视频在线 | 亚洲中文字幕无码一久久区 | 国产亚洲日韩欧美另类第八页 | 一本色道久久综合亚洲精品不卡 | 台湾无码一区二区 | 亚洲精品中文字幕久久久久 | 中文字幕人妻无码一区二区三区 | 性色欲网站人妻丰满中文久久不卡 | 99久久精品无码一区二区毛片 | 国产 精品 自在自线 | 成人精品一区二区三区中文字幕 | 亚洲国产日韩a在线播放 | 伊人久久婷婷五月综合97色 | 乌克兰少妇xxxx做受 | 久久午夜无码鲁丝片午夜精品 | 少妇厨房愉情理9仑片视频 | 国产午夜亚洲精品不卡下载 | 国产精品久久久久7777 | 日日噜噜噜噜夜夜爽亚洲精品 | 成人免费视频一区二区 | 377p欧洲日本亚洲大胆 | 丰满肥臀大屁股熟妇激情视频 | 国产精品18久久久久久麻辣 | 国产亚洲欧美日韩亚洲中文色 | yw尤物av无码国产在线观看 | 秋霞成人午夜鲁丝一区二区三区 | 美女极度色诱视频国产 | 少妇激情av一区二区 | 久久久久成人片免费观看蜜芽 | 国产午夜亚洲精品不卡下载 | 暴力强奷在线播放无码 | 东北女人啪啪对白 | 成人无码影片精品久久久 | 好男人社区资源 | 午夜精品一区二区三区在线观看 | 国产精品久久福利网站 | 国产精品多人p群无码 | 精品成人av一区二区三区 | 午夜肉伦伦影院 | 亚洲国产综合无码一区 | 国产肉丝袜在线观看 | 少女韩国电视剧在线观看完整 | 高潮毛片无遮挡高清免费视频 | 亚洲中文字幕乱码av波多ji | 亚洲综合另类小说色区 | 在线成人www免费观看视频 | 亚洲中文字幕无码一久久区 | 国产区女主播在线观看 | 国产人妻精品一区二区三区不卡 | 国产情侣作爱视频免费观看 | 国产精品99爱免费视频 | 日韩成人一区二区三区在线观看 | 国产精品资源一区二区 | 日韩精品成人一区二区三区 | 精品无码一区二区三区爱欲 | 狠狠综合久久久久综合网 | 无码精品人妻一区二区三区av | 牲交欧美兽交欧美 | 98国产精品综合一区二区三区 | 成人无码精品一区二区三区 | 在线a亚洲视频播放在线观看 | 亚洲熟熟妇xxxx | 亚洲成色在线综合网站 | 无码福利日韩神码福利片 | 色偷偷人人澡人人爽人人模 | 思思久久99热只有频精品66 | 狠狠色色综合网站 | 亚洲一区二区三区香蕉 | 波多野结衣 黑人 | 国产精品久久久久久亚洲毛片 | 欧美熟妇另类久久久久久不卡 | 嫩b人妻精品一区二区三区 | 天堂在线观看www | 久久无码专区国产精品s | 九一九色国产 | 国产97人人超碰caoprom | 丰满少妇女裸体bbw | 久久天天躁夜夜躁狠狠 | 夜精品a片一区二区三区无码白浆 | 国产色在线 | 国产 | 内射巨臀欧美在线视频 | 国产精品久久久久无码av色戒 | 性开放的女人aaa片 | 久久97精品久久久久久久不卡 | 久久久久久国产精品无码下载 | 装睡被陌生人摸出水好爽 | 天天躁夜夜躁狠狠是什么心态 | 精品国产精品久久一区免费式 | 秋霞成人午夜鲁丝一区二区三区 | 一区二区三区乱码在线 | 欧洲 | 欧美怡红院免费全部视频 | 国产无遮挡又黄又爽又色 | 日本爽爽爽爽爽爽在线观看免 | 国产精品无码成人午夜电影 | 久久国产劲爆∧v内射 | 精品无人区无码乱码毛片国产 | 精品久久久久久人妻无码中文字幕 | 欧美成人午夜精品久久久 | 又大又硬又黄的免费视频 | 亚洲综合无码久久精品综合 | 性生交大片免费看l | 无码人妻黑人中文字幕 | 无码人妻精品一区二区三区不卡 | 国产激情无码一区二区app | 国产精品爱久久久久久久 | 图片小说视频一区二区 | 九月婷婷人人澡人人添人人爽 | 国产精品久久久久久久9999 | 一本大道久久东京热无码av | 少妇无套内谢久久久久 | 国产精品亚洲一区二区三区喷水 | 久久久久久久久888 | 成人无码影片精品久久久 | 中文字幕日韩精品一区二区三区 | 欧洲美熟女乱又伦 | 亚洲精品久久久久中文第一幕 | 无码人妻av免费一区二区三区 | 激情人妻另类人妻伦 | 成人亚洲精品久久久久 | 中文字幕无码视频专区 | 亚洲国产欧美日韩精品一区二区三区 | 精品久久久中文字幕人妻 | 国产成人亚洲综合无码 | 在线播放无码字幕亚洲 | 国产精品igao视频网 | 国产人妻久久精品二区三区老狼 | 精品亚洲韩国一区二区三区 | 国产成人综合在线女婷五月99播放 | 国产小呦泬泬99精品 | 欧美放荡的少妇 | 四虎永久在线精品免费网址 | 国产成人精品一区二区在线小狼 | 国产亚av手机在线观看 | 中文字幕av日韩精品一区二区 | 激情内射日本一区二区三区 | 欧美人与牲动交xxxx | 亚洲欧洲日本综合aⅴ在线 | 国产午夜福利100集发布 | 日本乱偷人妻中文字幕 | 少妇厨房愉情理9仑片视频 | 中文字幕久久久久人妻 | 国产成人人人97超碰超爽8 | 国产97人人超碰caoprom | 国产乡下妇女做爰 | 亚洲精品综合五月久久小说 | 永久免费观看国产裸体美女 | 亚洲s色大片在线观看 | 四虎影视成人永久免费观看视频 | 国产精品久久久久7777 | 欧美日韩色另类综合 | 国产疯狂伦交大片 | 一本久道久久综合婷婷五月 | 性色av无码免费一区二区三区 | 成年美女黄网站色大免费全看 | 久久99国产综合精品 | 国产绳艺sm调教室论坛 | 男女爱爱好爽视频免费看 | а√天堂www在线天堂小说 | 午夜精品一区二区三区在线观看 | 又粗又大又硬又长又爽 | 77777熟女视频在线观看 а天堂中文在线官网 | 久久99热只有频精品8 | 久久国产自偷自偷免费一区调 | 精品人妻人人做人人爽夜夜爽 | 秋霞特色aa大片 | 国产精品国产自线拍免费软件 | 综合激情五月综合激情五月激情1 | 东京热无码av男人的天堂 | av香港经典三级级 在线 | 国产精品高潮呻吟av久久 | 色窝窝无码一区二区三区色欲 | 久久成人a毛片免费观看网站 | 精品国偷自产在线 | 亚洲区欧美区综合区自拍区 | 日产国产精品亚洲系列 | 无码人妻丰满熟妇区五十路百度 | 国产午夜无码精品免费看 | 天天躁夜夜躁狠狠是什么心态 | 国产精品香蕉在线观看 | 久久国产精品精品国产色婷婷 | 中文字幕无线码免费人妻 | 久久国产精品萌白酱免费 | 一个人看的www免费视频在线观看 | 无遮挡国产高潮视频免费观看 | 免费乱码人妻系列无码专区 | 少妇性荡欲午夜性开放视频剧场 | 福利一区二区三区视频在线观看 | 国产成人亚洲综合无码 | 午夜精品久久久久久久久 | 亚洲欧美色中文字幕在线 | 日韩av无码一区二区三区不卡 | 成人亚洲精品久久久久 | 日日橹狠狠爱欧美视频 | 久久久久国色av免费观看性色 | 波多野结衣高清一区二区三区 | 欧美日韩亚洲国产精品 | 无码福利日韩神码福利片 | 亚洲综合在线一区二区三区 | 中文字幕无线码 | 性欧美疯狂xxxxbbbb | 国产无遮挡吃胸膜奶免费看 | aⅴ在线视频男人的天堂 | 色一情一乱一伦 | 欧美丰满老熟妇xxxxx性 | 人人爽人人澡人人人妻 | 色综合久久久无码中文字幕 | 亚洲一区二区三区香蕉 | 人妻熟女一区 | 久久综合激激的五月天 | 午夜精品一区二区三区在线观看 | 四虎国产精品一区二区 | 三级4级全黄60分钟 | 亚洲爆乳大丰满无码专区 | 亚洲综合久久一区二区 | 亚洲娇小与黑人巨大交 | 女人被男人躁得好爽免费视频 | 日韩 欧美 动漫 国产 制服 | 欧美成人午夜精品久久久 | 亚洲国产精品久久久天堂 | 久久久中文久久久无码 | 欧美精品在线观看 | 中文字幕亚洲情99在线 | 东京热无码av男人的天堂 | 欧美黑人巨大xxxxx | 欧美成人高清在线播放 | 女人被男人爽到呻吟的视频 | 激情综合激情五月俺也去 | 少妇高潮喷潮久久久影院 | 日韩av无码中文无码电影 | 永久免费观看美女裸体的网站 | 亚洲 高清 成人 动漫 | 澳门永久av免费网站 | 性啪啪chinese东北女人 | 高清国产亚洲精品自在久久 | 成人动漫在线观看 | 亚洲综合另类小说色区 | 午夜精品久久久久久久久 | 国产精品香蕉在线观看 | 97精品国产97久久久久久免费 | 国产真实伦对白全集 | 国产精品久久久av久久久 | 天干天干啦夜天干天2017 | 少妇无套内谢久久久久 | 大屁股大乳丰满人妻 | 久久人人爽人人人人片 | 性欧美牲交xxxxx视频 | 爆乳一区二区三区无码 | 国产日产欧产精品精品app | 鲁鲁鲁爽爽爽在线视频观看 | 亚洲国产欧美日韩精品一区二区三区 | 老太婆性杂交欧美肥老太 | 蜜臀av在线观看 在线欧美精品一区二区三区 | 免费播放一区二区三区 | 在线精品国产一区二区三区 | 亚洲一区二区三区播放 | 一本加勒比波多野结衣 | 国产精品久久国产三级国 | 中文字幕乱码中文乱码51精品 | 日日麻批免费40分钟无码 | 婷婷丁香五月天综合东京热 | 久久人人97超碰a片精品 | 国产做国产爱免费视频 | 色婷婷香蕉在线一区二区 | 中文字幕无码热在线视频 | 3d动漫精品啪啪一区二区中 | 国产精品亚洲专区无码不卡 | 丁香花在线影院观看在线播放 | 国语自产偷拍精品视频偷 | 久久久精品成人免费观看 | 亚洲日本一区二区三区在线 | 亚洲人成网站色7799 | 国产激情无码一区二区app | 亚洲精品www久久久 | 久久97精品久久久久久久不卡 | 国产真实乱对白精彩久久 | 精品乱码久久久久久久 | 乱人伦人妻中文字幕无码久久网 | 国产精品久久久久久亚洲影视内衣 | 国产三级久久久精品麻豆三级 | 国产亚av手机在线观看 | 乱人伦中文视频在线观看 | 亚洲精品午夜无码电影网 | 久久精品国产一区二区三区 | 四十如虎的丰满熟妇啪啪 | 西西人体www44rt大胆高清 | 国产亚洲日韩欧美另类第八页 | 午夜性刺激在线视频免费 | 国产成人无码av一区二区 | 欧美精品国产综合久久 | 亚洲一区二区观看播放 | 日韩欧美成人免费观看 | 国产在热线精品视频 | 成人性做爰aaa片免费看不忠 | 久久久精品人妻久久影视 | 欧美日韩一区二区三区自拍 | 欧美刺激性大交 | 日本熟妇大屁股人妻 | 色狠狠av一区二区三区 | 波多野42部无码喷潮在线 | 天堂一区人妻无码 | 人妻aⅴ无码一区二区三区 | 亚洲综合精品香蕉久久网 | 夜精品a片一区二区三区无码白浆 | 男人和女人高潮免费网站 | 国产suv精品一区二区五 | 在线观看国产一区二区三区 | 欧美第一黄网免费网站 | 奇米影视7777久久精品人人爽 | 午夜福利不卡在线视频 | 精品无码国产一区二区三区av | 蜜桃视频韩日免费播放 | 亚洲高清偷拍一区二区三区 | 精品国产麻豆免费人成网站 | 精品厕所偷拍各类美女tp嘘嘘 | 国语自产偷拍精品视频偷 | 精品少妇爆乳无码av无码专区 | 青青青手机频在线观看 | 国产亚洲tv在线观看 | 国产精品久久国产精品99 | 国产香蕉尹人视频在线 | 99久久久无码国产精品免费 | 国产激情综合五月久久 | 亚洲日韩乱码中文无码蜜桃臀网站 | 天天躁日日躁狠狠躁免费麻豆 | 强伦人妻一区二区三区视频18 | 熟妇人妻无乱码中文字幕 | 人人妻人人澡人人爽欧美一区 | 激情综合激情五月俺也去 | 亚洲欧美综合区丁香五月小说 | 野外少妇愉情中文字幕 | 欧洲美熟女乱又伦 | 日韩欧美成人免费观看 | 午夜时刻免费入口 | 国产av剧情md精品麻豆 | 久久久久久av无码免费看大片 | 蜜桃av蜜臀av色欲av麻 999久久久国产精品消防器材 | 国产精品资源一区二区 | 亚洲欧洲日本综合aⅴ在线 | 久久精品丝袜高跟鞋 | 欧美黑人巨大xxxxx | 精品偷自拍另类在线观看 | 99视频精品全部免费免费观看 | 欧洲欧美人成视频在线 | 国产超级va在线观看视频 | 18禁黄网站男男禁片免费观看 | 亚洲熟妇色xxxxx欧美老妇y | 亚洲 欧美 激情 小说 另类 | 国产9 9在线 | 中文 | 精品无码av一区二区三区 | 熟妇女人妻丰满少妇中文字幕 | 四虎国产精品免费久久 | 一本久道久久综合狠狠爱 | 欧美变态另类xxxx | 51国偷自产一区二区三区 | 女高中生第一次破苞av | 国产人妻人伦精品1国产丝袜 | 精品亚洲韩国一区二区三区 | 动漫av网站免费观看 | 少妇厨房愉情理9仑片视频 | 成人精品天堂一区二区三区 | 国产 精品 自在自线 | 日韩人妻无码一区二区三区久久99 | 波多野结衣高清一区二区三区 | 国产精品18久久久久久麻辣 | 亚洲 另类 在线 欧美 制服 | 一本大道久久东京热无码av | 少妇的肉体aa片免费 | 国产精品国产自线拍免费软件 | 永久免费观看美女裸体的网站 | 日本大乳高潮视频在线观看 | 亚洲欧美日韩成人高清在线一区 | 无码纯肉视频在线观看 | 欧美性猛交内射兽交老熟妇 | 少妇被粗大的猛进出69影院 | 中文字幕精品av一区二区五区 | 亚洲精品中文字幕 | 亚洲狠狠色丁香婷婷综合 | 精品国产成人一区二区三区 | 国产人妻大战黑人第1集 | 中文字幕av伊人av无码av | 国产精品高潮呻吟av久久 | 亚洲自偷自偷在线制服 | 六月丁香婷婷色狠狠久久 | 欧美阿v高清资源不卡在线播放 | 久久国产精品二国产精品 | 永久免费精品精品永久-夜色 | 日韩av无码一区二区三区 | 亚洲色欲色欲天天天www | 亚洲中文字幕无码中文字在线 | 国产激情无码一区二区 | 麻豆国产人妻欲求不满谁演的 | 天堂亚洲免费视频 | 国产精品亚洲а∨无码播放麻豆 | аⅴ资源天堂资源库在线 | 日韩在线不卡免费视频一区 | 沈阳熟女露脸对白视频 | 成人精品一区二区三区中文字幕 | 97无码免费人妻超级碰碰夜夜 | 天堂久久天堂av色综合 | 免费视频欧美无人区码 | 成人免费视频视频在线观看 免费 | 免费网站看v片在线18禁无码 | 伊人久久大香线蕉av一区二区 | 在线精品亚洲一区二区 | 无码一区二区三区在线 | а√资源新版在线天堂 | 国产成人综合美国十次 | 亚洲 激情 小说 另类 欧美 | 狠狠躁日日躁夜夜躁2020 | 高清无码午夜福利视频 | 久久综合网欧美色妞网 | 亚洲精品一区二区三区大桥未久 | 国产精品怡红院永久免费 | 东京热无码av男人的天堂 | 少妇性l交大片 | 熟女少妇人妻中文字幕 | 影音先锋中文字幕无码 | 日韩亚洲欧美中文高清在线 | 欧美老妇与禽交 | 亚洲一区二区三区香蕉 | 国产成人无码专区 | 中文毛片无遮挡高清免费 | 久久国产36精品色熟妇 | 曰本女人与公拘交酡免费视频 | 对白脏话肉麻粗话av | 国产亚洲精品久久久久久大师 | 在线a亚洲视频播放在线观看 | 精品无人国产偷自产在线 | 欧美性生交活xxxxxdddd | 婷婷五月综合缴情在线视频 | 无码av最新清无码专区吞精 | 日产国产精品亚洲系列 | 国产又爽又黄又刺激的视频 | 又色又爽又黄的美女裸体网站 | 久久婷婷五月综合色国产香蕉 | a国产一区二区免费入口 | 久久99精品国产麻豆蜜芽 | 免费看男女做好爽好硬视频 | 玩弄人妻少妇500系列视频 | 国产精品久久精品三级 | 日本大香伊一区二区三区 | 婷婷丁香六月激情综合啪 | 99国产精品白浆在线观看免费 | 国产性生交xxxxx无码 | 国产农村妇女aaaaa视频 撕开奶罩揉吮奶头视频 | 亚洲精品国产精品乱码不卡 | 中文字幕 亚洲精品 第1页 | 亚洲の无码国产の无码影院 | 国产特级毛片aaaaaaa高清 | 色综合久久久久综合一本到桃花网 | 成年美女黄网站色大免费视频 | 欧美日韩人成综合在线播放 | 国产精品香蕉在线观看 | 久久人人爽人人爽人人片ⅴ | 午夜福利电影 | 熟女体下毛毛黑森林 | 人妻中文无码久热丝袜 | 久久午夜无码鲁丝片秋霞 | 玩弄少妇高潮ⅹxxxyw | 天天摸天天透天天添 | 中文字幕日韩精品一区二区三区 | 色综合视频一区二区三区 | 国产成人精品久久亚洲高清不卡 | 亚洲精品无码国产 | 精品久久久中文字幕人妻 | 欧美 日韩 人妻 高清 中文 | 无人区乱码一区二区三区 | 巨爆乳无码视频在线观看 | 国产 浪潮av性色四虎 | 久久久国产精品无码免费专区 | 亚洲va欧美va天堂v国产综合 | 狠狠噜狠狠狠狠丁香五月 | 荫蒂添的好舒服视频囗交 | 精品国产福利一区二区 | 99久久人妻精品免费一区 | 1000部夫妻午夜免费 | 欧美三级a做爰在线观看 | 人妻少妇精品无码专区动漫 | 成人aaa片一区国产精品 | 漂亮人妻洗澡被公强 日日躁 | 国产精品18久久久久久麻辣 | 色综合久久中文娱乐网 | 两性色午夜视频免费播放 | 亚洲日本在线电影 | 西西人体www44rt大胆高清 | 国产精品沙发午睡系列 | 双乳奶水饱满少妇呻吟 | 久久久久久av无码免费看大片 | 色欲久久久天天天综合网精品 | 亚洲一区二区三区国产精华液 | 亚洲国产成人av在线观看 | 波多野结衣一区二区三区av免费 | 国产精品久久国产三级国 | 国产无遮挡又黄又爽又色 | 亚洲欧美国产精品专区久久 | 国产精品久久久久久久9999 | 精品乱子伦一区二区三区 | 中文字幕乱妇无码av在线 | 国产乱码精品一品二品 | 亚洲一区二区三区四区 | 日本又色又爽又黄的a片18禁 | 一本久道高清无码视频 | 日本护士毛茸茸高潮 | 性做久久久久久久免费看 | 中文字幕无码av激情不卡 | 亚洲日本va中文字幕 | 久久国产精品精品国产色婷婷 | 精品亚洲成av人在线观看 | 野狼第一精品社区 | 欧美性猛交xxxx富婆 | 国内少妇偷人精品视频 | 亚洲の无码国产の无码步美 | 亚洲第一无码av无码专区 | 无码人中文字幕 | 成人片黄网站色大片免费观看 | 国产免费久久精品国产传媒 | 亚洲人成无码网www | 国产精品无码久久av | 国产精品亚洲专区无码不卡 | 中文字幕人妻丝袜二区 | 精品午夜福利在线观看 | 欧美熟妇另类久久久久久多毛 | 国产成人午夜福利在线播放 | 亚洲 欧美 激情 小说 另类 | 青草青草久热国产精品 | 男女爱爱好爽视频免费看 | 欧洲美熟女乱又伦 | 最新国产麻豆aⅴ精品无码 | 99久久精品无码一区二区毛片 | 亚洲欧美日韩国产精品一区二区 | 欧美zoozzooz性欧美 | 亚洲色www成人永久网址 | 欧美日韩在线亚洲综合国产人 | 内射巨臀欧美在线视频 | 无码人妻黑人中文字幕 | 国产精品亚洲五月天高清 | 久久国产精品精品国产色婷婷 | 国产精品久久久久久久9999 | 午夜免费福利小电影 | 日本饥渴人妻欲求不满 | 久久精品中文字幕大胸 | 99久久久无码国产aaa精品 | 亚洲爆乳无码专区 | 鲁大师影院在线观看 | 奇米综合四色77777久久 东京无码熟妇人妻av在线网址 | 色婷婷综合激情综在线播放 | 日日躁夜夜躁狠狠躁 | 无码一区二区三区在线 | 狠狠色色综合网站 | 亚洲人亚洲人成电影网站色 | 日本www一道久久久免费榴莲 | v一区无码内射国产 | 少妇人妻av毛片在线看 | 国产亚洲精品久久久ai换 | 国产 浪潮av性色四虎 | 少妇久久久久久人妻无码 | 色情久久久av熟女人妻网站 | 中文字幕色婷婷在线视频 | 成人精品一区二区三区中文字幕 | 色综合久久久无码中文字幕 | 国内老熟妇对白xxxxhd | 国产偷自视频区视频 | 久精品国产欧美亚洲色aⅴ大片 | 中文字幕乱码人妻二区三区 | 中文毛片无遮挡高清免费 | 国产亚洲美女精品久久久2020 | 国产午夜无码精品免费看 | 国产在线一区二区三区四区五区 | 狠狠噜狠狠狠狠丁香五月 | 俺去俺来也www色官网 | 99er热精品视频 | 国产无套内射久久久国产 | 亚洲欧美国产精品专区久久 | 久久zyz资源站无码中文动漫 | 国产小呦泬泬99精品 | 极品尤物被啪到呻吟喷水 | 日本精品高清一区二区 | 亚洲а∨天堂久久精品2021 | 成熟人妻av无码专区 | 香港三级日本三级妇三级 | 一二三四在线观看免费视频 | 夜夜夜高潮夜夜爽夜夜爰爰 | 日本www一道久久久免费榴莲 | 无码人中文字幕 | 夜精品a片一区二区三区无码白浆 | 亚洲娇小与黑人巨大交 | 亚洲另类伦春色综合小说 | 国产无遮挡吃胸膜奶免费看 | 久久午夜无码鲁丝片午夜精品 | 欧美日本免费一区二区三区 | 国产精品成人av在线观看 | 日日摸夜夜摸狠狠摸婷婷 | 人人爽人人爽人人片av亚洲 | 性色欲网站人妻丰满中文久久不卡 | 亚洲国产精品一区二区美利坚 | 无码任你躁久久久久久久 | 精品国产成人一区二区三区 | 欧美自拍另类欧美综合图片区 | 国产精品第一国产精品 | 天干天干啦夜天干天2017 | 丝袜 中出 制服 人妻 美腿 | 国产香蕉尹人视频在线 | 国产色精品久久人妻 | 欧美人与牲动交xxxx | 久久精品中文字幕一区 | 亚洲成av人片天堂网无码】 | 久久精品中文字幕一区 | 国产精品二区一区二区aⅴ污介绍 | 成人无码视频在线观看网站 | 中文字幕无线码免费人妻 | 亚洲另类伦春色综合小说 | 无遮无挡爽爽免费视频 | 色五月丁香五月综合五月 | 欧美人与禽zoz0性伦交 | 亚洲一区二区三区偷拍女厕 | 少妇人妻av毛片在线看 | 欧美日韩久久久精品a片 | 日韩少妇白浆无码系列 | 久久久久久av无码免费看大片 | 亚洲成色在线综合网站 | 欧美精品无码一区二区三区 | 亚洲欧洲日本综合aⅴ在线 | 性生交大片免费看女人按摩摩 | 久久这里只有精品视频9 | 国内精品一区二区三区不卡 | 少妇无码av无码专区在线观看 | 国产电影无码午夜在线播放 | 高清不卡一区二区三区 | 国产精品久免费的黄网站 | 四虎国产精品免费久久 | 日本一区二区更新不卡 | 欧美黑人巨大xxxxx | 国内揄拍国内精品少妇国语 | 国产精品亚洲专区无码不卡 | 中文字幕无码免费久久99 | 牛和人交xxxx欧美 | 久久精品视频在线看15 | 日韩成人一区二区三区在线观看 | 学生妹亚洲一区二区 | 亚洲色偷偷偷综合网 | 成年美女黄网站色大免费视频 | 国产亚洲欧美日韩亚洲中文色 | 免费无码一区二区三区蜜桃大 | 亚洲a无码综合a国产av中文 | 3d动漫精品啪啪一区二区中 | 97色伦图片97综合影院 | 黑人巨大精品欧美一区二区 | 中文字幕av日韩精品一区二区 | 国产美女极度色诱视频www | 久久www免费人成人片 | 精品人妻人人做人人爽 | 亚洲综合在线一区二区三区 | 人妻少妇被猛烈进入中文字幕 | 免费无码一区二区三区蜜桃大 | 色欲av亚洲一区无码少妇 | 亚洲中文字幕在线观看 | 免费看少妇作爱视频 | 无码国产激情在线观看 | 国产精品理论片在线观看 | 亚洲色欲久久久综合网东京热 | 亚洲色大成网站www国产 | 亚洲综合伊人久久大杳蕉 | 亚洲欧美色中文字幕在线 | 老熟妇仑乱视频一区二区 | 波多野结衣 黑人 | 国産精品久久久久久久 | 成熟妇人a片免费看网站 | 粉嫩少妇内射浓精videos | 欧美丰满少妇xxxx性 | 十八禁视频网站在线观看 | 久久久中文字幕日本无吗 | 国产一区二区三区精品视频 | 欧美人与动性行为视频 | 激情人妻另类人妻伦 | 成人毛片一区二区 | 国产黄在线观看免费观看不卡 | 最新国产麻豆aⅴ精品无码 | 国产成人人人97超碰超爽8 | 色欲av亚洲一区无码少妇 | 99riav国产精品视频 | 久久97精品久久久久久久不卡 | 狠狠综合久久久久综合网 | yw尤物av无码国产在线观看 | 亚洲国产av精品一区二区蜜芽 | 免费男性肉肉影院 | 青青草原综合久久大伊人精品 | 精品人妻中文字幕有码在线 | аⅴ资源天堂资源库在线 | 久久综合九色综合欧美狠狠 | 2020久久香蕉国产线看观看 | 老司机亚洲精品影院 | 亚欧洲精品在线视频免费观看 | 免费乱码人妻系列无码专区 | 狠狠色色综合网站 | 亚洲欧美日韩国产精品一区二区 | 一个人免费观看的www视频 | 国产av无码专区亚洲a∨毛片 | 亚洲人成无码网www | 久久精品国产99精品亚洲 | 中文字幕中文有码在线 | 久久精品国产精品国产精品污 | 国产婷婷色一区二区三区在线 | 日日干夜夜干 | 久久亚洲日韩精品一区二区三区 | 300部国产真实乱 | 久久综合激激的五月天 | 久久精品99久久香蕉国产色戒 | 午夜熟女插插xx免费视频 | 无码人妻av免费一区二区三区 | 亚洲欧美日韩综合久久久 | 国产网红无码精品视频 | 天天躁日日躁狠狠躁免费麻豆 | 亚洲爆乳无码专区 | 中文字幕 亚洲精品 第1页 | 欧美激情内射喷水高潮 | 亚洲va中文字幕无码久久不卡 | 国产精品人人爽人人做我的可爱 | 亚洲最大成人网站 | 撕开奶罩揉吮奶头视频 | 97资源共享在线视频 | 高潮毛片无遮挡高清免费视频 | 伊人久久大香线蕉亚洲 | 国产黄在线观看免费观看不卡 | 精品熟女少妇av免费观看 | 国产精品人妻一区二区三区四 | 国产欧美熟妇另类久久久 | 国产乱人无码伦av在线a | 国产无av码在线观看 | 日本一区二区三区免费播放 | 亚洲精品一区二区三区婷婷月 | 久久国产精品精品国产色婷婷 | 99久久婷婷国产综合精品青草免费 | 牲欲强的熟妇农村老妇女视频 | 性欧美大战久久久久久久 | 一本久道高清无码视频 | 大地资源网第二页免费观看 | 中文字幕av无码一区二区三区电影 | 国产亚洲欧美在线专区 | 欧美成人免费全部网站 | 国产亚av手机在线观看 | 四虎国产精品免费久久 | 成人三级无码视频在线观看 | 狠狠色欧美亚洲狠狠色www | 天天摸天天碰天天添 | 欧美三级不卡在线观看 | 日本精品高清一区二区 | 婷婷丁香六月激情综合啪 | 国产人妻精品一区二区三区不卡 | 撕开奶罩揉吮奶头视频 | 欧美丰满熟妇xxxx | 少妇无码一区二区二三区 | 女人被爽到呻吟gif动态图视看 | 超碰97人人做人人爱少妇 | 久久综合久久自在自线精品自 | 亚洲性无码av中文字幕 | 国产超碰人人爽人人做人人添 | 久久人人爽人人爽人人片ⅴ | 国产亲子乱弄免费视频 | 日韩亚洲欧美精品综合 | 99久久精品国产一区二区蜜芽 | 日本va欧美va欧美va精品 | 亚洲国产成人a精品不卡在线 | 午夜福利一区二区三区在线观看 | 亚洲精品中文字幕久久久久 | 人人澡人摸人人添 | 18禁黄网站男男禁片免费观看 | 精品久久8x国产免费观看 | 国产精品99爱免费视频 | 久久人人爽人人爽人人片ⅴ | 成人无码视频免费播放 | 亚洲精品综合五月久久小说 | 99国产精品白浆在线观看免费 | 97精品人妻一区二区三区香蕉 | 久久99精品久久久久久动态图 | 四虎国产精品免费久久 | 久久亚洲精品中文字幕无男同 | 影音先锋中文字幕无码 | 国产精品a成v人在线播放 | 成人亚洲精品久久久久软件 | 亚洲色www成人永久网址 | 男女下面进入的视频免费午夜 | 中文字幕 人妻熟女 | 国产成人精品优优av | 日韩欧美成人免费观看 | 精品国产乱码久久久久乱码 | 天天摸天天透天天添 | 高潮毛片无遮挡高清免费视频 | 国産精品久久久久久久 | 色诱久久久久综合网ywww | 国产精品无码成人午夜电影 | 狠狠色噜噜狠狠狠7777奇米 | 成人精品视频一区二区三区尤物 | 18黄暴禁片在线观看 | 特大黑人娇小亚洲女 | 一本无码人妻在中文字幕免费 | 日日碰狠狠躁久久躁蜜桃 | 2020最新国产自产精品 | 秋霞特色aa大片 | 99精品国产综合久久久久五月天 | 99久久人妻精品免费一区 | 日本www一道久久久免费榴莲 | 偷窥村妇洗澡毛毛多 | 国色天香社区在线视频 | 国产欧美熟妇另类久久久 | 好爽又高潮了毛片免费下载 | 麻豆精品国产精华精华液好用吗 | 亚洲gv猛男gv无码男同 | 人妻少妇精品久久 | 久久久精品国产sm最大网站 | 亚洲中文字幕av在天堂 | 国产成人无码av在线影院 | 久久精品99久久香蕉国产色戒 | 亚洲一区av无码专区在线观看 | 少妇无码吹潮 | 色诱久久久久综合网ywww | 全黄性性激高免费视频 | 精品无人区无码乱码毛片国产 | 亚洲欧洲日本综合aⅴ在线 | 在线成人www免费观看视频 | 亚洲日韩精品欧美一区二区 | 久久99精品久久久久久动态图 | 又紧又大又爽精品一区二区 | 久久久久久av无码免费看大片 | 99精品久久毛片a片 | 麻豆人妻少妇精品无码专区 | 永久黄网站色视频免费直播 | 国产精品人人妻人人爽 | 欧美老妇交乱视频在线观看 | 欧美成人午夜精品久久久 | 国产精华av午夜在线观看 | 青草青草久热国产精品 | 久久综合给合久久狠狠狠97色 | 兔费看少妇性l交大片免费 | 偷窥村妇洗澡毛毛多 | 中文精品久久久久人妻不卡 | 国内精品久久毛片一区二区 | √8天堂资源地址中文在线 | 18禁黄网站男男禁片免费观看 | 日本精品人妻无码77777 天堂一区人妻无码 | 久久久久国色av免费观看性色 | 乱码av麻豆丝袜熟女系列 | 亚洲 日韩 欧美 成人 在线观看 | 老熟女乱子伦 | 日本精品人妻无码免费大全 | 狠狠噜狠狠狠狠丁香五月 | 色偷偷人人澡人人爽人人模 | 全球成人中文在线 | 真人与拘做受免费视频一 | 日本大乳高潮视频在线观看 | 两性色午夜视频免费播放 | 性啪啪chinese东北女人 | 中文无码精品a∨在线观看不卡 | 日日噜噜噜噜夜夜爽亚洲精品 | 人人超人人超碰超国产 | 国产激情无码一区二区app | 国产精品久久久久久久影院 | 性色av无码免费一区二区三区 | 中文字幕久久久久人妻 | 久久精品女人天堂av免费观看 | 亚洲色无码一区二区三区 | 欧美精品国产综合久久 | 曰韩少妇内射免费播放 | 国产精品无码成人午夜电影 | 精品国产麻豆免费人成网站 | 国产香蕉97碰碰久久人人 | 少妇厨房愉情理9仑片视频 | 国内老熟妇对白xxxxhd | 色综合久久88色综合天天 | 99久久精品日本一区二区免费 | 亚洲成色www久久网站 | 欧洲vodafone精品性 | 无套内射视频囯产 | 大地资源网第二页免费观看 | 亚洲码国产精品高潮在线 | 国产国语老龄妇女a片 | 国产精品毛多多水多 | 99国产精品白浆在线观看免费 | 亚洲区小说区激情区图片区 | 中文字幕无码热在线视频 | 亚洲成熟女人毛毛耸耸多 | 131美女爱做视频 | 久久99精品国产麻豆 | 全球成人中文在线 | 亚洲色欲久久久综合网东京热 | 乱中年女人伦av三区 | 人妻插b视频一区二区三区 | 中文字幕日韩精品一区二区三区 | 国产综合色产在线精品 | 色综合久久久无码中文字幕 | 好爽又高潮了毛片免费下载 | 国产午夜福利亚洲第一 | 天堂无码人妻精品一区二区三区 | 在线观看国产一区二区三区 | 亚洲人成网站色7799 | 日韩精品成人一区二区三区 | 牲交欧美兽交欧美 | 精品一二三区久久aaa片 | 亚洲区小说区激情区图片区 | 国产农村乱对白刺激视频 | 婷婷综合久久中文字幕蜜桃三电影 | 亚洲日韩av一区二区三区四区 | 亚洲色偷偷男人的天堂 | 国产午夜福利100集发布 | 1000部夫妻午夜免费 | 欧美精品无码一区二区三区 | 性欧美videos高清精品 | 免费人成网站视频在线观看 | 麻豆蜜桃av蜜臀av色欲av | 1000部啪啪未满十八勿入下载 | 色婷婷综合中文久久一本 | 亚洲综合另类小说色区 | 国产av无码专区亚洲a∨毛片 | 成人片黄网站色大片免费观看 | 人妻少妇精品无码专区二区 | 无码播放一区二区三区 | 激情内射亚州一区二区三区爱妻 | 免费人成网站视频在线观看 | 日产精品高潮呻吟av久久 | 国产成人亚洲综合无码 | 国产人妻久久精品二区三区老狼 | 76少妇精品导航 | 无码国产乱人伦偷精品视频 | 99er热精品视频 | 18无码粉嫩小泬无套在线观看 | 欧美日韩亚洲国产精品 | 亚洲精品午夜国产va久久成人 | 日本一卡2卡3卡4卡无卡免费网站 国产一区二区三区影院 | 中文字幕乱码人妻二区三区 | 欧洲精品码一区二区三区免费看 | 午夜嘿嘿嘿影院 | 国产精品-区区久久久狼 | 黑人巨大精品欧美黑寡妇 | 内射老妇bbwx0c0ck | 久久久久久久女国产乱让韩 | 亚洲中文字幕无码一久久区 | 一本久道久久综合狠狠爱 | 欧洲精品码一区二区三区免费看 | 99re在线播放 | 久久久av男人的天堂 | 77777熟女视频在线观看 а天堂中文在线官网 | 清纯唯美经典一区二区 | 人人妻人人藻人人爽欧美一区 | 国产明星裸体无码xxxx视频 | 婷婷综合久久中文字幕蜜桃三电影 | 久久久久久久人妻无码中文字幕爆 | 又紧又大又爽精品一区二区 | 午夜无码区在线观看 | 老熟妇乱子伦牲交视频 | 一本色道久久综合亚洲精品不卡 | 欧美日韩一区二区三区自拍 | 全球成人中文在线 | 中文字幕乱码人妻无码久久 | 日本va欧美va欧美va精品 | 久久视频在线观看精品 | 日韩精品一区二区av在线 | 亚洲中文无码av永久不收费 | 97久久超碰中文字幕 | 国产在线一区二区三区四区五区 | 亚洲精品鲁一鲁一区二区三区 | 亚洲无人区午夜福利码高清完整版 | 131美女爱做视频 | 日韩成人一区二区三区在线观看 | 中文毛片无遮挡高清免费 | 内射巨臀欧美在线视频 | 亚洲国产精品无码久久久久高潮 | 亚洲码国产精品高潮在线 | 成人aaa片一区国产精品 | 国产精品久久久久9999小说 | 国产猛烈高潮尖叫视频免费 | 大地资源中文第3页 | 日韩视频 中文字幕 视频一区 | 99精品久久毛片a片 | 国内老熟妇对白xxxxhd | 久久国产精品二国产精品 | 日韩人妻少妇一区二区三区 | 夜精品a片一区二区三区无码白浆 | 成人精品天堂一区二区三区 | а天堂中文在线官网 | 亚洲爆乳精品无码一区二区三区 | 亚洲狠狠色丁香婷婷综合 | 欧美国产日韩亚洲中文 | 一二三四社区在线中文视频 | 国产午夜精品一区二区三区嫩草 | 色综合久久久无码网中文 | 日韩精品成人一区二区三区 | 中文字幕 人妻熟女 | 激情综合激情五月俺也去 | 奇米影视7777久久精品 | 亚洲日本在线电影 | 欧美精品国产综合久久 | 久久久久久久女国产乱让韩 | 婷婷色婷婷开心五月四房播播 | 国产成人亚洲综合无码 | 丰满人妻被黑人猛烈进入 | 国产成人精品三级麻豆 | 国产精品人人妻人人爽 | 欧美freesex黑人又粗又大 | 无码人妻少妇伦在线电影 | 久久99久久99精品中文字幕 | 亚洲成色www久久网站 | 国产真实夫妇视频 | 日日夜夜撸啊撸 | 18无码粉嫩小泬无套在线观看 | 三级4级全黄60分钟 | 中文字幕无码人妻少妇免费 | 国产特级毛片aaaaaaa高清 | 国产在线一区二区三区四区五区 | 少妇的肉体aa片免费 | 性欧美牲交xxxxx视频 | 两性色午夜视频免费播放 | 伊人色综合久久天天小片 | 亚洲精品鲁一鲁一区二区三区 | 在线观看欧美一区二区三区 | 日韩av无码中文无码电影 | 天堂亚洲2017在线观看 | 在线观看免费人成视频 | 国产精品va在线观看无码 | 女人色极品影院 | 国产午夜亚洲精品不卡 | 国产精品怡红院永久免费 | 又黄又爽又色的视频 | 精品乱子伦一区二区三区 | 一二三四社区在线中文视频 | 国产sm调教视频在线观看 | 亚洲の无码国产の无码影院 | 男女爱爱好爽视频免费看 | а√天堂www在线天堂小说 | 欧美乱妇无乱码大黄a片 | 午夜福利试看120秒体验区 | 日本va欧美va欧美va精品 | 国产成人综合色在线观看网站 | 亚洲精品综合一区二区三区在线 | 精品欧美一区二区三区久久久 | 国产精品亚洲五月天高清 | 国产香蕉97碰碰久久人人 | 亚洲狠狠色丁香婷婷综合 | 久精品国产欧美亚洲色aⅴ大片 | 欧美日韩一区二区免费视频 | 国产精品国产三级国产专播 | 欧美国产亚洲日韩在线二区 | 欧美亚洲日韩国产人成在线播放 | 男女下面进入的视频免费午夜 | 亚洲一区二区三区无码久久 | 精品熟女少妇av免费观看 | 伊人久久大香线焦av综合影院 | 亚洲综合精品香蕉久久网 | 激情五月综合色婷婷一区二区 | 亚洲色偷偷男人的天堂 | 77777熟女视频在线观看 а天堂中文在线官网 | 一区二区三区高清视频一 | 午夜精品一区二区三区在线观看 | 在线播放无码字幕亚洲 | 久久国产自偷自偷免费一区调 | 中文字幕乱码人妻无码久久 | 久久www免费人成人片 | 99re在线播放 | 午夜精品久久久久久久 | 波多野结衣乳巨码无在线观看 | 国产成人综合色在线观看网站 | 日日麻批免费40分钟无码 | 欧美成人高清在线播放 | 性欧美videos高清精品 | 荡女精品导航 | 亚洲人成影院在线无码按摩店 | 国产av剧情md精品麻豆 | 久久99精品国产麻豆 | 日本在线高清不卡免费播放 | 欧美 亚洲 国产 另类 | 国产成人精品一区二区在线小狼 | 熟女少妇人妻中文字幕 | 日韩av激情在线观看 | 国产精品免费大片 | 无码国模国产在线观看 | 大肉大捧一进一出视频出来呀 | 乱码午夜-极国产极内射 | 99久久精品国产一区二区蜜芽 | 亚洲va中文字幕无码久久不卡 | 水蜜桃亚洲一二三四在线 | 少妇无码一区二区二三区 | 午夜精品久久久内射近拍高清 | 伊人久久婷婷五月综合97色 | 呦交小u女精品视频 | 精品久久综合1区2区3区激情 | 一本久久a久久精品vr综合 | 色婷婷av一区二区三区之红樱桃 | 午夜福利一区二区三区在线观看 | 日韩精品a片一区二区三区妖精 | 97精品人妻一区二区三区香蕉 | 综合人妻久久一区二区精品 | 亚洲午夜久久久影院 | 中文精品无码中文字幕无码专区 | 午夜无码人妻av大片色欲 | 欧美日本免费一区二区三区 | 亚洲国产欧美国产综合一区 | 色一情一乱一伦一区二区三欧美 | 亚洲综合伊人久久大杳蕉 | 两性色午夜免费视频 | 亚洲日韩一区二区 | 日本饥渴人妻欲求不满 | 给我免费的视频在线观看 | 超碰97人人做人人爱少妇 | 国产精品无码一区二区三区不卡 | 欧美三级不卡在线观看 | 美女极度色诱视频国产 | 中文字幕无码免费久久99 | 亚洲第一网站男人都懂 | 色狠狠av一区二区三区 | 无码毛片视频一区二区本码 | 性色欲网站人妻丰满中文久久不卡 | 97精品人妻一区二区三区香蕉 | 久久综合九色综合97网 | 国产内射爽爽大片视频社区在线 | 久久久久亚洲精品中文字幕 | 欧美刺激性大交 | 无遮挡国产高潮视频免费观看 | 日本一卡2卡3卡四卡精品网站 | 婷婷五月综合激情中文字幕 | 久在线观看福利视频 | 国产在线精品一区二区高清不卡 | 久久zyz资源站无码中文动漫 | 国产成人综合色在线观看网站 | 亚洲精品一区三区三区在线观看 | 久久久精品人妻久久影视 | 亚洲自偷自偷在线制服 | 亚洲日韩av一区二区三区四区 | 中文字幕人妻无码一夲道 | 日日噜噜噜噜夜夜爽亚洲精品 | 久久亚洲中文字幕精品一区 | 亚洲一区二区三区四区 | 国产一区二区三区精品视频 | 国产在线精品一区二区三区直播 | 久久亚洲中文字幕无码 | 欧美35页视频在线观看 | 激情内射日本一区二区三区 | 亚洲成av人综合在线观看 | 女人被爽到呻吟gif动态图视看 | 亚洲日本一区二区三区在线 | 日本成熟视频免费视频 | 人妻天天爽夜夜爽一区二区 | 熟妇激情内射com | 国产成人综合色在线观看网站 | 精品久久久无码人妻字幂 | 草草网站影院白丝内射 | 国产精品久久久久久亚洲影视内衣 | 亚洲人交乣女bbw | 中文久久乱码一区二区 | 99精品国产综合久久久久五月天 | 国产九九九九九九九a片 | 久久亚洲中文字幕无码 | 99精品视频在线观看免费 | 亚洲爆乳无码专区 | 精品国产aⅴ无码一区二区 | 亚洲国产精品久久久久久 | 久久国产精品二国产精品 | 天天摸天天碰天天添 | 亚洲 另类 在线 欧美 制服 | 中文字幕亚洲情99在线 | 天堂无码人妻精品一区二区三区 | 国产精品毛多多水多 | 亚洲中文字幕在线观看 | 成人欧美一区二区三区 | 日本一区二区三区免费高清 | 精品午夜福利在线观看 | 国产手机在线αⅴ片无码观看 | 欧美xxxx黑人又粗又长 | 欧美一区二区三区 | 日韩少妇白浆无码系列 | 亚洲一区二区观看播放 | 成人女人看片免费视频放人 | 久久精品中文字幕大胸 | 精品国产乱码久久久久乱码 | 2020久久超碰国产精品最新 | 国产精品成人av在线观看 | 人人超人人超碰超国产 | 狠狠综合久久久久综合网 | 狂野欧美激情性xxxx | 少妇被粗大的猛进出69影院 | aⅴ亚洲 日韩 色 图网站 播放 | 婷婷丁香五月天综合东京热 | 色综合视频一区二区三区 | 又大又硬又黄的免费视频 | 亚洲精品一区二区三区在线观看 | 无码人妻精品一区二区三区下载 | 欧美成人免费全部网站 | 激情内射亚州一区二区三区爱妻 | 亚洲自偷自偷在线制服 | 久久久久se色偷偷亚洲精品av | 男人的天堂2018无码 | 精品国产一区二区三区四区在线看 | 亚洲理论电影在线观看 | 久久97精品久久久久久久不卡 | 久久精品无码一区二区三区 | 亚洲熟妇色xxxxx欧美老妇y | 欧美精品无码一区二区三区 | 亚洲精品国偷拍自产在线观看蜜桃 | 中文字幕人成乱码熟女app | 激情亚洲一区国产精品 | 色欲久久久天天天综合网精品 | 国产精品第一区揄拍无码 | 小sao货水好多真紧h无码视频 | 精品无码国产自产拍在线观看蜜 | 久久亚洲a片com人成 | 300部国产真实乱 | 国产综合色产在线精品 | 免费人成在线视频无码 | 日本va欧美va欧美va精品 | 色欲综合久久中文字幕网 | 久久精品人妻少妇一区二区三区 | 精品欧洲av无码一区二区三区 | 97资源共享在线视频 | 丰满人妻精品国产99aⅴ | 国产精品人人爽人人做我的可爱 | 男女下面进入的视频免费午夜 | 熟妇激情内射com | 蜜臀av在线播放 久久综合激激的五月天 | 亚洲人成影院在线观看 | 最新版天堂资源中文官网 | 日韩欧美中文字幕公布 | 98国产精品综合一区二区三区 | 成人免费视频在线观看 | 人人爽人人爽人人片av亚洲 | 人妻与老人中文字幕 | 久久精品中文字幕一区 | 4hu四虎永久在线观看 | 性欧美疯狂xxxxbbbb | 亚洲欧美精品伊人久久 | 久久亚洲国产成人精品性色 | 久久97精品久久久久久久不卡 | 久久亚洲a片com人成 | 国产精品国产自线拍免费软件 | 久热国产vs视频在线观看 | 国产精品久久久久影院嫩草 | 人妻尝试又大又粗久久 | 久久久中文久久久无码 | 国产精品无码mv在线观看 | 樱花草在线播放免费中文 | 人妻无码αv中文字幕久久琪琪布 | 午夜熟女插插xx免费视频 | 中文字幕人妻无码一夲道 | 给我免费的视频在线观看 | 亚洲毛片av日韩av无码 | 无码帝国www无码专区色综合 | 偷窥日本少妇撒尿chinese | 欧美日韩色另类综合 | 粗大的内捧猛烈进出视频 | 精品久久久无码人妻字幂 | 亚洲а∨天堂久久精品2021 | 无遮挡啪啪摇乳动态图 | 在线 国产 欧美 亚洲 天堂 | 性做久久久久久久久 | 内射白嫩少妇超碰 | 国产又爽又黄又刺激的视频 | 好屌草这里只有精品 | 人人妻在人人 | 亚洲另类伦春色综合小说 | 国产成人久久精品流白浆 | 亚洲人亚洲人成电影网站色 | 成年美女黄网站色大免费全看 | 亚洲一区二区三区四区 | 在线播放无码字幕亚洲 | 在线成人www免费观看视频 | 精品国产青草久久久久福利 | 国产成人无码区免费内射一片色欲 | 国产精品久久久久久无码 | 精品人妻人人做人人爽 | 一本久道高清无码视频 | 亚洲精品综合一区二区三区在线 | 国内精品九九久久久精品 | 波多野42部无码喷潮在线 | 国产精品亚洲五月天高清 | 亚洲精品中文字幕久久久久 | 帮老师解开蕾丝奶罩吸乳网站 | 无码国产色欲xxxxx视频 | 日韩人妻系列无码专区 | 国产高清不卡无码视频 | 爽爽影院免费观看 | 国产香蕉尹人视频在线 | 精品午夜福利在线观看 | 日本一卡2卡3卡四卡精品网站 | 日日麻批免费40分钟无码 | 狠狠色欧美亚洲狠狠色www | 午夜嘿嘿嘿影院 | 精品日本一区二区三区在线观看 | 中文字幕日韩精品一区二区三区 | 欧美精品一区二区精品久久 | 男女下面进入的视频免费午夜 | 丰满人妻翻云覆雨呻吟视频 | 欧美人与动性行为视频 | 2019nv天堂香蕉在线观看 | 色五月五月丁香亚洲综合网 | 久久亚洲a片com人成 | 成熟妇人a片免费看网站 | 国产成人午夜福利在线播放 | 亚洲自偷精品视频自拍 | 欧美国产亚洲日韩在线二区 | 自拍偷自拍亚洲精品被多人伦好爽 | 偷窥日本少妇撒尿chinese | 狠狠亚洲超碰狼人久久 | 国内精品久久久久久中文字幕 | 狠狠cao日日穞夜夜穞av | 午夜精品久久久久久久 | 久久久www成人免费毛片 | 麻豆国产人妻欲求不满 | 国产高潮视频在线观看 | 欧美真人作爱免费视频 | 亚洲欧美色中文字幕在线 | 日韩精品无码一本二本三本色 | 少妇无码av无码专区在线观看 | 水蜜桃av无码 | 性欧美熟妇videofreesex | 真人与拘做受免费视频一 | 国产卡一卡二卡三 | 亚洲高清偷拍一区二区三区 | 国产精品无码久久av | 无套内谢老熟女 | 牲欲强的熟妇农村老妇女 | 日日躁夜夜躁狠狠躁 | 成人无码视频免费播放 | 国产色在线 | 国产 | 免费看男女做好爽好硬视频 | 无码av免费一区二区三区试看 | a在线观看免费网站大全 | 国产无遮挡又黄又爽又色 | 麻豆蜜桃av蜜臀av色欲av | 国产亚洲精品久久久久久国模美 | 18精品久久久无码午夜福利 | 樱花草在线播放免费中文 | 日产国产精品亚洲系列 | 麻豆成人精品国产免费 | 欧美日韩综合一区二区三区 | 久久国产精品精品国产色婷婷 | 国产午夜精品一区二区三区嫩草 | 久久久久久国产精品无码下载 | 亚洲小说图区综合在线 | 麻豆md0077饥渴少妇 | www国产亚洲精品久久网站 | 男女下面进入的视频免费午夜 | 久久国产自偷自偷免费一区调 | 色诱久久久久综合网ywww | 久久成人a毛片免费观看网站 | 永久免费精品精品永久-夜色 | 久久久久久九九精品久 | 国产在线精品一区二区三区直播 | 日产国产精品亚洲系列 | a在线观看免费网站大全 | 亚洲欧洲日本无在线码 | 夜夜高潮次次欢爽av女 | 我要看www免费看插插视频 | 国内揄拍国内精品少妇国语 | 亚洲国产精品成人久久蜜臀 | 东京热一精品无码av | 乱码午夜-极国产极内射 | 欧美 日韩 人妻 高清 中文 | 三级4级全黄60分钟 | 国产无av码在线观看 | 97se亚洲精品一区 | 国产乱码精品一品二品 | 精品成在人线av无码免费看 | 大地资源网第二页免费观看 | 国产精品亚洲lv粉色 | 牲交欧美兽交欧美 | 亚洲综合色区中文字幕 | 日本一区二区更新不卡 | 窝窝午夜理论片影院 | 激情内射日本一区二区三区 | 国产乱码精品一品二品 | 无套内谢老熟女 | 久9re热视频这里只有精品 | 午夜成人1000部免费视频 | 欧美性生交活xxxxxdddd | 久久综合久久自在自线精品自 | 小sao货水好多真紧h无码视频 | 精品无人国产偷自产在线 | 午夜丰满少妇性开放视频 | 色一情一乱一伦一视频免费看 | 国精产品一区二区三区 | 亚洲精品综合一区二区三区在线 | 99久久婷婷国产综合精品青草免费 | 无码吃奶揉捏奶头高潮视频 | 国产精品第一区揄拍无码 | 国产精品高潮呻吟av久久 | 久久人妻内射无码一区三区 | 亚洲大尺度无码无码专区 | 国产精品久久久久无码av色戒 | 亚洲成av人综合在线观看 | 成人av无码一区二区三区 | 精品水蜜桃久久久久久久 | 欧美精品无码一区二区三区 | 宝宝好涨水快流出来免费视频 | 亚洲精品鲁一鲁一区二区三区 | 国产午夜无码视频在线观看 | 欧美 日韩 人妻 高清 中文 | 欧美丰满少妇xxxx性 | 亚洲精品久久久久avwww潮水 | 18黄暴禁片在线观看 | 风流少妇按摩来高潮 | 丰满岳乱妇在线观看中字无码 | 一区二区三区高清视频一 | 中文字幕人成乱码熟女app | 成熟妇人a片免费看网站 | 性色欲网站人妻丰满中文久久不卡 | 丰满诱人的人妻3 | 国产成人精品久久亚洲高清不卡 | 丰满人妻翻云覆雨呻吟视频 | 黑人粗大猛烈进出高潮视频 | 成人影院yy111111在线观看 | 久久熟妇人妻午夜寂寞影院 | 婷婷五月综合缴情在线视频 | 久久99精品国产.久久久久 | 久久综合网欧美色妞网 | 日日噜噜噜噜夜夜爽亚洲精品 | 一本色道久久综合狠狠躁 | 亚洲熟女一区二区三区 | 国产乱人伦app精品久久 国产在线无码精品电影网 国产国产精品人在线视 | 一本一道久久综合久久 | 国产在线aaa片一区二区99 | 丝袜人妻一区二区三区 | 国产免费无码一区二区视频 | 国产人妻久久精品二区三区老狼 | 97夜夜澡人人双人人人喊 | 亚洲自偷自偷在线制服 | 狠狠亚洲超碰狼人久久 | 99久久婷婷国产综合精品青草免费 | 久久精品丝袜高跟鞋 | 久久综合久久自在自线精品自 | 精品少妇爆乳无码av无码专区 | 人妻夜夜爽天天爽三区 | 最近的中文字幕在线看视频 | 少妇被黑人到高潮喷出白浆 | 日本精品少妇一区二区三区 | 国产乱人伦app精品久久 国产在线无码精品电影网 国产国产精品人在线视 | 国产在线aaa片一区二区99 | 5858s亚洲色大成网站www | 日本肉体xxxx裸交 | 成人免费视频在线观看 | 我要看www免费看插插视频 | 嫩b人妻精品一区二区三区 | 亚洲aⅴ无码成人网站国产app | 免费看少妇作爱视频 | 国产av无码专区亚洲awww | 日本一卡2卡3卡四卡精品网站 | 精品国产一区二区三区四区在线看 | 欧美亚洲国产一区二区三区 | 亚洲自偷精品视频自拍 | 51国偷自产一区二区三区 | 人人妻人人澡人人爽人人精品浪潮 | 精品久久久无码人妻字幂 | 国产无套内射久久久国产 | 一本无码人妻在中文字幕免费 | 野外少妇愉情中文字幕 | 伊人久久大香线蕉午夜 | 4hu四虎永久在线观看 | 亚洲男人av天堂午夜在 | 国产一区二区三区四区五区加勒比 | 精品无人国产偷自产在线 | 高中生自慰www网站 | 动漫av一区二区在线观看 | 人妻与老人中文字幕 | 成熟妇人a片免费看网站 | 女人被爽到呻吟gif动态图视看 | 99久久婷婷国产综合精品青草免费 | √天堂中文官网8在线 | 一个人看的www免费视频在线观看 | 成人三级无码视频在线观看 | 偷窥日本少妇撒尿chinese | 亚洲理论电影在线观看 | 亚洲精品www久久久 | 天天综合网天天综合色 | 性啪啪chinese东北女人 | 人人爽人人澡人人高潮 | 特大黑人娇小亚洲女 | 国产另类ts人妖一区二区 | 亚洲 a v无 码免 费 成 人 a v | 亚洲精品综合五月久久小说 | 久久国内精品自在自线 | 中文字幕无线码 | 激情五月综合色婷婷一区二区 | 国产成人无码a区在线观看视频app | 少妇的肉体aa片免费 | 色综合天天综合狠狠爱 | 亚洲精品欧美二区三区中文字幕 | 中文字幕色婷婷在线视频 | 亚洲а∨天堂久久精品2021 | 人人妻人人澡人人爽人人精品 | 国产精品亚洲专区无码不卡 | 青草视频在线播放 | 精品欧美一区二区三区久久久 | 少妇性l交大片 | 亚洲国产精华液网站w | 自拍偷自拍亚洲精品10p | 少妇被粗大的猛进出69影院 | 国产乱人伦av在线无码 | 久9re热视频这里只有精品 | 波多野结衣av在线观看 | 亚洲国产成人av在线观看 | 国产情侣作爱视频免费观看 | 天海翼激烈高潮到腰振不止 | 俺去俺来也在线www色官网 | 国産精品久久久久久久 | 色综合视频一区二区三区 | 少妇性l交大片欧洲热妇乱xxx | 麻豆md0077饥渴少妇 | 午夜精品久久久久久久久 | 夜夜躁日日躁狠狠久久av | 中文字幕无码免费久久9一区9 | 国产香蕉97碰碰久久人人 | 精品人妻人人做人人爽夜夜爽 | 久久无码中文字幕免费影院蜜桃 | 国产网红无码精品视频 | 综合人妻久久一区二区精品 | 国产香蕉97碰碰久久人人 | 波多野结衣一区二区三区av免费 | 国产人妻精品午夜福利免费 | 色综合久久久无码网中文 | 性欧美熟妇videofreesex | 欧美成人高清在线播放 | 水蜜桃亚洲一二三四在线 | 大肉大捧一进一出视频出来呀 | 精品厕所偷拍各类美女tp嘘嘘 | 98国产精品综合一区二区三区 | 乌克兰少妇性做爰 | 国产两女互慰高潮视频在线观看 | 东京无码熟妇人妻av在线网址 | 国产福利视频一区二区 | 国产精品资源一区二区 | 玩弄人妻少妇500系列视频 | 999久久久国产精品消防器材 | 国产av一区二区精品久久凹凸 | 亚洲天堂2017无码 | 欧美第一黄网免费网站 | 久久综合给合久久狠狠狠97色 | 亚洲中文无码av永久不收费 | 九九热爱视频精品 | 国内老熟妇对白xxxxhd | 性啪啪chinese东北女人 | 国产精品办公室沙发 | 在线播放免费人成毛片乱码 | 无码人妻久久一区二区三区不卡 | 内射老妇bbwx0c0ck | 久久熟妇人妻午夜寂寞影院 | 久久精品国产99精品亚洲 | 亚洲成av人影院在线观看 |