【约束布局】ConstraintLayout 引导线 Guideline 约束 ( 简介 | 可视化操作 | 属性 | 水平引导线 | 垂直引导线 | 开始结束尺寸 | 百分比位置 | 约束组件 )



I . Guideline 引导线 总结


1 . Guideline 引导线 属性 :


① 方向属性 : android:orientation=“horizontal” ; 取值 horizontal / vertical ;

② 开始尺寸定义 : app:layout_constraintGuide_begin=“22dp” ; 取值 dp 尺寸值 ; 距离 顶部 ( 水平 ) , 左侧 ( 垂直 ) 位置 ;

③ 结束尺寸定义 : app:layout_constraintGuide_end=“20dp” ; 取值 dp 尺寸值 ; 距离 底部 ( 水平 ) , 右侧 ( 垂直 ) 位置 ;

④ 百分比位置定义 : app:layout_constraintGuide_percent=“0.5” ; 取值 0 ~ 1.0 之间的小数 ;


2 . Guideline 引导线 约束 : 水平引导线 约束 垂直方向 , 垂直引导线约束水平方向 ;



II . Guideline 引导线 简介


Guideline 引导线 简介 :


① 引导线 种类 : Guideline 引导线 有 , 垂直 引导线 , 水平 引导线 两种 ;

② 引导线作用 : 这些引导线用于 约束视图组件 ;

③ 不可见 : Guideline 引导线是不可见的 , 用户在界面中看不到引导线 ;

④ 引导线定位方式 : 使用 dp 单位的尺寸值表示相对开始或结束的位置 , 或百分比值 , 基于布局的边缘 , 设定引导线的位置 ;



III . Guideline 引导线 可视化操作


Guideline 引导线 可视化工具添加 : 在 布局 设计 ( Design ) 视图中 , 点击 Guidelines 按钮 , 会弹出下面的下拉菜单 ;


① 添加垂直引导线 : Add Vertical Guideline” 选项用于 添加垂直引导线 ;

② 添加水平引导线 : Add Horizontal Guideline” 选项 用于添加水平引导线 ;

在这里插入图片描述


③ 自动生成代码 : 分别点击上述两个选项 , 添加水平和垂直引导线 , 会自动生成如下代码 :


<androidx.constraintlayout.widget.Guideline
    android:id="@+id/guideline2"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:orientation="vertical"
    app:layout_constraintGuide_begin="20dp" />
    
<androidx.constraintlayout.widget.Guideline
    android:id="@+id/guideline3"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:orientation="horizontal"
    app:layout_constraintGuide_begin="20dp" />

android:orientation=“vertical” : 表示该引导线是垂直的引导线 ;

android:orientation=“horizontal” : 表示该引导线是水平引导线 ;

app:layout_constraintGuide_begin=“20dp” : 表示该引导线距离开始位置 20dp , 如果是垂直引导线 , 该引导线距离顶部 20dp , 如果是水平引导线 , 该引导线距离容器左边缘 20dp ;


④ 自动生成效果如下 :

在这里插入图片描述



IV . Guideline 引导线 属性


1 . Guideline 引导线 属性 简介 : Guideline 引导线在 Constraintlayout 约束布局中 , 需要为其设置两个属性 , 分别是 使用 “android:orientation” 属性设置引导线方向 , 使用 “app:layout_constraintGuide_begin” , “app:layout_constraintGuide_end” 或 “layout_constraintGuide_percent” 设置引导线在对应的方向 ( 水平 / 垂直 ) 上 , 相对于边缘 ( 左边缘 / 上边缘 ) 的位置 ;


2 . 设置 Guideline 方向 :


① 水平方向 : 引导线是 从左到右 水平方向的 ;

android:orientation="horizontal"

② 垂直方向 : 引导线是 从上到下 垂直方向的 ;

android:orientation="vertical"

3 . 按照百分比设置 Guideline 位置 :


① 水平方向 : 设置的是 引导线 距离 顶部边缘 的距离 , 占父容器高度的百分比 ;

② 水平方向 : 设置的是 引导线 距离 左边边缘 的距离 , 占父容器宽度的百分比 ;

app:layout_constraintGuide_percent="0.5"

4 . 按照 尺寸 设置 Guideline 位置 ( 相对于开始位置 ) :


① 水平引导线 : 设置的是 引导线 距离 顶部边缘 的距离 ;

② 垂直引导线 : 设置的是 引导线 距离 左侧边缘 的距离 ;

app:layout_constraintGuide_begin="20dp"

5 . 按照 尺寸 设置 Guideline 位置 ( 相对于结束位置 ) :


① 水平引导线 : 设置的是 引导线 距离 底部边缘 的距离 ;

② 垂直引导线 : 设置的是 引导线 距离 右侧边缘 的距离 ;

app:layout_constraintGuide_end="20dp"


V . Guideline 引导线 位置定义 方式切换


1 . 引导线位置定义方式切换 : 如下引导线 , 使用的是 尺寸 定义的 引导线位置 ; 点击一次后 , 切换成 结束尺寸位置 ; 再点击一次 , 切换成 百分比位置 ; 第三次点击还原成最初的样式 :

