亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? chtrconstr.cpp

?? Windows上的MUD客戶端程序
?? CPP
?? 第 1 頁 / 共 2 頁
字號:
/*----------------------------------------------------------------------------
                        _                              _ _       
        /\             | |                            | (_)      
       /  \   _ __   __| |_ __ ___  _ __ ___   ___  __| |_  __ _ 
      / /\ \ | '_ \ / _` | '__/ _ \| '_ ` _ \ / _ \/ _` | |/ _` |
     / ____ \| | | | (_| | | | (_) | | | | | |  __/ (_| | | (_| |
    /_/    \_\_| |_|\__,_|_|  \___/|_| |_| |_|\___|\__,_|_|\__,_|

    The contents of this file are subject to the Andromedia Public
	License Version 1.0 (the "License"); you may not use this file
	except in compliance with the License. You may obtain a copy of
	the License at http://www.andromedia.com/APL/

    Software distributed under the License is distributed on an
	"AS IS" basis, WITHOUT WARRANTY OF ANY KIND, either express or
	implied. See the License for the specific language governing
	rights and limitations under the License.

    The Original Code is Pueblo client code, released November 4, 1998.

    The Initial Developer of the Original Code is Andromedia Incorporated.
	Portions created by Andromedia are Copyright (C) 1998 Andromedia
	Incorporated.  All Rights Reserved.

	Andromedia Incorporated                         415.365.6700
	818 Mission Street - 2nd Floor                  415.365.6701 fax
	San Francisco, CA 94103

    Contributor(s):
	--------------------------------------------------------------------------
	   Chaco team:  Dan Greening, Glenn Crocker, Jim Doubek,
	                Coyote Lussier, Pritham Shetty.

					Wrote and designed original codebase.

------------------------------------------------------------------------------

	Triangulator for Chaco VRML - based on Graphics Gems V.

----------------------------------------------------------------------------*/

#include <ChTriangle.h>
#include <math.h>
#include <memory.h>

/* Return a new node to be added into the query tree */
int ChTriangulator::newnode()
{
  if (q_idx < m_qSize)
    return q_idx++;
  else
    {
      TRACE("newnode: Query-table overflow\n");
	  throw CH_EX_TRIANGULATION;
      return -1;
    }
}

/* Return a free trapezoid */
int  ChTriangulator::newtrap()
{
  if (tr_idx < m_trSize)
    {
      tr[tr_idx].lseg = -1;
      tr[tr_idx].rseg = -1;
      tr[tr_idx].state = ST_VALID;
      return tr_idx++;
    }
  else
    {
      TRACE( "newtrap: Trapezoid-table overflow\n");
	  throw CH_EX_TRIANGULATION;
      return -1;
    }
}


/* Return the maximum of the two points into the yval structure */
static int _max(point_t *yval, point_t *v0, point_t *v1)
{
  if (v0->y > v1->y + C_EPS)
    *yval = *v0;
  else if (FP_EQUAL(v0->y, v1->y))
    {
      if (v0->x > v1->x + C_EPS)
	*yval = *v0;
      else
	*yval = *v1;
    }
  else
    *yval = *v1;
  
  return 0;
}


/* Return the minimum of the two points into the yval structure */
static int _min(point_t *yval, point_t *v0, point_t *v1)
{
  if (v0->y < v1->y - C_EPS)
    *yval = *v0;
  else if (FP_EQUAL(v0->y, v1->y))
    {
      if (v0->x < v1->x)
	*yval = *v0;
      else
	*yval = *v1;
    }
  else
    *yval = *v1;
  
  return 0;
}


int  ChTriangulator::_greater_than(point_t *v0, point_t *v1)
{
  if (v0->y > v1->y + C_EPS)
    return TRUE;
  else if (v0->y < v1->y - C_EPS)
    return FALSE;
  else
    return (v0->x > v1->x);
}


int  ChTriangulator::_equal_to(point_t *v0, point_t *v1)
{
  return (FP_EQUAL(v0->y, v1->y) && FP_EQUAL(v0->x, v1->x));
}

int  ChTriangulator::_greater_than_equal_to(point_t *v0, point_t *v1)
{
  if (v0->y > v1->y + C_EPS)
    return TRUE;
  else if (v0->y < v1->y - C_EPS)
    return FALSE;
  else
    return (v0->x >= v1->x);
}

