婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > MATLAB 全景圖切割及盒圖顯示的實現步驟

MATLAB 全景圖切割及盒圖顯示的實現步驟

熱門標簽:海南400電話如何申請 激戰2地圖標注 白銀外呼系統 唐山智能外呼系統一般多少錢 騰訊外呼線路 廣告地圖標注app 哈爾濱ai外呼系統定制 公司電話機器人 陜西金融外呼系統

part1 全景圖切割

原圖:

切割效果:


以下是切割部分步驟:
舉這張圖為例,圖片格式hdr,jpg啥的都行:

1.1 邊緣剔除

有些全景圖會自帶白灰色邊緣,若是直接進行切割便會出現如下效果:

這時候我們首先要對原圖進行白邊剔除,代碼如下:

oriPic=imread('test.hdr');
[rows,cols,~]=size(oriPic);

for i=cols:-1:1
    tempListR=oriPic(floor(rows/4):ceil(3*rows/4),i,1);
    tempListG=oriPic(floor(rows/4):ceil(3*rows/4),i,1);
    tempListB=oriPic(floor(rows/4):ceil(3*rows/4),i,1);
    if all(round(tempListR-mean(tempListR))==0)all(tempListR==tempListG)all(tempListR==tempListB)
        oriPic(:,i,:)=[];
    else
        break;
    end
end
oriPic=oriPic(:,end:-1:1,:);
for i=size(oriPic,2):-1:1
    tempListR=oriPic(floor(rows/4):ceil(3*rows/4),i,1);
    tempListG=oriPic(floor(rows/4):ceil(3*rows/4),i,1);
    tempListB=oriPic(floor(rows/4):ceil(3*rows/4),i,1);
    if all(round(tempListR-mean(tempListR))==0)all(tempListR==tempListG)all(tempListR==tempListB)
        oriPic(:,i,:)=[];
    else
        break;
    end
end
oriPic=oriPic(:,end:-1:1,:);
for i=rows:-1:1
    tempListR=oriPic(i,floor(cols/4):ceil(3*cols/4),1);
    tempListG=oriPic(i,floor(cols/4):ceil(3*cols/4),1);
    tempListB=oriPic(i,floor(cols/4):ceil(3*cols/4),1);
    if all(round(tempListR-mean(tempListR))==0)all(tempListR==tempListG)all(tempListR==tempListB)
        oriPic(i,:,:)=[];
    else
        break;
    end
end
oriPic=oriPic(end:-1:1,:,:);
for i=size(oriPic,1):-1:1
    tempListR=oriPic(i,floor(cols/4):ceil(3*cols/4),1);
    tempListG=oriPic(i,floor(cols/4):ceil(3*cols/4),1);
    tempListB=oriPic(i,floor(cols/4):ceil(3*cols/4),1);
    if all(round(tempListR-mean(tempListR))==0)all(tempListR==tempListG)all(tempListR==tempListB)
        oriPic(i,:,:)=[];
    else
        break;
    end
end
oriPic=oriPic(end:-1:1,:,:);

1.2 圖像裁剪

我們要讓完成的就是如下的變換和裁剪:


這部分其實已經有較為成熟的原理和代碼:
代碼參考:https://stackoverflow.com/questions/29678510/convert-21-equirectangular-panorama-to-cube-map

原理參考:
http://paulbourke.net/panorama/cubemaps/#1

http://paulbourke.net/panorama/cubemaps/

原理參考文章中更加清晰的變化圖:

另:
在參考代碼的基礎上,對映射像素進行了插值處理,可以使圖像更加平滑,原理如下:


主要函數代碼:

function resultPic=createCubeMapFace(oriPic,id,height,width)
    [M,N,~]=size(oriPic);
    resultPic=zeros([height,width,3]);
    an=sin(pi/4);
    ak=cos(pi/4);
    
    faceTransform=[0,0;
               pi/2,0;
               pi,0;
               -pi/2,0;
               0,-pi/2;
               0,pi];
    ftu=faceTransform(id,1);
    ftv=faceTransform(id,2);

    for y=0:height-1
        for x=0:width-1
            nx=y/height-0.5;
            ny=x/width-0.5;

            nx=nx*2*an;
            ny=ny*2*an;

            if (ftv == 0)
                u=atan2(nx, ak);
                v=atan2(ny*cos(u),ak);
                u=u+ftu;
            elseif(ftv>0)
                d=sqrt(nx*nx+ny*ny);
                v=pi/2-atan2(d,ak);
                u=atan2(ny,nx);
            else
                d=sqrt(nx*nx+ny*ny);
                v=-pi/2+atan2(d,ak);
                u=atan2(-ny,nx);
            end

            u=u/(pi);
            v=v/(pi/2);

            while(v-1)
                v=v+2;
                u=u+1;
            end
            while(v>1)
                v=v-2;
                u=u+1;
            end
            while(u-1)
                u=u+2;
            end
            while(u>1)
                u=u-2;
            end
            u=u/2+0.5;
            v=v/2+0.5;

            u=u*(N-1)+1;
            v=v*(M-1)+1;
            
            fv=floor(v);fv1=floor(v)+1;pv=v-fv;fv1(fv1>M)=M;
            fu=floor(u);fu1=floor(u)+1;pu=u-fu;fu1(fu1>N)=N;
            resultPic(x+1,y+1,:)=double(oriPic(fv,fu,:)).*(1-pv).*(1-pu)+...
                                 double(oriPic(fv1,fu,:)).*(pv).*(1-pu)+...
                                 double(oriPic(fv,fu1,:)).*(1-pv).*(pu)+...
                                 double(oriPic(fv1,fu1,:)).*(pv).*(pu);
        end
    end
    resultPic=uint8(resultPic);
end

函數調用及圖像存儲:
這里后面長寬數值可以任意設定,但是要求長寬數值一致,如果按照當前寫法,結果被存儲至result文件夾:

if ~exist('result','dir')
   mkdir('result');
end