<!-- 垂直引导线 , 距离左侧边缘 20dp -->
<androidx.constraintlayout.widget.Guideline
    android:id="@+id/guideline1"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:orientation="vertical"
    app:layout_constraintGuide_begin="20dp" />

2 . 引导线三种定位方式 : 点击 Design 视图中 , 引导线上方的按钮 , 即可 切换 引导线位置定义方式 ;


① 开始 尺寸位置 : 这是原始位置 , 点击一次后 , 切换成 结束尺寸位置 ;

<androidx.constraintlayout.widget.Guideline
    android:id="@+id/guideline1"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:orientation="vertical"
    app:layout_constraintGuide_begin="22dp" />

在这里插入图片描述


② 结束 尺寸位置 :


<androidx.constraintlayout.widget.Guideline
    android:id="@+id/guideline1"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:orientation="vertical"
    app:layout_constraintGuide_end="389dp" />

在这里插入图片描述


③ 百分比位置 :


<androidx.constraintlayout.widget.Guideline
    android:id="@+id/guideline1"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:orientation="vertical"
    app:layout_constraintGuide_percent="0.05352798" />

在这里插入图片描述



VI . Guideline 引导线 约束 其它组件


1 . Guideline 引导线 约束 简介 : 在 Constraintlayout 约束布局中使用 Guideline 引导线 约束其它组件 , 很简单 , 只要被约束的组件 ( 非 引导线 的其它组件 ) , 的左右约束 , 如 “app:layout_constraintLeft_toLeftOf” 直接约束与引导线即可 ;


① 垂直引导线 : 垂直引导线 用于组件 水平方向 的约束 , 主要约束 组件 的 Left 和 Right ;

② 水平引导线 : 水平引导线 用于组件 垂直方向 的约束 , 主要约束 组件 的 Top 和 Bottom ;


2 . 代码示例 : 如下代码是将组件的放在两条引导线的交点上 , 组件的左上角位置就是引导线交点 ;


① 水平约束 : 下面代码中的 guideline5 是 垂直方向的引导线 , 用于 被约束组件的 水平方向的约束 ;

② 垂直约束 : 下面代码中的 guideline6 是 水平方向的引导线 , 用于 被约束组件的 垂直方向的约束 ;

<!-- 被约束组件 -->
<TextView
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="Hello World!"
        app:layout_constraintLeft_toLeftOf="@+id/guideline5"
        app:layout_constraintRight_toRightOf="parent"
        app:layout_constraintHorizontal_bias="0"
        app:layout_constraintTop_toTopOf="@+id/guideline6"
        app:layout_constraintBottom_toBottomOf="parent"
        app:layout_constraintVertical_bias="0"/>

<!-- 垂直引导线 -->
<androidx.constraintlayout.widget.Guideline
    android:id="@+id/guideline5"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:orientation="vertical"
    app:layout_constraintGuide_percent="0.5" />
   
<!-- 水平引导线 --> 
<androidx.constraintlayout.widget.Guideline
    android:id="@+id/guideline6"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:orientation="horizontal"
    app:layout_constraintGuide_percent="0.5" />

3 . 约束图示 : 上述代码中的 两条引导线 , 被约束组件如下图所示 ;
在这里插入图片描述



VII . Guideline 代码示例


1 . 代码示例 : 在布局中定义了 6 6 6 条引导线 , 分别是 水平引导线 和 垂直引导线 与 3 3 3 种对应的引导线设置方式 ;


<?xml version="1.0" encoding="utf-8"?>
<androidx.constraintlayout.widget.ConstraintLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    tools:context=".MainActivity">

    <!-- 被约束组件 -->
    <TextView
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="Hello World!"
        app:layout_constraintLeft_toLeftOf="@+id/guideline5"
        app:layout_constraintRight_toRightOf="parent"
        app:layout_constraintHorizontal_bias="0"
        app:layout_constraintTop_toTopOf="@+id/guideline6"
        app:layout_constraintBottom_toBottomOf="parent"
        app:layout_constraintVertical_bias="0"/>

    <!-- 垂直引导线 , 距离左侧边缘 20dp -->
    <androidx.constraintlayout.widget.Guideline
        android:id="@+id/guideline1"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:orientation="vertical"
        app:layout_constraintGuide_begin="20dp" />

    <!-- 水平引导线 , 距离顶部边缘 20dp -->
    <androidx.constraintlayout.widget.Guideline
        android:id="@+id/guideline2"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:orientation="horizontal"
        app:layout_constraintGuide_begin="20dp" />

    <!-- 垂直引导线 , 距离底部边缘 20dp -->
    <androidx.constraintlayout.widget.Guideline
        android:id="@+id/guideline3"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:orientation="vertical"
        app:layout_constraintGuide_end="20dp" />

    <!-- 水平引导线 , 距离右侧边缘 20dp -->
    <androidx.constraintlayout.widget.Guideline
        android:id="@+id/guideline4"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:orientation="horizontal"
        app:layout_constraintGuide_end="20dp" />

    <!-- 垂直引导线 , 距离左侧边缘 0.5 百分比 -->
    <androidx.constraintlayout.widget.Guideline
        android:id="@+id/guideline5"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:orientation="vertical"
        app:layout_constraintGuide_percent="0.5" />

    <!-- 水平引导线 , 距离顶部边缘 0.5 百分比 -->
    <androidx.constraintlayout.widget.Guideline
        android:id="@+id/guideline6"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:orientation="horizontal"
        app:layout_constraintGuide_percent="0.5" />