int  ChTriangulator::_less_than(point_t *v0, point_t *v1)
{
  if (v0->y < v1->y - C_EPS)
    return TRUE;
  else if (v0->y > v1->y + C_EPS)
    return FALSE;
  else
    return (v0->x < v1->x);
}


/* Initilialise the query structure (Q) and the trapezoid table (T) 
 * when the first segment is added to start the trapezoidation
 */
int  ChTriangulator::init_query_structure(int segnum)
{
  int i1, i2, i3, i4, i5, i6, i7, root;
  int t1, t2, t3, t4;
  segment_t *s = &seg[segnum];

  memset((void *)tr, 0, m_trSize * sizeof(*tr));
  memset((void *)qs, 0, m_qSize * sizeof(*qs));

  i1 = newnode();
  qs[i1].nodetype = T_Y;
  _max(&qs[i1].yval, &s->v0, &s->v1); /* root */
  root = i1;

  qs[i1].right = i2 = newnode();
  qs[i2].nodetype = T_SINK;
  qs[i2].parent = i1;

  qs[i1].left = i3 = newnode();
  qs[i3].nodetype = T_Y;
  _min(&qs[i3].yval, &s->v0, &s->v1); /* root */
  qs[i3].parent = i1;
  
  qs[i3].left = i4 = newnode();
  qs[i4].nodetype = T_SINK;
  qs[i4].parent = i3;
  
  qs[i3].right = i5 = newnode();
  qs[i5].nodetype = T_X;
  qs[i5].segnum = segnum;
  qs[i5].parent = i3;
  
  qs[i5].left = i6 = newnode();
  qs[i6].nodetype = T_SINK;
  qs[i6].parent = i5;

  qs[i5].right = i7 = newnode();
  qs[i7].nodetype = T_SINK;
  qs[i7].parent = i5;

  t1 = newtrap();		/* middle left */
  t2 = newtrap();		/* middle right */
  t3 = newtrap();		/* bottom-most */
  t4 = newtrap();		/* topmost */

  tr[t1].hi = tr[t2].hi = tr[t4].lo = qs[i1].yval;
  tr[t1].lo = tr[t2].lo = tr[t3].hi = qs[i3].yval;
  tr[t4].hi.y = (double) (INFINITY);
  tr[t4].hi.x = (double) (INFINITY);
  tr[t3].lo.y = (double) -1* (INFINITY);
  tr[t3].lo.x = (double) -1* (INFINITY);
  tr[t1].rseg = tr[t2].lseg = segnum;
  tr[t1].u0 = tr[t2].u0 = t4;
  tr[t1].d0 = tr[t2].d0 = t3;
  tr[t4].d0 = tr[t3].u0 = t1;
  tr[t4].d1 = tr[t3].u1 = t2;
  
  tr[t1].sink = i6;
  tr[t2].sink = i7;
  tr[t3].sink = i4;
  tr[t4].sink = i2;

  tr[t1].state = tr[t2].state = ST_VALID;
  tr[t3].state = tr[t4].state = ST_VALID;

  qs[i2].trnum = t4;
  qs[i4].trnum = t3;
  qs[i6].trnum = t1;
  qs[i7].trnum = t2;

  s->is_inserted = TRUE;
  return root;
}


/* Retun TRUE if the vertex v is to the left of line segment no.
   * segnum
   */

int  ChTriangulator::is_left_of(int segnum, point_t *v)
{
  segment_t *s = &seg[segnum];
  double area;
  
  if (_greater_than(&s->v1, &s->v0)) /* seg. going upwards */
    {
      if (FP_EQUAL(s->v1.y, v->y))
	{
	  if (v->x < s->v1.x)
	    area = 1.0;
	  else
	    area = -1.0;
	}
      else if (FP_EQUAL(s->v0.y, v->y))
	{
	  if (v->x < s->v0.x)
	    area = 1.0;
	  else
	    area = -1.0;
	}
      else
	area = CROSS(s->v0, s->v1, (*v));
    }
  else				/* v0 > v1 */
    {
      if (FP_EQUAL(s->v1.y, v->y))
	{
	  if (v->x < s->v1.x)
	    area = 1.0;
	  else
	    area = -1.0;
	}
      else if (FP_EQUAL(s->v0.y, v->y))
	{
	  if (v->x < s->v0.x)
	    area = 1.0;
	  else
	    area = -1.0;
	}
      else
	area = CROSS(s->v1, s->v0, (*v));
    }
  
  if (area > 0.0)
    return TRUE;
  else 
    return FALSE;
}