for i=1:6
    resultPic=createCubeMapFace(oriPic,i,500,500);
    figure(i)
    imshow(resultPic)
    imwrite(resultPic,['result\',num2str(i),'.jpg'])
end

另: 如圖所示
圖片序號[1,2,3,4,5,6]分別對應圖片[右,后,左,前,上,下]

1.3 完整代碼

function panoramic2box
oriPic=imread('889027-884424860.jpg');
[rows,cols,~]=size(oriPic);

for i=cols:-1:1
    tempListR=oriPic(floor(rows/4):CEIL(3*rows/4),i,1);
    tempListG=oriPic(floor(rows/4):CEIL(3*rows/4),i,1);
    tempListB=oriPic(floor(rows/4):CEIL(3*rows/4),i,1);
    if all(round(tempListR-mean(tempListR))==0)all(tempListR==tempListG)all(tempListR==tempListB)
        oriPic(:,i,:)=[];
    else
        break;
    end
end
oriPic=oriPic(:,end:-1:1,:);
for i=size(oriPic,2):-1:1
    tempListR=oriPic(floor(rows/4):CEIL(3*rows/4),i,1);
    tempListG=oriPic(floor(rows/4):CEIL(3*rows/4),i,1);
    tempListB=oriPic(floor(rows/4):CEIL(3*rows/4),i,1);
    if all(round(tempListR-mean(tempListR))==0)all(tempListR==tempListG)all(tempListR==tempListB)
        oriPic(:,i,:)=[];
    else
        break;
    end
end
oriPic=oriPic(:,end:-1:1,:);
for i=rows:-1:1
    tempListR=oriPic(i,floor(cols/4):CEIL(3*cols/4),1);
    tempListG=oriPic(i,floor(cols/4):CEIL(3*cols/4),1);
    tempListB=oriPic(i,floor(cols/4):CEIL(3*cols/4),1);
    if all(round(tempListR-mean(tempListR))==0)all(tempListR==tempListG)all(tempListR==tempListB)
        oriPic(i,:,:)=[];
    else
        break;
    end
end
oriPic=oriPic(end:-1:1,:,:);
for i=size(oriPic,1):-1:1
    tempListR=oriPic(i,floor(cols/4):CEIL(3*cols/4),1);
    tempListG=oriPic(i,floor(cols/4):CEIL(3*cols/4),1);
    tempListB=oriPic(i,floor(cols/4):CEIL(3*cols/4),1);
    if all(round(tempListR-mean(tempListR))==0)all(tempListR==tempListG)all(tempListR==tempListB)
        oriPic(i,:,:)=[];
    else
        break;
    end
end
oriPic=oriPic(end:-1:1,:,:);
% =========================================================================
if ~exist('result','dir')
   mkdir('result');
end

for i=1:6
    resultPic=createCubeMapFace(oriPic,i,500,500);
    figure(i)
    imshow(resultPic)
    imwrite(resultPic,['result\',num2str(i),'.jpg'])
end



% =========================================================================
function resultPic=createCubeMapFace(oriPic,id,height,width)
    [M,N,~]=size(oriPic);
    resultPic=zeros([height,width,3]);
    an=sin(pi/4);
    ak=cos(pi/4);
    
    faceTransform=[0,0;
               pi/2,0;
               pi,0;
               -pi/2,0;
               0,-pi/2;
               0,pi];
    ftu=faceTransform(id,1);
    ftv=faceTransform(id,2);

    for y=0:height-1
        for x=0:width-1
            nx=y/height-0.5;
            ny=x/width-0.5;

            nx=nx*2*an;
            ny=ny*2*an;

            if (ftv == 0)
                u=atan2(nx, ak);
                v=atan2(ny*cos(u),ak);
                u=u+ftu;
            elseif(ftv>0)
                d=sqrt(nx*nx+ny*ny);
                v=pi/2-atan2(d,ak);
                u=atan2(ny,nx);
            else
                d=sqrt(nx*nx+ny*ny);
                v=-pi/2+atan2(d,ak);
                u=atan2(-ny,nx);
            end

            u=u/(pi);
            v=v/(pi/2);

            while(v-1)
                v=v+2;
                u=u+1;
            end
            while(v>1)
                v=v-2;
                u=u+1;
            end
            while(u-1)
                u=u+2;
            end
            while(u>1)
                u=u-2;
            end
            u=u/2+0.5;
            v=v/2+0.5;

            u=u*(N-1)+1;
            v=v*(M-1)+1;
            
            fv=floor(v);fv1=floor(v)+1;pv=v-fv;fv1(fv1>M)=M;
            fu=floor(u);fu1=floor(u)+1;pu=u-fu;fu1(fu1>N)=N;
            resultPic(x+1,y+1,:)=double(oriPic(fv,fu,:)).*(1-pv).*(1-pu)+...
                                 double(oriPic(fv1,fu,:)).*(pv).*(1-pu)+...
                                 double(oriPic(fv,fu1,:)).*(1-pv).*(pu)+...
                                 double(oriPic(fv1,fu1,:)).*(pv).*(pu);
        end
    end
    resultPic=uint8(resultPic);
end
end

1.4 其他幾組切割結果

圖片源自:https://www.cgmodel.com/article/9004.html






part2 盒圖展示

2.1 曲面繪制

使用surf繪制各個曲面后,并為各個曲面貼圖:

for i=1:6
    oriPic.(['p',num2str(i)])=imread(['result\',num2str(i),'.jpg']);   
end
[rows,cols,~]=size(oriPic.p1);
[baseXY,baseZ]=meshgrid(1:cols,rows:-1:1);

ax=gca;hold(ax,'on')


surf(baseXY(:,end:-1:1)-(1+rows)/2,-(rows-1)./2.*ones(size(baseXY)),baseZ,'CData',oriPic.p1,'EdgeColor','none','FaceColor','interp')
surf(-(rows-1)./2.*ones(size(baseXY)),baseXY-(1+rows)/2,baseZ,'CData',oriPic.p2,'EdgeColor','none','FaceColor','interp')
surf(baseXY-(1+rows)/2,(rows-1)./2.*ones(size(baseXY)),baseZ,'CData',oriPic.p3,'EdgeColor','none','FaceColor','interp')
surf((rows-1)./2.*ones(size(baseXY)),baseXY(:,end:-1:1)-(1+rows)/2,baseZ,'CData',oriPic.p4,'EdgeColor','none','FaceColor','interp')
surf(baseXY'-(1+rows)/2,baseXY-(1+rows)/2,ones(size(baseXY)),'CData',oriPic.p6(end:-1:1,end:-1:1,:),'EdgeColor','none','FaceColor','interp')
surf(baseXY'-(1+rows)/2,baseXY-(1+rows)/2,rows-1+ones(size(baseXY)),'CData',oriPic.p5(:,end:-1:1,:),'EdgeColor','none','FaceColor','interp')


2.2 視角調整

通過設置axes屬性將視角調整至盒子里面

ax=axes('parent',fig,'position',[-0.45 -0.45 1.9 1.9]);hold(ax,'on')
ax.ZLim=[0,rows+1];
ax.XLim=[0-(1+rows)/2,rows+1-(1+rows)/2];
ax.YLim=[0-(1+rows)/2,rows+1-(1+rows)/2];
ax.Color=[0 0 0];
ax.CameraPosition=[0,0,rows/2];
ax.CameraPositionMode='manual';
ax.DataAspectRatio=[1,1,1];
ax.DataAspectRatioMode='manual';
ax.Projection='perspective';
ax.CameraTargetMode='manual';
ax.CameraViewAngle = 7;
ax.View=[-2.7391 90.0000];
ax.CameraTarget=[0 0 (rows-1)/2];
ax.Toolbar.Visible='on';

運行后點擊那個三位旋轉按鈕即可開始漫游

此時的盒圖是無縫隙版本,有縫隙版放在后面

2.3 完整代碼

無縫隙版:

function showBox
for i=1:6
    oriPic.(['p',num2str(i)])=imread(['result\',num2str(i),'.jpg']);   
end
[rows,cols,~]=size(oriPic.p1);
[baseXY,baseZ]=meshgrid(1:cols,rows:-1:1);

fig=figure('units','pixels','position',[300 80 500 500],...
                       'Numbertitle','off','menubar','none','resize','off',...
                       'name','box');
                   

ax=axes('parent',fig,'position',[-0.45 -0.45 1.9 1.9]);hold(ax,'on')
ax.ZLim=[0,rows+1];
ax.XLim=[0-(1+rows)/2,rows+1-(1+rows)/2];
ax.YLim=[0-(1+rows)/2,rows+1-(1+rows)/2];
ax.Color=[0 0 0];
ax.CameraPosition=[0,0,rows/2];
ax.CameraPositionMode='manual';
ax.DataAspectRatio=[1,1,1];
ax.DataAspectRatioMode='manual';
ax.Projection='perspective';
ax.CameraTargetMode='manual';
ax.CameraViewAngle = 7;
ax.View=[-2.7391 90.0000];
ax.CameraTarget=[0 0 (rows-1)/2];
ax.Toolbar.Visible='on';




surf(baseXY(:,end:-1:1)-(1+rows)/2,-(rows-1)./2.*ones(size(baseXY)),baseZ,'CData',oriPic.p1,'EdgeColor','none','FaceColor','interp')
surf(-(rows-1)./2.*ones(size(baseXY)),baseXY-(1+rows)/2,baseZ,'CData',oriPic.p2,'EdgeColor','none','FaceColor','interp')
surf(baseXY-(1+rows)/2,(rows-1)./2.*ones(size(baseXY)),baseZ,'CData',oriPic.p3,'EdgeColor','none','FaceColor','interp')
surf((rows-1)./2.*ones(size(baseXY)),baseXY(:,end:-1:1)-(1+rows)/2,baseZ,'CData',oriPic.p4,'EdgeColor','none','FaceColor','interp')
surf(baseXY'-(1+rows)/2,baseXY-(1+rows)/2,ones(size(baseXY)),'CData',oriPic.p6(end:-1:1,end:-1:1,:),'EdgeColor','none','FaceColor','interp')
surf(baseXY'-(1+rows)/2,baseXY-(1+rows)/2,rows-1+ones(size(baseXY)),'CData',oriPic.p5(:,end:-1:1,:),'EdgeColor','none','FaceColor','interp')

end


有縫隙版:

function showBox2
for i=1:6
    oriPic.(['p',num2str(i)])=imread(['result\',num2str(i),'.jpg']);   
end
[rows,cols,~]=size(oriPic.p1);
[baseXY,baseZ]=meshgrid(1:cols,rows:-1:1);

fig=figure('units','pixels','position',[300 80 500 500],...
                       'Numbertitle','off','menubar','none','resize','off',...
                       'name','box');
                   

ax=axes('parent',fig,'position',[-0.45 -0.45 1.9 1.9]);hold(ax,'on')
ax.ZLim=[0,rows+1];
ax.XLim=[0-(1+rows)/2,rows+1-(1+rows)/2];
ax.YLim=[0-(1+rows)/2,rows+1-(1+rows)/2];
ax.Color=[0 0 0];
ax.CameraPosition=[0,0,rows/2];
ax.CameraPositionMode='manual';
ax.DataAspectRatio=[1,1,1];
ax.DataAspectRatioMode='manual';
ax.Projection='perspective';
ax.CameraTargetMode='manual';
ax.CameraViewAngle = 7;
ax.View=[-2.7391 90.0000];
ax.CameraTarget=[0 0 (rows+1)/2];
ax.Toolbar.Visible='on';




surf(baseXY(:,end:-1:1)-rows/2,-rows./2.*ones(size(baseXY)),baseZ,'CData',oriPic.p1,'EdgeColor','none','FaceColor','interp')
surf(-rows./2.*ones(size(baseXY)),baseXY-(1+rows)/2,baseZ,'CData',oriPic.p2,'EdgeColor','none','FaceColor','interp')
surf(baseXY-(1+rows)/2,rows./2.*ones(size(baseXY)),baseZ,'CData',oriPic.p3,'EdgeColor','none','FaceColor','interp')
surf(rows./2.*ones(size(baseXY)),baseXY(:,end:-1:1)-(1+rows)/2,baseZ,'CData',oriPic.p4,'EdgeColor','none','FaceColor','interp')
surf(baseXY'-(1+rows)/2,baseXY-(1+rows)/2,zeros(size(baseXY)),'CData',oriPic.p6(end:-1:1,end:-1:1,:),'EdgeColor','none','FaceColor','interp')
surf(baseXY'-(1+rows)/2,baseXY-(1+rows)/2,rows+ones(size(baseXY)),'CData',oriPic.p5(:,end:-1:1,:),'EdgeColor','none','FaceColor','interp')

end


以上就是MATLAB 全景圖切割及盒圖顯示的詳細內容,更多關于MATLAB 全景圖的資料請關注腳本之家其它相關文章!

您可能感興趣的文章:
  • 在python中計算ssim的方法(與Matlab結果一致)
  • 使用matlab或python將txt文件轉為excel表格
  • 詳解python和matlab的優勢與區別
  • 實例詳解Matlab 與 Python 的區別
  • python調用matlab的m自定義函數方法
  • 詳解如何在python中讀寫和存儲matlab的數據文件(*.mat)
  • 簡述:我為什么選擇Python而不是Matlab和R語言

標簽:常德 惠州 益陽 四川 黑龍江 鷹潭 黔西 上海

巨人網絡通訊聲明:本文標題《MATLAB 全景圖切割及盒圖顯示的實現步驟》,本文關鍵詞  MATLAB,全景,圖,切割,及,盒圖,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《MATLAB 全景圖切割及盒圖顯示的實現步驟》相關的同類信息!
  • 本頁收集關于MATLAB 全景圖切割及盒圖顯示的實現步驟的相關信息資訊供網民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    亚洲日本免费电影| 欧美日韩你懂得| 麻豆国产一区二区| 天天亚洲美女在线视频| 亚洲大片在线观看| 一区二区三区免费网站| 一区二区三区在线观看欧美| 亚洲图片一区二区| 日本亚洲免费观看| 精品亚洲成a人| 国产精品一区二区在线播放| 国产超碰在线一区| 91免费版在线| 在线播放91灌醉迷j高跟美女 | 国产精品超碰97尤物18| 国产精品美女久久久久久久久 | 国产欧美一区二区三区在线看蜜臀| 精品少妇一区二区三区| 日本一区二区三区在线观看| 亚洲免费成人av| 午夜精品123| 国产在线一区二区| 99国产精品久| 911精品国产一区二区在线| 欧美va亚洲va在线观看蝴蝶网| 精品国产一区二区国模嫣然| 中文字幕精品三区| 亚洲一二三区视频在线观看| 日韩国产精品久久久久久亚洲| 国产精品中文有码| 欧美精选在线播放| 国产日韩精品一区二区三区| 一区二区三区四区视频精品免费| 美美哒免费高清在线观看视频一区二区 | 99久久免费国产| 91精品国产美女浴室洗澡无遮挡| 久久嫩草精品久久久久| 亚洲日韩欧美一区二区在线| 精品一区二区三区免费毛片爱| 国产成人丝袜美腿| 717成人午夜免费福利电影| 国产欧美一区二区精品久导航 | 欧美国产成人精品| 亚洲国产精品视频| av午夜精品一区二区三区| 日韩免费观看2025年上映的电影 | 亚洲精品一线二线三线无人区| 亚洲少妇30p| 国产精品影视在线观看| 777欧美精品| 亚洲人成影院在线观看| 激情综合五月婷婷| 欧美欧美欧美欧美首页| 亚洲女同一区二区| 国产福利视频一区二区三区| 欧美一级理论片| 亚洲国产三级在线| 91原创在线视频| 久久精品视频免费观看| 久久成人免费日本黄色| 欧美日韩激情在线| 午夜久久久久久电影| 91蝌蚪porny九色| 成人欧美一区二区三区视频网页| 国产美女一区二区| 久久综合色婷婷| 老司机精品视频一区二区三区| 欧美美女视频在线观看| 一级中文字幕一区二区| 91美女在线视频| 亚洲免费观看高清在线观看| 色一区在线观看| 亚洲免费成人av| 在线观看视频一区二区欧美日韩| 亚洲欧美另类图片小说| 日本道免费精品一区二区三区| 亚洲欧洲99久久| 91视频.com| 亚洲一区影音先锋| 在线成人免费视频| 久久66热re国产| wwwwxxxxx欧美| 成人免费va视频| 亚洲免费在线播放| 色婷婷久久久亚洲一区二区三区| 亚洲乱码国产乱码精品精98午夜 | 91网上在线视频| 亚洲综合在线免费观看| 欧美日本视频在线| 丝袜美腿成人在线| 日韩美女视频一区二区在线观看| 久久99精品国产麻豆婷婷洗澡| 久久午夜色播影院免费高清| 91啪在线观看| 日韩成人dvd| 国产精品无遮挡| 欧美性一二三区| 国产在线国偷精品免费看| 国产精品美女久久久久久2018| 在线观看视频91| 国产在线视频一区二区三区| 国产精品成人一区二区三区夜夜夜| 欧美在线观看视频一区二区| 午夜精品一区二区三区电影天堂 | 成人国产精品视频| 一区二区视频在线看| 欧美精品在线一区二区| 国产精品一区二区三区乱码| 亚洲国产精品久久久久婷婷884 | 久久亚洲综合色| 91色视频在线| 精品一区二区三区不卡| 亚洲黄网站在线观看| 精品国精品国产| 欧美三级一区二区| 国产mv日韩mv欧美| 看片网站欧美日韩| 一区二区激情视频| 欧美国产一区二区在线观看| 欧美一级久久久久久久大片| 色狠狠色噜噜噜综合网| 国产精品一区二区免费不卡| 天堂影院一区二区| 亚洲蜜臀av乱码久久精品 | 欧美日本一道本在线视频| av中文一区二区三区| 精品一区二区三区免费观看| 亚洲午夜电影在线观看| 亚洲欧美激情小说另类| 国产亚洲一区二区三区| 日韩一区二区三区在线观看| 欧美性猛片aaaaaaa做受| 国产999精品久久久久久绿帽| 久久99精品久久久久久动态图 | 国产在线日韩欧美| 久久精品国产澳门| 偷拍日韩校园综合在线| 亚洲精品伦理在线| 亚洲女同一区二区| 国产精品女上位| 成人免费视频在线观看| 国产精品乱人伦中文| 中文字幕av一区 二区| 国产精品日韩精品欧美在线| 日本一区二区在线不卡| 亚洲国产精品传媒在线观看| 国产欧美日韩麻豆91| 国产日韩欧美激情| 中文字幕亚洲综合久久菠萝蜜| 国产精品久久久久久久裸模| 国产精品美日韩| 亚洲欧美另类小说| 亚洲国产精品一区二区www| 午夜精品久久久久久久久久久| 亚洲一区二区中文在线| 香港成人在线视频| 日韩电影在线观看电影| 奇米一区二区三区| 国内精品嫩模私拍在线| 国产精品一区2区| 99精品偷自拍| 欧美日韩国产色站一区二区三区| 欧美色图一区二区三区| 69久久99精品久久久久婷婷| 欧美videossexotv100| 国产精品美女久久久久久2018| 综合久久久久久| 日欧美一区二区| 国产美女精品一区二区三区| 99久久婷婷国产综合精品电影| 91久久精品日日躁夜夜躁欧美| 91精品国产欧美一区二区18| 国产色91在线| 亚洲午夜精品在线| 韩国女主播一区二区三区| 成人黄色在线看| 欧美日韩国产精选| 精品黑人一区二区三区久久| 18成人在线视频| 天堂一区二区在线| 国产99久久久国产精品免费看 | 国产拍欧美日韩视频二区| 最新欧美精品一区二区三区| 亚洲国产精品一区二区尤物区| 精油按摩中文字幕久久| 99国产精品视频免费观看| 日韩欧美一二三区| 依依成人综合视频| 国产主播一区二区三区| 欧美熟乱第一页| 亚洲欧洲性图库| 国内久久精品视频| 欧美日韩在线亚洲一区蜜芽| 有码一区二区三区| 狠狠色狠狠色综合日日91app| 色婷婷久久久久swag精品| 国产日产欧产精品推荐色 | 久久众筹精品私拍模特| 一区二区三区资源| 99久久久免费精品国产一区二区 |