</androidx.constraintlayout.widget.ConstraintLayout>

2 . 展示效果 :


在这里插入图片描述

  • 7
    点赞
  • 28
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
### 回答1: 引导线科技框是一种通过使用JavaScript(JS)进行实现的技术框,其主要功能是引导用户在页面上进行交互操作。 实现引导线科技框的首要步骤是通过JS获取页面元素,例如按钮、文本框等,这些元素将成为用户进行交互操作的目标。接下来,我们可以使用JS编写代码,通过对这些元素添加事件监听器,来捕捉用户的交互行为。 当用户与特定元素进行交互时,引导线科技框可以在用户操作的目标元素周围显示引导线,以引导用户进行下一步操作。这可以通过JS在页面上添加一个透明的div元素实现。 在该透明div元素中,我们可以通过JS设置其样式属性,例如设置边框样式、宽度和颜色等,来模拟出引导线的效果。通过计算目标元素的位置坐标,我们可以确定引导线的起点位置,并设置其长度和角度,使得引导线能够连接用户当前操作的元素。 在用户完成当前操作后,引导线科技框可以通过JS监听用户的状态改变,并根据需求进行相应的操作。例如,可以通过JS隐藏或移除引导线,以便用户能够进一步操作页面上的其他元素。 总之,JS的强大功能使得实现引导线科技框成为可能。通过获取页面元素、添加事件监听器和设置样式属性操作,我们可以实现一个功能强大的引导线科技框,为用户提供更好的交互体验。 ### 回答2: 引导线科技框可以通过JavaScript来实现。引导线科技框是一种在网页中引导用户进行操作的工具,通常用于演示新功能、指南用户使用界面或提供说明。以下是一个简单的实现方式: 1. 使用HTML创建一个包含引导线科技框的容器: ```html <div id="guide-container"> <div class="guide-box"></div> <div class="guide-line"></div> </div> ``` 2. 使用CSS样式对容器和引导线进行布局和样式设置: ```css #guide-container { position: relative; } .guide-box { position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%); width: 300px; height: 200px; background-color: #f1f1f1; } .guide-line { position: absolute; top: 0; left: 50%; width: 2px; height: 100%; background-color: #000; } ``` 3. 使用JavaScript控制引导线科技框的显示和隐藏: ```javascript // 获取容器和引导线的元素 const guideContainer = document.getElementById('guide-container'); const guideLine = document.querySelector('.guide-line'); // 显示引导线和科技框 function showGuide() { guideContainer.style.display = 'block'; } // 隐藏引导线和科技框 function hideGuide() { guideContainer.style.display = 'none'; } // 调用showGuide函数显示引导线和科技框 showGuide(); // 调用hideGuide函数隐藏引导线和科技框 hideGuide(); ``` 通过上述步骤,就可以使用JavaScript实现引导线科技框。你可以根据需求自定义样式、位置和触发条件,以更好地满足实际应用场景的需求。 ### 回答3: 引导线是一种常用于科技界的界面元素,它可以用来引导用户完成特定的操作或者提供说明和提示。在 JavaScript 中,我们可以通过以下步骤来实现引导线科技框: 1. 首先,我们需要确定引导线位置和样式。可以使用 CSS 来设置引导线的样式,如颜色、宽度、高度、边框等。 2. 在 HTML 文档中,我们可以添加一个容器元素,用于包裹需要引导的元素和引导线。可以使用 `<div>` 元素作为容器,并为其设置一个唯一的 id。 3. 使用 JavaScript,我们可以获取需要引导的元素和容器元素。可以使用 `document.getElementById()` 方法根据元素的 id 获取元素对象。 4. 接下来,我们需要创建一个引导线元素。可以使用 `document.createElement()` 方法创建一个新的元素节点,并使用 `setAttribute()` 方法设置引导线元素的属性,如 class、id、样式等。 5. 将引导线元素添加到容器元素中,可以使用 `appendChild()` 方法将引导线元素添加到容器元素的子节点列表中。 6. 最后,使用 JavaScript 的事件监听器,可以在特定的操作或触发事件时显示引导线。可以使用 `addEventListener()` 方法添加事件监听器,并在事件处理函数中设置引导线的显示和隐藏。 通过以上步骤,我们可以实现一个简单的引导线科技框。通过设置不同的样式和触发条件,可以实现更加丰富和复杂的引导线效果,从而提升用户体验和操作指导。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值