int  ChTriangulator::is_collinear(int segnum, point_t *v, int is_swapped)
{
  segment_t *s = &seg[segnum];
  int n;
  
  /* First check if the endpoint is already inserted */
  if (!is_swapped)
    n = MODULO_NEXT(segnum + 1, global.nseg);
  else
    if ((n = segnum - 1) == 0)
      n = 1;
  
  return seg[n].is_inserted;
}

 
/* This is query routine which determines which trapezoid does the 
 * point v lie in. The return value is the trapezoid number 
 */

int  ChTriangulator::locate_endpoint(point_t *v, point_t *vo, int r)
{
  node_t *rptr = &qs[r];
  
  switch (rptr->nodetype)
    {
    case T_SINK:
      return rptr->trnum;
      
    case T_Y:
      if (_greater_than(v, &rptr->yval)) /* above */
	return locate_endpoint(v, vo, rptr->right);
      else if (_equal_to(v, &rptr->yval)) /* the point is already */
	{			          /* inserted. */
	  if (_greater_than(vo, &rptr->yval)) /* above */
	    return locate_endpoint(v, vo, rptr->right);
	  else 
	    return locate_endpoint(v, vo, rptr->left); /* below */	    
	}
      else
	return locate_endpoint(v, vo, rptr->left); /* below */

    case T_X:
      if (_equal_to(v, &seg[rptr->segnum].v0) || 
	       _equal_to(v, &seg[rptr->segnum].v1))
	{
	  if (FP_EQUAL(v->y, vo->y)) /* horizontal segment */
	    {
	      if (vo->x < v->x)
		return locate_endpoint(v, vo, rptr->left); /* left */
	      else
		return locate_endpoint(v, vo, rptr->right); /* right */
	    }

	  else if (is_left_of(rptr->segnum, vo))
	    return locate_endpoint(v, vo, rptr->left); /* left */
	  else
	    return locate_endpoint(v, vo, rptr->right); /* right */
	}
      else if (is_left_of(rptr->segnum, v))
	return locate_endpoint(v, vo, rptr->left); /* left */
      else
	return locate_endpoint(v, vo, rptr->right); /* right */	

    default:
      TRACE(  "Haggu !!!!!\n");
	  //	throw CH_EX_TRIANGULATION; ???????
      break;
    }
	return 0;
}


/* Thread in the segment into the existing trapezoidation. The 
 * limiting trapezoids are given by tfirst and tlast (which are the
 * trapezoids containing the two endpoints of the segment 
 */

int  ChTriangulator::merge_trapezoids(int segnum, int tfirst, int tlast, int side)
{
  int t, tnext, cond;
  int ptnext;

  /* First merge polys on the LHS */
  t = tfirst;
  while ((t > 0) && _greater_than_equal_to(&tr[t].lo, &tr[tlast].lo))
    {
      if (side == S_LEFT)
	cond = ((((tnext = tr[t].d0) > 0) && (tr[tnext].rseg == segnum)) ||
		(((tnext = tr[t].d1) > 0) && (tr[tnext].rseg == segnum)));
      else
	cond = ((((tnext = tr[t].d0) > 0) && (tr[tnext].lseg == segnum)) ||
		(((tnext = tr[t].d1) > 0) && (tr[tnext].lseg == segnum)));
      
      if (cond)
	{
	  if ((tr[t].lseg == tr[tnext].lseg) &&
	      (tr[t].rseg == tr[tnext].rseg)) /* good neighbours */
	    {			              /* merge them */
	      /* Use the upper node as the new node i.e. t */
	      
	      ptnext = qs[tr[tnext].sink].parent;
	      
	      if (qs[ptnext].left == tr[tnext].sink)
		qs[ptnext].left = tr[t].sink;
	      else
		qs[ptnext].right = tr[t].sink;	/* redirect parent */
	      
	      
	      /* Change the upper neighbours of the lower trapezoids */
	      
	      if ((tr[t].d0 = tr[tnext].d0) > 0)
		if (tr[tr[t].d0].u0 == tnext)
		  tr[tr[t].d0].u0 = t;
		else if (tr[tr[t].d0].u1 == tnext)
		  tr[tr[t].d0].u1 = t;
	      
	      if ((tr[t].d1 = tr[tnext].d1) > 0)
		if (tr[tr[t].d1].u0 == tnext)
		  tr[tr[t].d1].u0 = t;
		else if (tr[tr[t].d1].u1 == tnext)
		  tr[tr[t].d1].u1 = t;
	      
	      tr[t].lo = tr[tnext].lo;
	      tr[tnext].state = ST_INVALID; /* invalidate the lower */
				            /* trapezium */
	    }
	  else		    /* not good neighbours */
	    t = tnext;
	}
      else		    /* do not satisfy the outer if */
	t = tnext;
      
    } /* end-while */
       
  return 0;
}


