日韩av黄I国产麻豆传媒I国产91av视频在线观看I日韩一区二区三区在线看I美女国产在线I麻豆视频国产在线观看I成人黄色短片

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 运维知识 > Android >内容正文

Android

一行代码实现Android App指引

發布時間:2023/12/20 Android 32 豆豆
生活随笔 收集整理的這篇文章主要介紹了 一行代码实现Android App指引 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

目錄

  • 概述
    • 指引需求分析
      • 入門級指引
      • 升級版指引
      • 指引需求的抽象
    • 指引的技術實現
      • 指引的要素:Shape
      • 封裝指引步驟:GuideInfo
      • 繪制指引要素:GuideView
      • 管理指引:GuideManager
      • 承載GuideView的載體:GuideDialog
      • 接入項目
    • 關鍵技術點
      • 定位高亮區域
      • 繪制高亮的View區域
      • 高亮區域點擊事件
    • 優缺點
    • 項目地址
    • 總結

概述

前幾周app改版,在修改老代碼的過程中發現了一個指引,讓我想起很久以前項目里指引實現是在布局文件中添加布局,并在代碼中插入很多非業務的代碼,這樣寫感覺不好。指引本只是一個不太重要,可能經常變動的功能,說不定下個版本又改了,當它和正常業務耦合在一起以后,就顯得代碼有點混亂了。有沒有一種方法,可以無縫嵌入,將指引和正常業務徹底解耦?前幾天早晨,幾個公眾號都發了同樣一篇博客來摳個圖吧~——更優雅的Android UI界面控件高亮的實現,看到這篇博客的時候有種醍醐灌頂的感覺,這不正是我想要的指引嗎?看完博客中的實現原理后,決定動手重復造一個輪子,本文簡單分析一下這個輪子是如何實現的,并分析了一下優缺點。下面先看個效果:

指引需求分析

不談技術實現,首先分析一下指引這個需求本身。

入門級指引

入門級的指引,就是最簡單的指引,在app安裝新版本或者覆蓋安裝新版本后第一時間彈出來幾張圖片。為了突出某些功能,會高亮顯示一些內容,同時還有一些指示性的箭頭,或者在高亮旁邊有文本描述。

升級版指引

升級版指引,在用戶第一次進入到個頁面的時候,告訴用戶哪幾個按鈕有是做什么的。指引內容和入門級的差不多,高亮顯示View,箭頭、文本描述,點擊高亮View后跑到下一步指引直到指引結束。

指引需求的抽象

