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

首頁 > 編程 > C# > 正文

C#繪制曲線圖的方法

2020-01-24 01:26:19
字體:
來源:轉載
供稿:網友

本文實例講述了C#繪制曲線圖的方法。分享給大家供大家參考。具體如下:

1. 曲線圖效果:

2. C#代碼:

/// <summary>/// 自動根據參數調整圖像大小/// </summary>public void Fit(){ //計算字體距離 intFontSpace = FontSize + 5; //計算圖像邊距 float fltSpace = Math.Min(Width / 6, Height / 6); XSpace = fltSpace; YSpace = fltSpace; //計算X軸刻度寬度 XSlice = (Width - 2 * XSpace) / (Keys.Length - 1); //計算Y軸刻度寬度和Y軸刻度開始值 float fltMinValue = 0; float fltMaxValue = 0; for (int i = 0; i < Values.Length; i++) {  if (Values[i] < fltMinValue)  {  fltMinValue = Values[i];  }  else if (Values[i] > fltMaxValue)  {  fltMaxValue = Values[i];  } } if (YSliceBegin > fltMinValue) {  YSliceBegin = fltMinValue; } int intYSliceCount = (int)(fltMaxValue / YSliceValue); if (fltMaxValue % YSliceValue != 0) {  intYSliceCount++; } YSlice = (Height - 2 * YSpace) / intYSliceCount;}

3. 數據縮小一個級別的效果:

4. 完整代碼 DrawingCurve.cs:

using System;using System.Collections.Generic;using System.Text;using System.Drawing;using System.Data;using System.Drawing.Drawing2D;namespace SarchPMS.Business.Draw{ public class DrawingCurve : DrawingChart {  /// <summary>  /// 畫曲線圖  /// </summary>  /// <param name="dsParameter"></param>  /// <returns></returns>  public override Bitmap DrawImage(DataSet dsParameter)  {   Curve2D cuv2D = new Curve2D();   cuv2D.Fit();   return cuv2D.CreateImage();  } } public class Curve2D {  private Graphics objGraphics; //Graphics 類提供將對象繪制到顯示設備的方法  private Bitmap objBitmap; //位圖對象  private float fltWidth = 480; //圖像寬度  private float fltHeight = 248; //圖像高度  private float fltXSlice = 50; //X軸刻度寬度  private float fltYSlice = 50; //Y軸刻度寬度  private float fltYSliceValue = 20; //Y軸刻度的數值寬度  private float fltYSliceBegin = 0; //Y軸刻度開始值  private float fltTension = 0.5f;  private string strTitle = "曲線圖"; //標題  private string strXAxisText = "月份"; //X軸說明文字  private string strYAxisText = "萬元"; //Y軸說明文字  private string[] strsKeys = new string[] { "一月", "二月", "三月", "四月", "五月", "六月", "七月", "八月", "九月", "十月", "十一月", "十二月" }; //鍵  private float[] fltsValues = new float[] { 20.0f, 30.0f, 50.0f, 55.4f, 21.6f, 12.8f, 99.5f, 36.4f, 78.2f, 56.4f, 45.8f, 66.5f, 99.5f, 36.4f, 78.2f, 56.4f, 45.8f, 66.5f, 20.0f, 30.0f, 50.0f, 55.4f, 21.6f, 12.8f }; //值  private Color clrBgColor = Color.Snow; //背景色  private Color clrTextColor = Color.Black; //文字顏色  private Color clrBorderColor = Color.Black; //整體邊框顏色  private Color clrAxisColor = Color.Black; //軸線顏色  private Color clrAxisTextColor = Color.Black; //軸說明文字顏色  private Color clrSliceTextColor = Color.Black; //刻度文字顏色  private Color clrSliceColor = Color.Black; //刻度顏色  private Color[] clrsCurveColors = new Color[] { Color.Red, Color.Blue }; //曲線顏色  private float fltXSpace = 100f; //圖像左右距離邊緣距離  private float fltYSpace = 100f; //圖像上下距離邊緣距離  private int intFontSize = 9; //字體大小號數  private float fltXRotateAngle = 30f; //X軸文字旋轉角度  private float fltYRotateAngle = 0f; //Y軸文字旋轉角度  private int intCurveSize = 2; //曲線線條大小  private int intFontSpace = 0; //intFontSpace 是字體大小和距離調整出來的一個比較適合的數字  #region 公共屬性  /// <summary>  /// 圖像的寬度  /// </summary>  public float Width  {   set   {    if (value < 100)    {     fltWidth = 100;    }    else    {     fltWidth = value;    }   }   get   {    if (fltWidth <= 100)    {     return 100;    }    else    {     return fltWidth;    }   }  }  /// <summary>  /// 圖像的高度  /// </summary>  public float Height  {   set   {    if (value < 100)    {     fltHeight = 100;    }    else    {     fltHeight = value;    }   }   get   {    if (fltHeight <= 100)    {     return 100;    }    else    {     return fltHeight;    }   }  }  /// <summary>  /// X軸刻度寬度  /// </summary>  public float XSlice  {   set { fltXSlice = value; }   get { return fltXSlice; }  }  /// <summary>  /// Y軸刻度寬度  /// </summary>  public float YSlice  {   set { fltYSlice = value; }   get { return fltYSlice; }  }  /// <summary>  /// Y軸刻度的數值寬度  /// </summary>  public float YSliceValue  {   set { fltYSliceValue = value; }   get { return fltYSliceValue; }  }  /// <summary>  /// Y軸刻度開始值  /// </summary>  public float YSliceBegin  {   set { fltYSliceBegin = value; }   get { return fltYSliceBegin; }  }  /// <summary>  /// 張力系數  /// </summary>  public float Tension  {   set   {    if (value < 0.0f && value > 1.0f)    {     fltTension = 0.5f;    }    else    {     fltTension = value;    }   }   get   {    return fltTension;   }  }  /// <summary>  /// 標題  /// </summary>  public string Title  {   set { strTitle = value; }   get { return strTitle; }  }  /// <summary>  /// 鍵,X軸數據  /// </summary>  public string[] Keys  {   set { strsKeys = value; }   get { return strsKeys; }  }  /// <summary>  /// 值,Y軸數據  /// </summary>  public float[] Values  {   set { fltsValues = value; }   get { return fltsValues; }  }  /// <summary>  /// 背景色  /// </summary>  public Color BgColor  {   set { clrBgColor = value; }   get { return clrBgColor; }  }  /// <summary>  /// 文字顏色  /// </summary>  public Color TextColor  {   set { clrTextColor = value; }   get { return clrTextColor; }  }  /// <summary>  /// 整體邊框顏色  /// </summary>  public Color BorderColor  {   set { clrBorderColor = value; }   get { return clrBorderColor; }  }  /// <summary>  /// 軸線顏色  /// </summary>  public Color AxisColor  {   set { clrAxisColor = value; }   get { return clrAxisColor; }  }  /// <summary>  /// X軸說明文字  /// </summary>  public string XAxisText  {   set { strXAxisText = value; }   get { return strXAxisText; }  }  /// <summary>  /// Y軸說明文字  /// </summary>  public string YAxisText  {   set { strYAxisText = value; }   get { return strYAxisText; }  }  /// <summary>  /// 軸說明文字顏色  /// </summary>  public Color AxisTextColor  {   set { clrAxisTextColor = value; }   get { return clrAxisTextColor; }  }  /// <summary>  /// 刻度文字顏色  /// </summary>  public Color SliceTextColor  {   set { clrSliceTextColor = value; }   get { return clrSliceTextColor; }  }  /// <summary>  /// 刻度顏色  /// </summary>  public Color SliceColor  {   set { clrSliceColor = value; }   get { return clrSliceColor; }  }  /// <summary>  /// 曲線顏色  /// </summary>  public Color[] CurveColors  {   set { clrsCurveColors = value; }   get { return clrsCurveColors; }  }  /// <summary>  /// X軸文字旋轉角度  /// </summary>  public float XRotateAngle  {   get { return fltXRotateAngle; }   set { fltXRotateAngle = value; }  }  /// <summary>  /// Y軸文字旋轉角度  /// </summary>  public float YRotateAngle  {   get { return fltYRotateAngle; }   set { fltYRotateAngle = value; }  }  /// <summary>  /// 圖像左右距離邊緣距離  /// </summary>  public float XSpace  {   get { return fltXSpace; }   set { fltXSpace = value; }  }  /// <summary>  /// 圖像上下距離邊緣距離  /// </summary>  public float YSpace  {   get { return fltYSpace; }   set { fltYSpace = value; }  }  /// <summary>  /// 字體大小號數  /// </summary>  public int FontSize  {   get { return intFontSize; }   set { intFontSize = value; }  }  /// <summary>  /// 曲線線條大小  /// </summary>  public int CurveSize  {   get { return intCurveSize; }   set { intCurveSize = value; }  }  #endregion  /// <summary>  /// 自動根據參數調整圖像大小  /// </summary>  public void Fit()  {   //計算字體距離   intFontSpace = FontSize + 5;   //計算圖像邊距   float fltSpace = Math.Min(Width / 6, Height / 6);   XSpace = fltSpace;   YSpace = fltSpace;   //計算X軸刻度寬度   XSlice = (Width - 2 * XSpace) / (Keys.Length - 1);   //計算Y軸刻度寬度和Y軸刻度開始值   float fltMinValue = 0;   float fltMaxValue = 0;   for (int i = 0; i < Values.Length; i++)   {    if (Values[i] < fltMinValue)    {     fltMinValue = Values[i];    }    else if (Values[i] > fltMaxValue)    {     fltMaxValue = Values[i];    }   }   if (YSliceBegin > fltMinValue)   {    YSliceBegin = fltMinValue;   }   int intYSliceCount = (int)(fltMaxValue / YSliceValue);   if (fltMaxValue % YSliceValue != 0)   {    intYSliceCount++;   }   YSlice = (Height - 2 * YSpace) / intYSliceCount;  }  /// <summary>  /// 生成圖像并返回bmp圖像對象  /// </summary>  /// <returns></returns>  public Bitmap CreateImage()  {   InitializeGraph();   int intKeysCount = Keys.Length;   int intValuesCount = Values.Length;   if (intValuesCount % intKeysCount == 0)   {    int intCurvesCount = intValuesCount / intKeysCount;    for (int i = 0; i < intCurvesCount; i++)    {     float[] fltCurrentValues = new float[intKeysCount];     for (int j = 0; j < intKeysCount; j++)     {      fltCurrentValues[j] = Values[i * intKeysCount + j];     }     DrawContent(ref objGraphics, fltCurrentValues, clrsCurveColors[i]);    }   }   else   {    objGraphics.DrawString("發生錯誤,Values的長度必須是Keys的整數倍!", new Font("宋體", FontSize + 5), new SolidBrush(TextColor), new Point((int)XSpace, (int)(Height / 2)));   }   return objBitmap;  }  /// <summary>  /// 初始化和填充圖像區域,畫出邊框,初始標題  /// </summary>  private void InitializeGraph()  {   //根據給定的高度和寬度創建一個位圖圖像   objBitmap = new Bitmap((int)Width, (int)Height);   //從指定的 objBitmap 對象創建 objGraphics 對象 (即在objBitmap對象中畫圖)   objGraphics = Graphics.FromImage(objBitmap);   //根據給定顏色(LightGray)填充圖像的矩形區域 (背景)   objGraphics.DrawRectangle(new Pen(BorderColor, 1), 0, 0, Width - 1, Height - 1); //畫邊框   objGraphics.FillRectangle(new SolidBrush(BgColor), 1, 1, Width - 2, Height - 2); //填充邊框   //畫X軸,注意圖像的原始X軸和Y軸計算是以左上角為原點,向右和向下計算的   float fltX1 = XSpace;   float fltY1 = Height - YSpace;   float fltX2 = Width - XSpace + XSlice / 2;   float fltY2 = fltY1;   objGraphics.DrawLine(new Pen(new SolidBrush(AxisColor), 1), fltX1, fltY1, fltX2, fltY2);   //畫Y軸   fltX1 = XSpace;   fltY1 = Height - YSpace;   fltX2 = XSpace;   fltY2 = YSpace - YSlice / 2;   objGraphics.DrawLine(new Pen(new SolidBrush(AxisColor), 1), fltX1, fltY1, fltX2, fltY2);   //初始化軸線說明文字   SetAxisText(ref objGraphics);   //初始化X軸上的刻度和文字   SetXAxis(ref objGraphics);   //初始化Y軸上的刻度和文字   SetYAxis(ref objGraphics);   //初始化標題   CreateTitle(ref objGraphics);  }  /// <summary>  /// 初始化軸線說明文字  /// </summary>  /// <param name="objGraphics"></param>  private void SetAxisText(ref Graphics objGraphics)  {   float fltX = Width - XSpace + XSlice / 2 - (XAxisText.Length - 1) * intFontSpace;   float fltY = Height - YSpace - intFontSpace;   objGraphics.DrawString(XAxisText, new Font("宋體", FontSize), new SolidBrush(AxisTextColor), fltX, fltY);   fltX = XSpace + 5;   fltY = YSpace - YSlice / 2 - intFontSpace;   for (int i = 0; i < YAxisText.Length; i++)   {    objGraphics.DrawString(YAxisText[i].ToString(), new Font("宋體", FontSize), new SolidBrush(AxisTextColor), fltX, fltY);    fltY += intFontSpace; //字體上下距離   }  }  /// <summary>  /// 初始化X軸上的刻度和文字  /// </summary>  /// <param name="objGraphics"></param>  private void SetXAxis(ref Graphics objGraphics)  {   float fltX1 = XSpace;   float fltY1 = Height - YSpace;   float fltX2 = XSpace;   float fltY2 = Height - YSpace;   int iCount = 0;   int iSliceCount = 1;   float Scale = 0;   float iWidth = ((Width - 2 * XSpace) / XSlice) * 50; //將要畫刻度的長度分段,并乘以50,以10為單位畫刻度線。   float fltSliceHeight = XSlice / 10; //刻度線的高度   objGraphics.TranslateTransform(fltX1, fltY1); //平移圖像(原點)   objGraphics.RotateTransform(XRotateAngle, MatrixOrder.Prepend); //旋轉圖像   objGraphics.DrawString(Keys[0].ToString(), new Font("宋體", FontSize), new SolidBrush(SliceTextColor), 0, 0);   objGraphics.ResetTransform(); //重置圖像   for (int i = 0; i <= iWidth; i += 10) //以10為單位   {    Scale = i * XSlice / 50;//即(i / 10) * (XSlice / 5),將每個刻度分五部分畫,但因為i以10為單位,得除以10    if (iCount == 5)    {     objGraphics.DrawLine(new Pen(new SolidBrush(AxisColor)), fltX1 + Scale, fltY1 + fltSliceHeight * 1.5f, fltX2 + Scale, fltY2 - fltSliceHeight * 1.5f);     //畫網格虛線     Pen penDashed = new Pen(new SolidBrush(AxisColor));     penDashed.DashStyle = DashStyle.Dash;     objGraphics.DrawLine(penDashed, fltX1 + Scale, fltY1, fltX2 + Scale, YSpace - YSlice / 2);     //這里顯示X軸刻度     if (iSliceCount <= Keys.Length - 1)     {      objGraphics.TranslateTransform(fltX1 + Scale, fltY1);      objGraphics.RotateTransform(XRotateAngle, MatrixOrder.Prepend);      objGraphics.DrawString(Keys[iSliceCount].ToString(), new Font("宋體", FontSize), new SolidBrush(SliceTextColor), 0, 0);      objGraphics.ResetTransform();     }     else     {      //超過范圍,不畫任何刻度文字     }     iCount = 0;     iSliceCount++;     if (fltX1 + Scale > Width - XSpace)     {      break;     }    }    else    {     objGraphics.DrawLine(new Pen(new SolidBrush(SliceColor)), fltX1 + Scale, fltY1 + fltSliceHeight, fltX2 + Scale, fltY2 - fltSliceHeight);    }    iCount++;   }  }  /// <summary>  /// 初始化Y軸上的刻度和文字  /// </summary>  /// <param name="objGraphics"></param>  private void SetYAxis(ref Graphics objGraphics)  {   float fltX1 = XSpace;   float fltY1 = Height - YSpace;   float fltX2 = XSpace;   float fltY2 = Height - YSpace;   int iCount = 0;   float Scale = 0;   int iSliceCount = 1;   float iHeight = ((Height - 2 * YSpace) / YSlice) * 50; //將要畫刻度的長度分段,并乘以50,以10為單位畫刻度線。   float fltSliceWidth = YSlice / 10; //刻度線的寬度   string strSliceText = string.Empty;   objGraphics.TranslateTransform(XSpace - intFontSpace * YSliceBegin.ToString().Length, Height - YSpace); //平移圖像(原點)   objGraphics.RotateTransform(YRotateAngle, MatrixOrder.Prepend); //旋轉圖像   objGraphics.DrawString(YSliceBegin.ToString(), new Font("宋體", FontSize), new SolidBrush(SliceTextColor), 0, 0);   objGraphics.ResetTransform(); //重置圖像   for (int i = 0; i < iHeight; i += 10)   {    Scale = i * YSlice / 50; //即(i / 10) * (YSlice / 5),將每個刻度分五部分畫,但因為i以10為單位,得除以10    if (iCount == 5)    {     objGraphics.DrawLine(new Pen(new SolidBrush(AxisColor)), fltX1 - fltSliceWidth * 1.5f, fltY1 - Scale, fltX2 + fltSliceWidth * 1.5f, fltY2 - Scale);     //畫網格虛線     Pen penDashed = new Pen(new SolidBrush(AxisColor));     penDashed.DashStyle = DashStyle.Dash;     objGraphics.DrawLine(penDashed, XSpace, fltY1 - Scale, Width - XSpace + XSlice / 2, fltY2 - Scale);     //這里顯示Y軸刻度     strSliceText = Convert.ToString(YSliceValue * iSliceCount + YSliceBegin);     objGraphics.TranslateTransform(XSpace - intFontSize * strSliceText.Length, fltY1 - Scale); //平移圖像(原點)     objGraphics.RotateTransform(YRotateAngle, MatrixOrder.Prepend); //旋轉圖像     objGraphics.DrawString(strSliceText, new Font("宋體", FontSize), new SolidBrush(SliceTextColor), 0, 0);     objGraphics.ResetTransform(); //重置圖像     iCount = 0;     iSliceCount++;    }    else    {     objGraphics.DrawLine(new Pen(new SolidBrush(SliceColor)), fltX1 - fltSliceWidth, fltY1 - Scale, fltX2 + fltSliceWidth, fltY2 - Scale);    }    iCount++;   }  }  /// <summary>  /// 畫曲線  /// </summary>  /// <param name="objGraphics"></param>  private void DrawContent(ref Graphics objGraphics, float[] fltCurrentValues, Color clrCurrentColor)  {   Pen CurvePen = new Pen(clrCurrentColor, CurveSize);   PointF[] CurvePointF = new PointF[Keys.Length];   float keys = 0;   float values = 0;   for (int i = 0; i < Keys.Length; i++)   {    keys = XSlice * i + XSpace;    values = (Height - YSpace) + YSliceBegin - YSlice * (fltCurrentValues[i] / YSliceValue);    CurvePointF[i] = new PointF(keys, values);   }   objGraphics.DrawCurve(CurvePen, CurvePointF, Tension);  }  /// <summary>  /// 初始化標題  /// </summary>  /// <param name="objGraphics"></param>  private void CreateTitle(ref Graphics objGraphics)  {   objGraphics.DrawString(Title, new Font("宋體", FontSize), new SolidBrush(TextColor), new Point((int)(Width - XSpace) - intFontSize * Title.Length, (int)(YSpace - YSlice / 2 - intFontSpace)));  } }}

希望本文所述對大家的C#程序設計有所幫助。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
精品视频9999| 九色精品美女在线| 亚洲男人的天堂在线| 成人免费在线网址| 欧美激情中文字幕在线| 久久久噜久噜久久综合| 国产精品成人av在线| 欧美激情视频在线| 国产视频精品自拍| 国产精品偷伦视频免费观看国产| 久久免费成人精品视频| 国产欧美日韩中文| 国产成人中文字幕| 久久久久久亚洲精品中文字幕| 日韩电影中文字幕在线| 中文字幕亚洲无线码在线一区| 日韩av在线影院| 亚洲男人天堂网站| 欧美丰满少妇xxxx| 亚洲欧美日韩精品久久| 91精品视频观看| 欧美一区二区三区免费观看| 大桥未久av一区二区三区| 国产日韩欧美日韩大片| 久久精品国产v日韩v亚洲| 亚洲欧美中文在线视频| 国产欧美精品日韩精品| 久久免费少妇高潮久久精品99| 在线国产精品播放| 亚洲最大成人在线| 欧美日韩免费在线观看| 日韩精品久久久久久久玫瑰园| 欧美在线精品免播放器视频| 日本不卡免费高清视频| 亚洲一区二区精品| 2019中文在线观看| 久久精品这里热有精品| 国产精品视频一区二区高潮| 欧美精品中文字幕一区| 国产精品美女免费看| 精品久久久久久国产| 91精品啪在线观看麻豆免费| 久久777国产线看观看精品| 欧美激情喷水视频| 亚洲第五色综合网| 国产999精品久久久| 欧美猛交免费看| 欧美国产在线视频| 日韩在线观看网站| 国产精品入口免费视频一| 久久福利网址导航| 欧美成人免费观看| 日韩免费看的电影电视剧大全| 亚洲国产精品嫩草影院久久| 神马久久久久久| 成人美女免费网站视频| 日韩高清电影免费观看完整版| 亚洲性夜色噜噜噜7777| 日本成人黄色片| 国产精品高潮呻吟久久av无限| 日韩av手机在线观看| 国产91网红主播在线观看| 亚洲欧美激情精品一区二区| 国内成人精品一区| 欧美一区二区三区免费视| 亚洲跨种族黑人xxx| 97碰在线观看| 久久99热这里只有精品国产| 欧美日韩另类视频| 国产精品天天狠天天看| 成人av电影天堂| 国产一区二区美女视频| 伊人成人开心激情综合网| 亚洲自拍偷拍视频| 国产精品久久久久久五月尺| 久久中文字幕在线视频| 日韩中文字幕在线精品| 成人精品在线观看| 国产精品www色诱视频| 一区二区三区亚洲| 亚洲国产美女久久久久| 色噜噜亚洲精品中文字幕| 色噜噜狠狠狠综合曰曰曰88av| 黄色精品在线看| 亚洲精品99久久久久中文字幕| 亚洲最大成人在线| 欧美亚洲激情视频| 亚洲国内高清视频| 国产精品久久久久一区二区| 久久影视电视剧免费网站| 久久免费少妇高潮久久精品99| 日韩视频在线一区| 中文字幕亚洲专区| 九九热这里只有在线精品视| 亚洲黄色在线看| 欧美激情喷水视频| 亚洲女人被黑人巨大进入| 国产福利视频一区二区| 高清一区二区三区四区五区| 久久精品国产2020观看福利| 一本一本久久a久久精品综合小说| 91久久综合亚洲鲁鲁五月天| 久热国产精品视频| 91精品视频专区| 欧美成人激情视频| 亚洲欧美日韩精品久久亚洲区| 日韩av123| 日韩在线一区二区三区免费视频| 在线观看精品国产视频| 国产精品自产拍在线观| 日本精品免费观看| 国产精品黄色影片导航在线观看| 国产精品尤物福利片在线观看| 亚洲大胆人体在线| 91在线无精精品一区二区| 欧美国产激情18| 国产精品丝袜高跟| 国产亚洲欧美视频| 欧美剧在线观看| 久久天天躁狠狠躁夜夜av| 91精品视频播放| 亚洲电影成人av99爱色| 神马久久桃色视频| 亚洲精品乱码久久久久久按摩观| 庆余年2免费日韩剧观看大牛| 91国产视频在线播放| 18一19gay欧美视频网站| 2019中文字幕全在线观看| 69**夜色精品国产69乱| 亚洲精品乱码久久久久久金桔影视| 国产精品久久久久久av福利软件| 国产精品久久久久久久久免费看| 精品亚洲永久免费精品| 久久亚洲电影天堂| 欧美极品第一页| 国产精品久久久久久久久久99| 97**国产露脸精品国产| www.欧美精品| 高清亚洲成在人网站天堂| 亚洲天堂av在线免费| 91久久精品国产91久久性色| 日韩中文字幕免费视频| 热草久综合在线| 91欧美精品午夜性色福利在线| 欧美肥婆姓交大片| 亚洲成人a**站| 少妇av一区二区三区| 亚洲一区二区少妇| 久久成人精品电影| 精品亚洲一区二区三区四区五区| 亚洲美女www午夜| 欧美一级免费看| 亚洲精品网站在线播放gif| 亚洲福利在线播放| 欧美一级bbbbb性bbbb喷潮片| 亚洲香蕉成人av网站在线观看| 51视频国产精品一区二区| 亚洲精品第一页| 国产精品91久久久久久| 国内精品久久久久久久| 91影视免费在线观看| 欧美专区在线观看| 国产成人在线播放| 国产精品久久久久久网站|