/* Add in the new segment into the trapezoidation and update Q and T
 * structures 
 */
int  ChTriangulator::add_segment(int segnum)
{
  segment_t s;
  segment_t *so = &seg[segnum];
  int tu, tl, sk, tfirst, tlast, tnext;
  int tfirstr = -1, tlastr, tfirstl, tlastl;
  int i1, i2, t, tn;
  //int t1, t2;
  point_t vper, tpt;
  int tritop = 0, tribot = 0, is_swapped = 0;
  int tmptriseg;

  s = seg[segnum];
  if (_greater_than(&s.v1, &s.v0)) /* Get higher vertex in v0 */
    {
      int tmp;
      tpt = s.v0;
      s.v0 = s.v1;
      s.v1 = tpt;
      tmp = s.root0;
      s.root0 = s.root1;
      s.root1 = tmp;
      is_swapped = TRUE;
    }

  if ((is_swapped) ? !inserted(segnum, LASTPT) :
       !inserted(segnum, FIRSTPT))     /* insert v0 in the tree */
    {
      int tmp_d;

      tu = locate_endpoint(&s.v0, &s.v1, s.root0);
      tl = newtrap();		/* tl is the new lower trapezoid */
      tr[tl].state = ST_VALID;
      tr[tl] = tr[tu];
      tr[tu].lo.y = tr[tl].hi.y = s.v0.y;
      tr[tu].lo.x = tr[tl].hi.x = s.v0.x;
      tr[tu].d0 = tl;      
      tr[tu].d1 = 0;
      tr[tl].u0 = tu;
      tr[tl].u1 = 0;

      if (((tmp_d = tr[tl].d0) > 0) && (tr[tmp_d].u0 == tu))
	tr[tmp_d].u0 = tl;
      if (((tmp_d = tr[tl].d0) > 0) && (tr[tmp_d].u1 == tu))
	tr[tmp_d].u1 = tl;

      if (((tmp_d = tr[tl].d1) > 0) && (tr[tmp_d].u0 == tu))
	tr[tmp_d].u0 = tl;
      if (((tmp_d = tr[tl].d1) > 0) && (tr[tmp_d].u1 == tu))
	tr[tmp_d].u1 = tl;

      /* Now update the query structure and obtain the sinks for the */
      /* two trapezoids */ 
      
      i1 = newnode();		/* Upper trapezoid sink */
      i2 = newnode();		/* Lower trapezoid sink */
      sk = tr[tu].sink;
      
      qs[sk].nodetype = T_Y;
      qs[sk].yval = s.v0;
      qs[sk].segnum = segnum;	/* not really reqd ... maybe later */
      qs[sk].left = i2;
      qs[sk].right = i1;

      qs[i1].nodetype = T_SINK;
      qs[i1].trnum = tu;
      qs[i1].parent = sk;

      qs[i2].nodetype = T_SINK;
      qs[i2].trnum = tl;
      qs[i2].parent = sk;

      tr[tu].sink = i1;
      tr[tl].sink = i2;
      tfirst = tl;
    }
  else				/* v0 already present */
    {       /* Get the topmost intersecting trapezoid */
      vper.x = s.v0.x + EPS * (s.v1.x - s.v0.x);
      vper.y = s.v0.y + EPS * (s.v1.y - s.v0.y);
      tfirst = locate_endpoint(&s.v0, &s.v1, s.root0);
      tritop = 1;
    }


  if ((is_swapped) ? !inserted(segnum, FIRSTPT) :
       !inserted(segnum, LASTPT))     /* insert v1 in the tree */
    {
      int tmp_d;

      tu = locate_endpoint(&s.v1, &s.v0, s.root1);

      tl = newtrap();		/* tl is the new lower trapezoid */
      tr[tl].state = ST_VALID;
      tr[tl] = tr[tu];
      tr[tu].lo.y = tr[tl].hi.y = s.v1.y;
      tr[tu].lo.x = tr[tl].hi.x = s.v1.x;
      tr[tu].d0 = tl;      
      tr[tu].d1 = 0;
      tr[tl].u0 = tu;
      tr[tl].u1 = 0;

      if (((tmp_d = tr[tl].d0) > 0) && (tr[tmp_d].u0 == tu))
	tr[tmp_d].u0 = tl;
      if (((tmp_d = tr[tl].d0) > 0) && (tr[tmp_d].u1 == tu))
	tr[tmp_d].u1 = tl;

      if (((tmp_d = tr[tl].d1) > 0) && (tr[tmp_d].u0 == tu))
	tr[tmp_d].u0 = tl;
      if (((tmp_d = tr[tl].d1) > 0) && (tr[tmp_d].u1 == tu))
	tr[tmp_d].u1 = tl;
      
      /* Now update the query structure and obtain the sinks for the */
      /* two trapezoids */ 
      

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美喷水一区二区| 亚洲视频网在线直播| 国产精品国产三级国产普通话99| 亚洲免费电影在线| 蜜桃久久av一区| 一本到一区二区三区| 亚洲精品一区二区在线观看| 亚洲精品免费一二三区| 国产乱理伦片在线观看夜一区| 一本到不卡免费一区二区| 精品国产3级a| 奇米影视7777精品一区二区| 色噜噜狠狠色综合中国| 久久精品欧美日韩| 黄色小说综合网站| 欧美精品v国产精品v日韩精品| 国产精品传媒入口麻豆| 国产做a爰片久久毛片| 欧美精品久久99| 午夜精品一区二区三区免费视频| 成人免费视频一区二区| xfplay精品久久| 美女mm1313爽爽久久久蜜臀| 欧美日韩黄视频| 亚洲第一精品在线| 欧美日韩一级片在线观看| 亚洲欧美日韩久久精品| 91欧美激情一区二区三区成人| 国产日韩精品视频一区| 国产乱一区二区| 2019国产精品| 国产精品一区一区三区| 久久久av毛片精品| 韩国女主播一区| 国产午夜精品福利| 国产成人免费在线视频| 欧美国产欧美亚州国产日韩mv天天看完整| 国产主播一区二区三区| 久久一区二区三区国产精品| 国产一区二区免费在线| 欧美激情自拍偷拍| 色综合久久综合网欧美综合网| 亚洲三级电影网站| 欧美中文字幕一区| 日本最新不卡在线| 欧美精品一区在线观看| 国产成人精品亚洲777人妖| 中日韩av电影| 日本黄色一区二区| 青青草原综合久久大伊人精品优势| 欧美成人aa大片| 国产在线精品国自产拍免费| 国产精品色哟哟网站| 91国模大尺度私拍在线视频| 婷婷综合另类小说色区| 精品国产乱码久久久久久久| 成人短视频下载| 亚洲电影你懂得| 精品国产乱码久久| 91香蕉视频在线| 日本强好片久久久久久aaa| 精品粉嫩aⅴ一区二区三区四区| 丰满岳乱妇一区二区三区| 亚洲精品国产品国语在线app| 欧美猛男超大videosgay| 国产毛片精品视频| 亚洲小说欧美激情另类| 日韩欧美在线一区二区三区| 丁香婷婷综合色啪| 丝袜美腿亚洲综合| 国产日韩一级二级三级| 欧美三级视频在线播放| 国产麻豆精品在线| 亚洲国产精品久久不卡毛片| 久久综合av免费| 欧美日韩在线三区| 国产成人精品免费看| 天天影视色香欲综合网老头| 久久精品一区二区| 欧美精品国产精品| 91麻豆6部合集magnet| 久久国产麻豆精品| 亚洲午夜久久久久久久久久久 | 麻豆国产精品一区二区三区 | 欧美精品一区二区不卡| 91尤物视频在线观看| 理论片日本一区| 亚洲aaa精品| 亚洲猫色日本管| 中文一区二区在线观看| 欧美成人一区二区| 欧美区一区二区三区| 91黄色免费网站| 91理论电影在线观看| 国产91精品一区二区麻豆网站 | 东方aⅴ免费观看久久av| 免费视频一区二区| 亚洲bt欧美bt精品| 亚洲国产精品一区二区www在线 | 欧美曰成人黄网| 99视频在线精品| 国产999精品久久久久久绿帽| 青青草伊人久久| 婷婷综合另类小说色区| 亚洲韩国精品一区| 亚洲福利一二三区| 亚洲国产aⅴ成人精品无吗| 亚洲丝袜自拍清纯另类| 国产精品国产三级国产普通话99 | 色狠狠综合天天综合综合| 国产一区二区按摩在线观看| 久久国产欧美日韩精品| 久久国产精品99精品国产 | 一级中文字幕一区二区| 亚洲视频图片小说| 亚洲手机成人高清视频| 中文字幕一区视频| 亚洲免费在线视频| 亚洲综合一区二区三区| 一级日本不卡的影视| 亚洲国产日韩av| 视频一区视频二区在线观看| 日产国产欧美视频一区精品| 老司机午夜精品99久久| 国产在线视频一区二区三区| 国产精品影视在线观看| 成人丝袜视频网| 在线中文字幕一区| 91麻豆精品久久久久蜜臀| 日韩免费高清av| 久久久精品蜜桃| 亚洲欧洲av一区二区三区久久| 最近日韩中文字幕| 亚洲一级二级在线| 久久超碰97人人做人人爱| 国产高清不卡一区| 一本到高清视频免费精品| 91精品国产乱| 国产亚洲一本大道中文在线| 亚洲理论在线观看| 男人操女人的视频在线观看欧美| 精品亚洲aⅴ乱码一区二区三区| 国产乱人伦精品一区二区在线观看| 高清成人免费视频| 欧美日韩国产综合一区二区| 精品国产青草久久久久福利| 日韩美女视频19| 奇米在线7777在线精品| 成人一二三区视频| 欧美日本在线播放| 国产欧美一区视频| 图片区小说区区亚洲影院| 国产精品亚洲成人| 日本二三区不卡| 欧美精品一区二区久久久| 一级做a爱片久久| 国产精品一区二区x88av| 在线视频综合导航| 亚洲精品在线电影| 午夜一区二区三区视频| 国产老女人精品毛片久久| 在线视频亚洲一区| 久久精品夜色噜噜亚洲aⅴ| 亚洲国产一区二区在线播放| 国产成人一区在线| 日韩免费视频线观看| 亚洲猫色日本管| 成人综合婷婷国产精品久久| 91麻豆精品久久久久蜜臀| 亚洲黄色小视频| 99麻豆久久久国产精品免费优播| 日韩一区二区在线看片| 亚洲国产sm捆绑调教视频| jiyouzz国产精品久久| 精品成人在线观看| 视频一区视频二区中文字幕| 日本道精品一区二区三区| 欧美激情一区二区三区全黄| 精品一区二区免费在线观看| 欧美三片在线视频观看| 亚洲精品国产无套在线观| 成人av综合在线| 国产嫩草影院久久久久| 精品在线视频一区| 日韩欧美综合一区| 三级久久三级久久久| 欧美日韩视频专区在线播放| 亚洲视频资源在线| 91麻豆蜜桃一区二区三区| 国产精品美日韩| 成人午夜av电影| 国产亚洲成年网址在线观看| 国内精品伊人久久久久av一坑 | 国产日韩精品一区二区三区| 久久99国产精品成人| 日韩欧美精品在线| 久久综合综合久久综合| 精品欧美乱码久久久久久| 蜜桃久久av一区| 亚洲精品一区二区三区香蕉|