簡單指引一般由UI切圖就好,這里以app內部的指引需求分析指引,如圖(圖片是隨便找的),指引一般包括以下內容:

  • 滿屏幕的半透明遮罩層;
  • 高亮顯示突出顯示底層app頁面的某個或者某些View;
  • 在高亮顯示的View旁邊可能有一些帶文本的圖片,或者指示方向的圖片+文本;
  • 高亮部分可以響應點擊事件,并且很有可能點擊后繼續顯示下一步指引,直到顯示完。
  • 指引的技術實現

    分析了指引的需求后,得到指引的基本元素,決定用自定義View實現,命名這個自定義View為GuideView。實現整個指引流程如下:
    1.定義指引繪制要素Shape,及其派生類:Rectangle、Oval、BitmapDecoration、TextDecoration;
    2.定義每一步指引的信息GuideInfo,并獲取高亮區域的坐標矩形;
    3.定義GuideView繼承View,繪制指引要素:Shape;
    4.定義GuideManager,管理多步驟指引;
    5.定義GuideDialog承載GuideView,覆蓋在頁面上,和GuideManager

    指引的要素:Shape

    指引的基本要素包括:高亮顯示的View區域,圖片,文本等飾品。定義個接口,命名為Shape,那么Shape有子類:高亮的矩形(Rectangle),高亮的圓形(Oval),圖片(BitmapDecoration),文本(TextDecoration)。指引要素實現代碼如下:

    interface Shape {fun draw(canvas: Canvas, paint: Paint) }class Oval(private val rect: RectF) : Shape {override fun draw(canvas: Canvas, paint: Paint) {canvas.drawOval(rect, paint)} }class Rectangle(private val rect: RectF,private val xRadius: Float = 0F,private val yRadius: Float = 0F ) : Shape {override fun draw(canvas: Canvas, paint: Paint) {canvas.drawRoundRect(rect, xRadius, yRadius, paint)} } class BitmapDecoration(private val bitmap: Bitmap,private val left: Float,private val top: Float ) : Shape {override fun draw(canvas: Canvas, paint: Paint) {canvas.drawBitmap(bitmap, left, top, paint)} } class TextDecoration(protected val text: String, // 要繪制的文本protected val textSize: Float, // 字體大小protected val textColor: Int, // 字體顏色protected val startX: Float, // x軸起點(left)protected val startY: Float, // y軸七點(top)protected val bold: Boolean = false // 粗體 ) : Shape {override fun draw(canvas: Canvas, paint: Paint) {paint.color = textColorpaint.textSize = textSizepaint.typeface = if (bold) {Typeface.create(Typeface.SANS_SERIF, Typeface.BOLD)} else {Typeface.DEFAULT_BOLD}canvas.drawText(text, startX, startY, paint)} }

    封裝指引步驟:GuideInfo

    上面介紹了指引要素Shape,接下來需要繼續完成指引要素的封裝,命名為GuideInfo。GuideInfo封裝了一個指引頁面(或者說一幀)包含的所有顯示要素,也就是多個Shape,包括:高亮的View區域,圖片,文本等。GuideView顯示指引,也就是把一個GuideInfo對象的Shape繪制出來。

    class GuideInfo(private val targetView: View, // 高亮顯示的,要指引的Viewval padding: Int = 0, // 高亮區域的padding(如果要顯示大一些時可設置padding)val isOval: Boolean = false, // 高亮區域是否時圓形val radius: Float = 0F, // 如果時矩形,那么可以設置圓角private val paddingLeft: Int = 0, // 四個方向的paddingprivate val paddingTop: Int = 0,private val paddingRight: Int = 0,private val paddingBottom: Int = 0,autoShape: Boolean = false // 是否使用自定義的高亮區域,true: 自動根據View的Background獲取Shape ) {val mShapes = mutableListOf<Shape>()var mTargetHighlightShape: Shape? = null // 這就是高亮顯示的地方val targetBound: RectF // 高亮View的矩形區域,可根據這個矩形設置其它Shape的位置 }

    一個GuideInfo對象代表一個指引步驟(一幀),一個完整的指引,可能包含多個步指引

    繪制指引要素:GuideView

    繪制指引的大概流程如下:

  • 繪制一個半透明遮罩層;
  • 繪制高亮顯示的View區域;
  • 繪制其它裝飾,如圖片,文本等。
  • 代碼如下:

    class GuideView : View, View.OnTouchListener, GestureDetector.OnGestureListener {/*** 當點擊了高亮區域時響應*/interface OnClickListener {fun onClick()}private val location = IntArray(2)private var initLocation = falseprivate val mPaint = Paint()private var mGuideInfo: GuideInfo? = nullprivate var background: Int = 0private lateinit var mGestureDetector: GestureDetectorvar mOnClickListener: OnClickListener? = nullprivate fun initView(attrs: AttributeSet) {background = getColor(context, R.color.translucent)val typedArray: TypedArray = context.obtainStyledAttributes(attrs, R.styleable.GuideView)background = typedArray.getColor(R.styleable.GuideView_background_translucent, background)typedArray.recycle()mPaint.isAntiAlias = truesetOnTouchListener(this)mGestureDetector = GestureDetector(context, this)}constructor(context: Context) : super(context)constructor(context: Context, attrs: AttributeSet) : super(context, attrs) {initView(attrs)}constructor(context: Context, attrs: AttributeSet, defStyleAttr: Int) : super(context, attrs, defStyleAttr) {initView(attrs)}override fun onDraw(canvas: Canvas) {super.onDraw(canvas)if(!initLocation) {getLocationOnScreen(location)initLocation = true}drawBackGround(canvas)drawShapes(canvas)}override fun onTouch(v: View?, event: MotionEvent?): Boolean {if (v != this || event == null || mGuideInfo == null) {return false}return mGestureDetector.onTouchEvent(event)}override fun onShowPress(e: MotionEvent?) {}override fun onSingleTapUp(event: MotionEvent?): Boolean {if (event == null || mGuideInfo == null) {return false}if (mGuideInfo!!.targetBound.contains(location[0] + event.x,location[1] + event.y)) {mOnClickListener?.onClick()return true}return false}override fun onDown(e: MotionEvent?): Boolean {return true}override fun onFling(e1: MotionEvent?,e2: MotionEvent?,velocityX: Float,velocityY: Float): Boolean {return false}override fun onScroll(e1: MotionEvent?,e2: MotionEvent?,distanceX: Float,distanceY: Float): Boolean {return false}override fun onLongPress(e: MotionEvent?) {}fun showGuide(guideStep: GuideInfo) {this.mGuideInfo = guideSteppostInvalidate()}private fun drawBackGround(canvas: Canvas) {mPaint.xfermode = nullmPaint.color = backgroundcanvas.drawRect(0F, 0F, width.toFloat(), height.toFloat(), mPaint)}private fun drawShapes(canvas: Canvas) {if (mGuideInfo == null) {return}// 先轉換一下坐標,這樣繪制得到的和底層目標View區域重疊canvas.translate(-location[0].toFloat(), -location[1].toFloat())// 1.先繪制要摳圖的部分,也就是高亮的區域mPaint.xfermode = PorterDuffXfermode(PorterDuff.Mode.DST_OUT)mGuideInfo?.mTargetHighlightShape?.draw(canvas, mPaint)// 2.再繪制其它的箭頭,文本等指示性的ShapemPaint.xfermode = nullmGuideInfo?.mShapes?.forEach {it.draw(canvas, mPaint)}}}

    管理指引:GuideManager

    一個GuideInfo代表一幀指引,一個完整的指引可能會包含多幀,所以,指引流程需要定義一個管理類GuideManager,作為中間層,上對接用戶,下對接GuideDialog,比較簡單,就是定義了一個GuideInfo數組和一個指向當前步驟的指針,還定義了一些回調,直接貼代碼吧:

    interface GuideListener {fun onNextStep(step: Int)fun onCompleted() }class GuideManager(activity: Activity) :GuideDialog.OnNextStepListener {private val mGuideSteps = mutableListOf<GuideInfo>()private var currentStep = -1val mGuideDialog: GuideDialog =GuideDialog(activity)var mGuideListener: GuideListener? = nullvar showGuideButton = falseinit {mGuideDialog.mOnNextStepListener = thisif (!showGuideButton) {mGuideDialog.btnPreStep.visibility = View.GONEmGuideDialog.btnNextStep.visibility = View.GONE}}fun addGuideStep(guideInfo: GuideInfo) {mGuideSteps.add(guideInfo)}fun guideStepCount(): Int {return mGuideSteps.size}fun show() {mGuideDialog.show()onNextStep()}override fun onNextStep() {if (currentStep >= mGuideSteps.size - 1) {mGuideDialog.dismiss()mGuideListener?.onCompleted()return}currentStep++val guideStep: GuideInfo = mGuideSteps[currentStep]mGuideDialog.guideView.showGuide(guideStep)if (currentStep > 0 && showGuideButton) {mGuideDialog.btnPreStep.visibility = View.VISIBLE}updateNextText()}override fun onPreStep() {if (currentStep == 0) {return}currentStep -= 1val guideStep: GuideInfo = mGuideSteps[currentStep]mGuideDialog.guideView.showGuide(guideStep)if (currentStep == 0 && showGuideButton) {mGuideDialog.btnPreStep.visibility = View.GONE}updateNextText()}private fun updateNextText() {if (currentStep == mGuideSteps.size - 1) {mGuideDialog.btnNextStep.setText(R.string.end)} else {mGuideDialog.btnNextStep.setText(R.string.next_step)}mGuideListener?.onNextStep(currentStep)} }

    承載GuideView的載體:GuideDialog

    這個就更簡單了,直接看代碼:

    class GuideDialog : BaseDialog, View.OnClickListener,GuideView.OnClickListener {var mOnNextStepListener: OnNextStepListener? = nullconstructor(context: Context): super(context, R.style.DialogFullScreenTranslucent){setContentView(R.layout.dialog_guide)btnNextStep.setOnClickListener(this)btnPreStep.setOnClickListener(this)guideView.mOnClickListener = this}override fun onClick(view: View) {if (view.id == R.id.btnNextStep) {mOnNextStepListener?.onNextStep()} else if (view.id == R.id.btnPreStep) {mOnNextStepListener?.onPreStep()}}interface OnNextStepListener {fun onNextStep()fun onPreStep()}override fun onClick() {mOnNextStepListener?.onNextStep()} }

    接入項目

    這里舉個栗子,自己再封裝一下,就算是一行代碼接入,代碼中的imgLogo,imgLogo2,tvName分別是頁面上的ImageView和TextView:

    fun showGuide(context: Activity) {GuideManager(context).apply {addGuideStep(GuideInfo(imgLogo, isOval = true).apply {val textShape = TextDecoration("這是圓形高亮區域,點擊高亮進入下一步",sp2px(context, 12F).toFloat(),ContextCompat.getColor(context, R.color.white),targetBound.right + dip2px(context, 8F), targetBound.centerY())addShape(textShape)})addGuideStep(GuideInfo(imgLogo2, radius = 16F).apply {val textShape = TextDecoration("這是圓角矩形高亮區域,點擊高亮繼續進入下一步",sp2px(context, 12F).toFloat(),ContextCompat.getColor(context, R.color.white),targetBound.left, targetBound.bottom + dip2px(context, 24F))addShape(textShape)})addGuideStep(GuideInfo(tvName, padding = 20).apply {val bitmap = BitmapFactory.decodeResource(resources, R.mipmap.ic_add_location_white_48dp)val bitmapShape =BitmapDecoration(bitmap,targetBound.left,targetBound.top - dip2px(context, 45F))addShape(bitmapShape)val textShape = TextDecoration("點擊高亮結束指引",sp2px(context, 14F).toFloat(),ContextCompat.getColor(context, R.color.white),targetBound.centerX(),targetBound.bottom + dip2px(context, 32F))addShape(textShape)})mGuideListener = object: GuideListener {override fun onNextStep(step: Int) {Toast.makeText(context, "當前步驟:${step + 1}", Toast.LENGTH_SHORT).show()}override fun onCompleted() {tvShowGuide.visibility = View.VISIBLE}}// 如果要顯示“上一步”,“下一步”,可以設置GuideManager中的mGuideDialog,}.show() }

    關鍵技術點

    定位高亮區域

    通過View#getLocationOnScreen()方法可以獲得目標View左上角頂點的屏幕坐標,已知目標View的寬高,然后可以得到高亮View的矩形(劃重點:是屏幕坐標,后面繪制需要根據GuideView左上角坐標做一次變換,這樣繪制出來剛好和目標View重疊):

    fun targetViewRectF(): RectF {val location = IntArray(2)targetView.getLocationOnScreen(location)val rectF = RectF(location[0].toFloat(),location[1].toFloat(),location[0].toFloat() + targetView.width,location[1].toFloat() + targetView.height)return rectF}

    繪制高亮的View區域

    如代碼所示,繪制高亮View實際是從半透明背景中把目標View的區域摳出來,這樣底層View就能正常顯示,對比半透明層就是高亮效果了。關鍵點一,繪制完半透明背景后,需要轉換一次坐標,xy就是GuideView左上角頂點坐標;關鍵點二,mPaint.xfermode = PorterDuffXfermode(PorterDuff.Mode.DST_OUT),有興趣可以深入學習一下,這里不解析(自己不懂,就不要忽悠別人)。

    private fun drawShapes(canvas: Canvas) {if (mGuideInfo == null) {return}// 轉換一下坐標,這樣繪制得到的和底層目標View區域重疊canvas.translate(-location[0].toFloat(), -location[1].toFloat())// 1.先繪制要摳圖的部分,也就是高亮的區域mPaint.xfermode = PorterDuffXfermode(PorterDuff.Mode.DST_OUT)mGuideInfo?.mTargetHighlightShape?.draw(canvas, mPaint)// 2.再繪制其它的箭頭,文本等指示性的ShapemPaint.xfermode = nullmGuideInfo?.mShapes?.forEach {it.draw(canvas, mPaint)}}

    高亮區域點擊事件

    上面已經得到了高亮View的矩形區域RectF,只要監聽onTouch,判斷事件是否落在這個矩形內即可。通過GestureDetector接管onTouch事件,可以輕松實現高亮View區域的點擊事件。
    至此,指引繪制部分,GuideView基本就這么點代碼,就OK了。

    override fun onTouch(v: View?, event: MotionEvent?): Boolean {if (v != this || event == null || mGuideInfo == null) {return false}return mGestureDetector.onTouchEvent(event)}override fun onSingleTapUp(event: MotionEvent?): Boolean {if (event == null || mGuideInfo == null) {return false}if (mGuideInfo!!.targetBound.contains(event.rawX, event.rawY)) {mOnClickListener?.onClick()return true}return false}

    優缺點

    優點:

    • 封裝了指引的數據結構,支持擴展,清晰易懂;
    • 流式構建流程,清晰優雅,簡潔卻不簡單,可以實現復雜的指引;
    • 對現有的代碼無侵入性,封裝后,可以做到一行代碼接入指引;
    • 無反射等影響性能的代碼,對性能無任何影響,同一個頁面的多個指引在一個Dialog中繪制,不會有切換感;
    • 支持高亮View的點擊事件

    缺點:

    • 每幀指引,只有一個高亮的View,目前還不能顯示多個高亮的View;
    • 給指引添加圖片時,需要找準位置,文本目前還不支持換行,也不支持方向(如果確實需要,可繼承TextDecoration,實現onDraw(),或者實現接口Shape重新定義一個新的TextDecoration),再或者直接讓UI設計師給tu,用BitmapDecoration代替;
    • 高亮的View未能自動識別形狀和屬性,需要根據View來設置屬性(雖然這些是已知的,沒太大問題,但是如果能夠自動識別確實可以再簡化代碼)

    項目地址

    代碼不多,三五百行,核心的就那么幾十行,下面附上項目githug地址:
    GuideView

    總結

    • 一行代碼接入指引,無代碼侵入,無性能損耗;
    • 借助kotlin的apply函數流式構建指引流程,簡介明了;
    • 以屏幕坐標為參考,準確定位高亮View的矩形區域;
    • 在構建流程中動態添加Bitmap和文本,可以實現復雜指引;
    • 實現了高亮區域點擊事件,可以監聽并完成額外的需求;
    • 不足之處在于未能根據View自動識別高亮區域,隨無大礙,但有待優化。

    最后特別感謝來摳個圖吧~——更優雅的Android UI界面控件高亮的實現的作者,如果沒有他的思路我也難以實現這個指引小項目,也就沒有本文。

    總結

    以上是生活随笔為你收集整理的一行代码实现Android App指引的全部內容,希望文章能夠幫你解決所遇到的問題。

    如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。

    91精品国产欧美一区二区成人 | 九九热免费在线观看 | 久久久久久国产精品 | 久久与婷婷 | 中文字幕在线观看国产 | 91久久久久久国产精品 | 国产日韩视频在线 | 黄色网www| 91中文视频 | x99av成人免费 | 国产一区二区三区高清播放 | 久久精品国产亚洲精品 | 综合伊人久久 | 人人超在线公开视频 | 国产午夜剧场 | 丁香花中文在线免费观看 | 91伊人久久大香线蕉蜜芽人口 | 免费视频a| 色亚洲激情 | 激情视频在线观看网址 | 精产嫩模国品一二三区 | av免费在线看网站 | 国内精品久久久久久久影视麻豆 | 91精品视频在线观看免费 | www.eeuss影院av撸 | 玖玖玖国产精品 | 91精品区 | 九九日韩 | 精品国产伦一区二区三区观看体验 | 国产综合精品一区二区三区 | 国产人成一区二区三区影院 | 日韩网站视频 | 国产视频精品在线 | 国内精品久久久久久中文字幕 | 在线免费观看黄色大片 | 九九九热精品免费视频观看网站 | 久久久久成人精品免费播放动漫 | 天天爱天天色 | av 在线观看 | 97涩涩视频 | 国产香蕉久久精品综合网 | 精品视频在线免费 | 午夜久久久精品 | 国产99久| 久久久久免费精品视频 | 欧美日韩国产色综合一二三四 | 色婷婷国产 | 99免在线观看免费视频高清 | 婷婷免费在线视频 | 久草男人天堂 | 一区二区欧美在线观看 | 日韩区欠美精品av视频 | 青青河边草免费观看完整版高清 | 日本乱视频 | 日韩和的一区二在线 | 日韩免费视频在线观看 | www天天干com | 天海冀一区二区三区 | 国产91综合一区在线观看 | 九九久久影视 | 国产精品免费久久久久影院仙踪林 | 久久天天躁狠狠躁夜夜不卡公司 | 欧美另类一二三四区 | 国产精品18久久久久久不卡孕妇 | 成人在线播放av | 毛片一二区 | 日韩大片在线 | 久久久精品免费观看 | 午夜久久久久久久久久久 | 免费下载高清毛片 | 91精品在线看 | 色瓜 | 99国内精品久久久久久久 | 日韩免费一区二区在线观看 | 最近中文字幕mv免费高清在线 | 99久久99视频 | 久久黄色网 | 日日爱网址| avwww在线 | 天天摸天天舔天天操 | 亚洲精品动漫在线 | 激情久久久久久久久久久久久久久久 | 欧美精品一区二区免费 | 欧美日韩不卡在线视频 | 成人免费观看视频大全 | 久草在线网址 | 日韩理论片在线观看 | 国产精品福利午夜在线观看 | 精品黄色在线 | 国产又粗又猛又黄又爽 | 日韩一级电影网站 | 免费黄色在线网址 | 久久久精品亚洲 | 99免在线观看免费视频高清 | 亚洲 欧美变态 另类 综合 | 久久久精品国产免费观看同学 | 国产无套精品久久久久久 | 丁香色婷 | 免费看成人av | 精品久久久久久久久久久久久 | 91资源在线视频 | 亚洲麻豆精品 | 天天综合网久久 | 黄色av大片 | 亚洲国产精品视频在线观看 | 综合黄色网 | 99热国产在线观看 | 成人宗合网 | 日韩在线观看视频中文字幕 | 精品国产一区二区三区久久久久久 | 人人看看人人 | 麻豆国产精品视频 | a v在线视频| 99精品视频精品精品视频 | 在线视频精品播放 | 久久不卡免费视频 | 99日精品| 狠狠色伊人亚洲综合网站野外 | 友田真希x88av | 中文字幕在线网 | 国产欧美日韩一区 | 精品国产一区二区三区蜜臀 | 久久国产精品一区二区三区四区 | 狠狠干网址 | 欧美一区二区精品在线 | 国产97色在线 | 九九久久久久久久久激情 | 嫩嫩影院理论片 | 81精品国产乱码久久久久久 | 97视频在线播放 | 93久久精品日日躁夜夜躁欧美 | 奇米影视在线99精品 | 国产视频观看 | 激情婷婷网 | 日韩免费视频 | 国产精品久久久久一区二区国产 | 成年人在线观看视频免费 | 超碰在线94 | 国产一级二级三级视频 | 婷婷色综合 | 亚洲精品在线播放视频 | 亚洲女在线 | 色噜噜日韩精品一区二区三区视频 | 98久久| 九九爱免费视频在线观看 | 91九色网址| 免费日韩av电影 | 麻豆精品在线视频 | 丁香婷婷综合网 | 黄色成年网站 | 婷婷在线免费视频 | 久久久久这里只有精品 | 激情av在线播放 | 亚洲视频免费 | 丰满少妇对白在线偷拍 | 一区二区三区视频 | 91久久国产自产拍夜夜嗨 | 亚洲日本国产 | 国产亚洲欧美日韩高清 | 91探花国产综合在线精品 | 日本 在线 视频 中文 有码 | 色99中文字幕 | 久久成年人网站 | 99精品一区二区三区 | 日韩精品久久中文字幕 | 免费无遮挡动漫网站 | 国产精品粉嫩 | 午夜视频一区二区三区 | 国产精品一区二区你懂的 | 激情视频在线高清看 | 97电影在线观看 | 久草视频在线免费播放 | 久久色中文字幕 | 日韩精品久久一区二区三区 | 91av手机在线| 欧美激情精品久久久久久变态 | 国产精品都在这里 | 午夜精品一二区 | 久久在线精品 | 久久免费视频这里只有精品 | 中文字幕视频免费观看 | 欧美黄色软件 | 国产精品久久久久亚洲影视 | 在线视频手机国产 | 久久高清av | 欧美日韩在线精品 | 狠狠艹夜夜干 | 天天操天天综合网 | 精品国产一区二区三区四区在线观看 | 国产毛片久久久 | 五月天久久婷婷 | 日韩精品中字 | 亚洲女人天堂成人av在线 | 夜夜骑天天操 | 天天摸天天操天天舔 | 久久久久久久久久久久久影院 | 亚洲三级黄色 | 一区 二区电影免费在线观看 | 欧美亚洲免费在线一区 | 免费av网址在线观看 | 伊人久在线 | 狠狠网 | 91视频这里只有精品 | 欧美成年性 | 久久国产手机看片 | 日韩在线精品视频 | 国产精品女主播一区二区三区 | 亚洲影视九九影院在线观看 | 国产精品视频不卡 | 亚洲欧美综合 | 日韩免费电影一区二区三区 | 精品福利视频在线观看 | 欧美激情精品久久久久 | 在线观看av不卡 | 久久亚洲电影 | 国产91影视 | 99久久久国产精品免费99 | 91精品免费在线观看 | 91在线看黄 | 婷五月天激情 | 亚洲精品高清视频在线观看 | 福利视频区| 美女视频久久 | 久久国产精品一区二区 | 精品一二区 | 欧美成人aa | 免费亚洲视频在线观看 | 国产精品成人在线观看 | 色999精品| 国产1区2区3区在线 亚洲自拍偷拍色图 | 成年人黄色免费看 | 国产亚洲人成网站在线观看 | 久久av电影 | 中文字幕国产在线 | 久久专区 | 国产亚洲综合在线 | 中文字幕电影高清在线观看 | 日本少妇久久久 | 国产精选在线观看 | 国产精品一区二区电影 | 美女网站在线免费观看 | 99精品国产一区二区 | 一区二区三区四区五区六区 | 99久久久国产精品免费观看 | 日韩电影在线看 | 久久久久久久久综合 | 青青河边草观看完整版高清 | 国产亚洲精品综合一区91 | 婷婷丁香六月 | 欧美精品久久久久久久免费 | 蜜臀aⅴ国产精品久久久国产 | 欧美另类z0zx | 久久久久成人精品免费播放动漫 | 国产免费中文字幕 | www.夜色.com | 久久免费视频一区 | 国产成人精品亚洲 | 国产69精品久久久久久久久久 | 国产精品久久久久久久久久久久久 | 国产黄色在线观看 | 精品99视频| 五月天欧美精品 | 日韩91在线 | av电影中文 | 久久男人视频 | 久久国内精品视频 | 国产综合精品久久 | 国产裸体视频bbbbb | 久久撸在线视频 | 亚洲好视频 | 婷婷六月激情 | 在线亚洲激情 | 国产一在线精品一区在线观看 | 欧美日本一区 | 国产麻豆视频 | 热久久国产精品 | 久草爱| 麻豆传媒视频在线播放 | 亚洲成aⅴ人片久久青草影院 | 欧美色综合天天久久综合精品 | 国产成人久久精品一区二区三区 | 五月婷婷在线播放 | 国产成年免费视频 | 男女精品久久 | 福利电影久久 | 日日干美女| 欧美va天堂va视频va在线 | 91精品爽啪蜜夜国产在线播放 | 人人干在线 | 狠狠操狠狠插 | 国产精品久久久久久一区二区三区 | 456免费视频 | 久久久久久高潮国产精品视 | www国产亚洲 | 伊人婷婷在线 | 日韩av三区| 久久天天躁狠狠躁亚洲综合公司 | 大荫蒂欧美视频另类xxxx | 一级欧美日韩 | 国产精品大片免费观看 | 成人一级片免费看 | 亚洲精品国产第一综合99久久 | 欧美a在线免费观看 | 毛片网在线 | 一级黄色片毛片 | 人人澡人人草 | 99热精品在线观看 | 欧美最猛性xxxxx(亚洲精品) | 国产中文自拍 | 日韩精品一区二区免费 | 亚洲资源一区 | 免费亚洲视频 | 亚洲小视频在线观看 | 五月天六月色 | 97视频在线观看成人 | 亚洲国产三级在线观看 | 99精品毛片| 中文字幕久久亚洲 | 蜜臀久久99精品久久久酒店新书 | 18国产精品白浆在线观看免费 | 国产精彩视频一区 | 亚洲成人一区 | 欧美成人手机版 | 韩国在线一区二区 | 久久99爱视频 | 在线视频在线观看 | 亚洲精品欧美专区 | 欧美少妇xxx | 成人视屏免费看 | 草免费视频 | 久艹在线播放 | 日韩av免费观看网站 | 97香蕉视频 | 人人干人人搞 | 尤物九九久久国产精品的分类 | 婷婷精品在线视频 | 精品国产伦一区二区三区观看方式 | 五月天久久综合网 | 国产精品久久久久三级 | 国外调教视频网站 | 日本成人黄色片 | 国产精品免费视频网站 | 成人黄色av免费在线观看 | 99久久精品免费看国产一区二区三区 | 91精品在线免费 | 99在线观看视频网站 | 国产精品99久久久久久人免费 | 亚洲精品动漫成人3d无尽在线 | 久久久久激情视频 | 成人精品久久久 | 国产精品18p | 热久久免费国产视频 | 国产一区二区三区网站 | 超碰在线观看av.com | 欧美韩国日本在线观看 | 一区二区三区在线播放 | 国内精品美女在线观看 | 欧美色图88 | 91丨九色丨蝌蚪丨老版 | 欧美亚洲国产精品久久高清浪潮 | 国产精品日韩在线观看 | 亚洲五月花 | www.av免费 | 久久久国产精品亚洲一区 | 国产成人久久久久 | 99精品视频在线观看视频 | 精品视频97 | 亚洲视频1 | 中文字幕第一页在线 | 人人爽人人爽人人片av | 日韩免费中文 | 在线91视频 | 免费在线国产精品 | av视屏在线播放 | 午夜视频免费 | 乱男乱女www7788 | 9热精品| 日韩av一区二区三区在线观看 | 午夜精品久久久99热福利 | 国产精品女人久久久久久 | 中文字幕免费播放 | 日本在线观看一区二区三区 | 亚洲视频电影在线 | 国产精品热视频 | 中字幕视频在线永久在线观看免费 | 亚洲日韩精品欧美一区二区 | 久久精品国产亚洲aⅴ | 国产69久久精品成人看 | 97干com| 精品极品在线 | av在线激情 | 六月色丁 | 日韩狠狠操 | 一区二区三区免费在线观看视频 | 亚洲一二三在线 | 日本不卡一区二区三区在线观看 | 96久久| 久久免费视频8 | 国产一区二区三区黄 | av在线播放观看 | 国产精品久久一区二区三区不卡 | 久久久午夜视频 | 99产精品成人啪免费网站 | 国产一区二区三区免费在线观看 | 精品国产免费一区二区三区五区 | 一区二区三区国产欧美 | 91麻豆产精品久久久久久 | 国产视频高清 | 欧美日韩国产精品一区二区亚洲 | 国产视频1| 欧美激情h | 天天操天天干天天玩 | 在线 国产一区 | 久久精品久久99精品久久 | 欧美性做爰猛烈叫床潮 | 久久在线免费观看视频 | 国产中文字幕大全 | 国产成人久久av977小说 | 92精品国产成人观看免费 | 视频一区二区在线观看 | 99精品美女| 婷婷六月综合亚洲 | 亚洲伦理精品 | 国产999| 韩日av一区二区 | 黄色午夜网站 | 在线观看的黄色 | 亚洲国产影院 | 色噜噜狠狠色综合中国 | 在线观看日韩国产 | 国产精品久久久久一区二区三区 | 在线免费观看国产精品 | 国产综合视频在线观看 | 九九九视频精品 | 在线免费试看 | 四虎www.| 午夜精品一区二区三区免费 | 97人人添人澡人人爽超碰动图 | 国产亚洲精品美女 | 麻豆视频在线看 | 国产精品区免费视频 | 丁香国产视频 | zzijzzij亚洲日本少妇熟睡 | 久久只精品99品免费久23小说 | 男女拍拍免费视频 | 欧美片一区二区三区 | 久久精品视频99 | 欧美日韩国产一区二区三区在线观看 | a在线视频v视频 | 成年性视频 | 久久免费99 | 中文字幕视频播放 | 欧洲激情综合 | 国产青春久久久国产毛片 | 中文字幕免费一区二区 | 精品国产一区二区三区久久久蜜月 | 香蕉视频免费看 | 天天超碰 | 97精品一区二区三区 | 开心激情网五月天 | 亚洲日本在线一区 | 六月久久婷婷 | 99在线精品视频观看 | av免费看看 | 国产黄大片 | 免费视频二区 | 午夜av影院 | av不卡免费看 | 亚洲精品激情 | 日韩欧美电影 | 国产男女爽爽爽免费视频 | 日韩在线激情 | 丁香综合av | www免费在线观看 | 亚洲a在线观看 | 亚洲一级电影 | 国产护士av | 国产精品久久久久久久毛片 | 91在线网址 | 中文字幕在线资源 | 国产在线综合视频 | 亚州日韩中文字幕 | 91九色丨porny丨丰满6 | 97精品国产91久久久久久久 | av成人免费在线 | 99日精品| 国产精品theporn | 日韩在线精品一区 | 亚洲一级免费电影 | 国产麻豆剧果冻传媒视频播放量 | 欧美一级黄色视屏 | 亚洲成人av电影 | 九九热在线精品 | 91精品国自产在线观看欧美 | 亚洲最大免费成人网 | 男女视频91 | 天天干天天天天 | 曰韩精品 | 91精品国产成人www | 三级av在线免费观看 | 亚洲国产精品成人av | 激情五月婷婷网 | 亚洲理论影院 | 91成人看片 | av色综合网 | 亚洲日本在线一区 | 久久视频这里只有精品 | 天天干夜夜想 | 国产精品久久 | 亚洲视频免费在线 | www日韩| 亚洲黄色激情小说 | 91麻豆精品国产91久久久更新时间 | 国产精品短视频 | 在线观看视频一区二区三区 | 黄色小说视频在线 | 亚洲三级毛片 | 成人亚洲免费 | .国产精品成人自产拍在线观看6 | 91在线视频在线观看 | 国产精品综合av一区二区国产馆 | 精品视频在线免费 | 成人免费观看完整版电影 | 一区二区三区日韩在线 | 欧美精品乱码99久久影院 | 四虎影视成人永久免费观看亚洲欧美 | 国产自产在线视频 | 国产精品乱看 | 天堂av观看 | 国产精品v a免费视频 | 青青久视频 | 天天操天天艹 | 成人免费观看a | 又黄又刺激的视频 | 成人一区二区在线 | 国产精品美女久久久久久久 | 综合色影院| 午夜av电影 | 中文字幕a∨在线乱码免费看 | 亚洲在线视频网站 | 免费在线a | 亚洲va在线va天堂va偷拍 | 日本中文不卡 | 日韩久久久久久久久久久久 | 久草精品在线播放 | 在线黄色国产电影 | 在线观看91av | 99热免费在线 | 久久蜜臀一区二区三区av | 99视频在线观看视频 | 国产视频二| 婷婷激情网站 | 久久99九九99精品 | 日b视频在线观看网址 | 午夜在线日韩 | 2022国产精品视频 | 一区二区三区韩国免费中文网站 | 欧美一级免费黄色片 | 色综合久久66 | 免费av观看 | 婷婷视频在线播放 | 免费在线观看国产精品 | 国内精品久久久久影院日本资源 | 97自拍超碰 | 美女黄频视频大全 | 在线观看黄色av | 免费网址你懂的 | 伊人婷婷久久 | 欧美综合在线视频 | 日日夜夜噜 | av免费观看网址 | 国产精品久久久一区二区三区网站 | 久久久久久久久久久黄色 | 色婷婷婷| 天天操天天射天天爱 | 激情综合五月 | 国产精品自产拍 | 久久一线 | 黄色国产成人 | 久久精品—区二区三区 | 久草网站在线观看 | 亚洲日韩中文字幕在线播放 | 免费韩国av| 9色在线视频 | 国产 字幕 制服 中文 在线 | 97成人精品区在线播放 | 少妇视频在线播放 | 丝袜精品视频 | 国产小视频在线免费观看视频 | 久久精品亚洲 | 日韩在线观看你懂的 | 成人免费在线观看入口 | 国产视频精品免费播放 | 亚洲婷婷在线 | 久久黄色a级片 | 91高清免费观看 | 日韩欧美一区二区在线播放 | 国产亚洲激情视频在线 | 国产精品麻豆欧美日韩ww | 婷婷色综合网 | 日韩高清无线码2023 | 欧美激情视频一区二区三区免费 | 国产精品 999| 日韩免费高清 | 国产精品久久伊人 | 国产视频在线观看一区 | 黄色成人毛片 | 不卡的av在线播放 | 夜夜夜影院 | 免费在线91 | 国产成人精品久久 | 国精产品999国精产品岳 | 日韩电影在线观看一区二区 | 国产 一区二区三区 在线 | 亚洲视频免费在线观看 | 国产精品高清av | 日韩女同一区二区三区在线观看 | 日韩免费电影一区二区三区 | 日本精品视频一区 | 人人插人人草 | av天天草 | av解说在线 | 欧美久久久久久久久中文字幕 | 国产精品1区2区 | 国产人成一区二区三区影院 | 久久亚洲私人国产精品va | 亚洲一区二区三区精品在线观看 | 免费a网站 | 91观看视频 | 国产精品一区二区在线免费观看 | 国产精品久久电影观看 | 国产第一页在线观看 | 国产日韩欧美在线 | 午夜视频在线观看一区二区三区 | 五月天天色 | a特级毛片| 香蕉视频一级 | 深爱激情五月网 | 91片网| 久久久久国产一区二区 | 欧美久久久久 | 天天插天天射 | 91超碰免费在线 | 久久精品99国产精品亚洲最刺激 | 中文字幕永久在线 | 中日韩免费视频 | 国产喷水在线 | 国产精品二区在线观看 | 国产va在线观看免费 | bayu135国产精品视频 | 在线 日韩 av | 久久精品视频在线免费观看 | 4p变态网欧美系列 | 国产 中文 日韩 欧美 | 亚洲电影院 | 91久久偷偷做嫩草影院 | 国产一区二区三区四区在线 | 在线观看日本高清mv视频 | 久久久久国产精品视频 | 久草精品视频 | 国产精品国产三级国产aⅴ无密码 | 日韩免费在线网站 | 高清国产午夜精品久久久久久 | 免费欧美精品 | 日韩精品在线视频免费观看 | 国产中文在线播放 | 色噜噜日韩精品欧美一区二区 | 久久久国产一区二区三区四区小说 | 欧美韩日精品 | 国产一级精品在线观看 | 亚洲无吗视频在线 | 日韩欧美专区 | 国产成人综合图片 | 久久精品国产久精国产 | 99精品免费在线观看 | 国产拍揄自揄精品视频麻豆 | 国产精品国内免费一区二区三区 | 国产精品免费视频久久久 | 五月情婷婷 | www.国产高清 | 91九色在线观看 | 六月婷婷久香在线视频 | 色香网 | 超碰在线1| 黄色一级在线观看 | 国产成人在线精品 | 日韩精品无码一区二区三区 | 精品视频9999| 麻豆视频国产 | 在线观看一| 日日夜夜噜 | 国产精品美女久久久久aⅴ 干干夜夜 | 国产成人精品女人久久久 | 四虎www com | 波多野结衣视频一区二区三区 | 中文字幕成人网 | 国产在线视频资源 | 999一区二区三区 | 在线观看国产区 | 激情av一区二区 | 五月婷网 | 亚洲高清在线 | 中文字幕精品久久 | 国产在线91在线电影 | 国产一区不卡在线 | 免费国产在线精品 | 国产精品久久久久久久7电影 | 久久黄色免费 | 国产午夜精品一区 | 在线免费观看的av | 亚洲人成人在线 | 久久免费久久 | 成人亚洲精品国产www | 久久夜夜操 | 国产精品欧美久久久久三级 | 久久久久久蜜桃一区二区 | 久久综合久久88 | 成人四虎影院 | 国产精品一区二区三区四 | 91 在线视频 | 欧美日韩国产一区二区在线观看 | 国产字幕在线看 | 亚洲丝袜一区 | 成人在线观看网址 | wwxxxx日本 | 色.www | 色婷婷精品大在线视频 | 成人在线你懂得 | 欧美精品在线观看免费 | 精品中文字幕在线播放 | 97视频在线 | 91精品视频在线观看免费 | 国产成人在线免费观看 | 日本精品中文字幕在线观看 | 国产涩涩在线观看 | 中文字幕黄网 | 午夜91视频 | 日本高清久久久 | 激情 一区二区 | 奇米影音四色 | 欧美日韩99 | 国产成人精品一二三区 | 91视频免费国产 | 欧美一级免费高清 | 亚洲少妇天堂 | 欧美日韩xx| 午夜三级大片 | 国模视频一区二区三区 | www.夜夜操| 狠狠干狠狠色 | 91在线中字| 免费视频久久久久久久 | 日韩精品欧美专区 | 亚洲视频国产 | 婷婷四房综合激情五月 | 久青草视频 | 久久亚洲在线 | 国产成人91 | 国产高清精品在线 | 看国产黄色大片 | 国产精品视频全国免费观看 | 蜜臀久久99精品久久久无需会员 | 91黄色视屏| 国产九九九九九 | 亚洲精品国产精品国自产观看 | 永久免费在线 | 色视频在线免费 | 欧美 亚洲 另类 激情 另类 | 久久理论视频 | 色婷婷激情四射 | 人人澡视频| 日韩在线第一 | 亚洲国产成人精品在线观看 | japanese黑人亚洲人4k | 五月综合婷 | 中文字幕在线播放视频 | 亚洲一区网站 | 天天曰天天射 | 成人精品久久久 | 国产在线精品二区 | 蜜臀av性久久久久蜜臀aⅴ流畅 | 国产一区二区三区免费视频 | 欧美另类一二三四区 | 少妇搡bbbb搡bbb搡69 | 国语久久| 黄色大片av | 波多野结衣视频一区 | 日日碰狠狠添天天爽超碰97久久 | 亚洲久草在线视频 | 久久久成人精品 | 日韩精品一区二区在线观看视频 | 国产欧美最新羞羞视频在线观看 | 激情自拍av| 国产手机精品视频 | 免费亚洲黄色 | 免费成人在线网站 | 最新av在线免费观看 | 在线精品视频免费播放 | 91色九色 | 日韩特级毛片 | 国模精品在线 | 日韩高清一| 国产精品国内免费一区二区三区 | av黄色在线观看 | 亚洲精品一区二区精华 | 色99视频| 久久99亚洲精品久久久久 | 亚洲国产精品人久久电影 | 亚洲1区 在线 | 五月婷婷视频在线 | 久久久综合电影 | 丁香五月亚洲综合在线 | 成人在线网站观看 | 色综合天天狠狠 | 黄色aaa级片 | 亚洲国产精品一区二区尤物区 | 亚洲欧美国产视频 | 亚洲精品在线观看视频 | 日韩视频一区二区三区在线播放免费观看 | 久久国色夜色精品国产 | 久久在线视频精品 | 日韩在线视频网 | 亚洲午夜av| 黄网站免费看 | 久久久精品 | 国产97视频| 免费看91的网站 | 国产尤物在线观看 | 精品久久一区 | 免费在线观看不卡av | 国产在线观看xxx | 婷婷丁香激情五月 | 国产中文字幕亚洲 | 黄网站色成年免费观看 | 一区三区视频在线观看 | 国产999精品久久久久久 | 午夜精品久久久久久久99无限制 | 精品一区二区三区香蕉蜜桃 | 亚洲综合色网站 | 日韩四虎| 中文字幕在线观看一区二区三区 | 日韩高清在线一区 | 亚洲精品资源在线 | 四虎成人免费观看 | www.伊人网 | 亚洲伊人av | 亚洲国产中文字幕在线观看 | 成年人在线观看免费视频 | 欧美激情视频一区二区三区 | 亚洲专区视频在线观看 | 日本福利视频在线 | 开心激情综合网 | 在线亚洲小视频 | 日本精品视频在线观看 | 综合色天天| 精品国内自产拍在线观看视频 | 亚洲精品动漫久久久久 | 最近中文字幕高清字幕在线视频 | 91九色视频 | 国产精品久久久久久久久久久久久久 | 久久综合狠狠综合久久狠狠色综合 | 国产一级不卡毛片 | 国产涩图 | 五月天开心 | 99视频精品免费视频 | 黄色亚洲精品 | 国产一区视频在线 | 国产午夜精品一区二区三区欧美 | 欧美激情第28页 | 国产中文伊人 | 美女搞黄国产视频网站 | 毛片无卡免费无播放器 | 99久久久久成人国产免费 | 伊人干综合 | 中文字幕免费高 | 伊人视频 | 特黄色大片 | 日韩精品久久久免费观看夜色 | 国产一线二线三线在线观看 | 成人羞羞免费 | 久久不射电影院 | 日日夜夜添 | 国产毛片在线 | 五月婷婷在线观看视频 | 久草在线免费色站 | 福利视频一区二区 | 欧美日韩aaaa| 激情在线网站 | 区一区二在线 | 在线午夜| 深夜免费福利在线 | 在线观看一 | 亚洲国产精品99久久久久久久久 | 超碰97网站 | 在线国产一区二区 | 永久免费精品视频网站 | 国产精品久久久久久影院 | 欧美analxxxx | 99在线视频精品 | 国产自在线 | 国产资源网 | 成人一级免费电影 | 精品一区二区久久久久久久网站 | 在线观看视频日韩 | 亚洲,播放| 99精品在线免费 | 日韩免费一区二区三区 | 天天射天天干天天爽 | 国产欧美日韩精品一区二区免费 | 国产毛片在线 | 中文字幕888 | 欧美少妇bbwhd | 久久久 激情 | 久久综合色天天久久综合图片 | 黄污视频网站大全 | 免费国产黄线在线观看视频 | 中文字幕资源网在线观看 | 黄色大片网| 人成在线免费视频 | 青青草视频精品 | 天天干天天想 | 91成人在线视频观看 | 国产午夜精品一区二区三区四区 | 免费观看久久久 | 六月丁香婷婷网 | 午夜国产一区二区三区四区 | 超碰在线公开 | 亚洲国产视频网站 | 天天射天天射天天 | 精品1区2区3区 | 一区二区三区免费 | 夜夜爽天天爽 | 精品在线亚洲视频 | 国产美女精品视频 | 999久久久久久久久 69av视频在线观看 | 蜜桃视频在线视频 | 欧美一区二视频在线免费观看 | 激情大尺度视频 | 一级黄色在线免费观看 | 中文字幕免费观看视频 | 一区二区三区在线免费观看 | 亚洲国产视频网站 | 国产精品精品久久久 | www.五月天| 国产不卡在线观看视频 | 日p视频| 久久精品这里精品 | 免费亚洲精品视频 | 免费av大片| 成人黄色国产 | 久久精品综合一区 | 国产黄视频在线观看 | 色狠狠婷婷 | 欧美激情视频免费看 | 久久久久99精品成人片三人毛片 | 丝袜+亚洲+另类+欧美+变态 | 中文字幕av在线 | 欧美高清成人 | 国产成人精品久久久久蜜臀 | 六月丁香综合 | 亚洲影院一区 | 国产原创在线 | 亚洲最快最全在线视频 | 91精品久久久久久久久 | 欧美最爽乱淫视频播放 | 亚洲精品美女免费 | 日韩精品在线看 | 国产精品理论在线观看 | av在线影视 | 久久久九九| 一级电影免费在线观看 | 日b黄色片| 久草.com| 97色婷婷成人综合在线观看 | 精品国精品自拍自在线 | 久久久久久免费 | 国产精品999久久久 久产久精国产品 | 日韩天堂在线观看 | 91亚洲精品在线观看 | 97超碰中文字幕 | 久久99精品国产 | 日韩一二三在线 | 日日干天天爽 | 天堂va在线观看 | 亚洲成人黄色在线观看 | 97视频在线观看免费 | 日韩精品一区二区三区免费观看 | 中文字幕久久久精品 | www日韩欧美 | 99人成在线观看视频 | 国产精品一区二 | 久久中文字幕在线视频 | 久久人操| 在线视频日韩欧美 | 黄色三级免费观看 | 日本动漫做毛片一区二区 | 久久精品1区 | 国产精品免费一区二区三区 |