首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    Android 约束布局ConstraintLayout1.1.0 版详解

    /这篇文章中,我们对 ConstraintLayout 1.0.2 版进行了详细的了解。...Margins and chains 在 1.1.0-beta4 版本中(已知),为链中的控件设置 marginRight/End 是无效的(个人感觉这应该是个 Bug)。...可设置的值有: none:不应用优化。 standard:仅优化直接约束和屏障约束(默认的)。 direct:优化直接约束。 barrier:优化屏障约束。 chain:优化链约束(实验)。...在设置值时,可以设置多个,如: app:layout_optimizationLevel="direct|barrier|dimensions" Barrier 当我们在布局时,有时候就会遇到布局会随着数据的多少而改变大小的情况...这是个非常好用的东东,和 GuideLine 一样,它是一个虚拟的 View,对界面是不可见的。目的就是辅助布局。

    1.1K40

    ConstraintLayout(约束布局)的使用

    概述 ConstraintLayout(约束布局)的出现是为了在Android应用布局中保持扁平的层次结构,减少布局的嵌套,为应用创建响应快速而灵敏的界面。...Bias 在ConstraintLayout中没有直接的属性让一个控件水平居中,或者竖直居中,可以使用如下方式: ?...) 如果一个View的尺寸被设置为wrap_content,那么当View的内容太多时,可能会超出约束规定的范围,约束布局提供了两个属性来限制View的尺寸: layout_constrainedWidth...设置Guidline的方向: android:orientation="horizontal":高度0dp,宽度与父容器等宽 android:orientation="vertical":宽度0dp,高度与父容器等高...tools:parentTag:设为ConstraintLayout,使得编辑器将当前merge标签当做约束布局来预览。 content:是要填入这个占位符的View的id。 引用模板: ?

    2.3K30

    【约束布局】ConstraintSet 约束集 ( 简介 | 约束属性集合 | 约束集初始化 | 约束集应用到布局中 | 关键帧动画 | TransitionManager 使用 )

    约束属性的集合 , 其表示 约束布局 ( ConstraintLayout ) 中 所有的组件 的 约束条件 , 尺寸 , 边距 , 等 约束属性 ; ② 约束集 ConstraintSet 封装内容...: 约束集中封装了 每个组件 的所有 约束布局 属性 ; ③ 约束集应用效果 : 约束布局 ( ConstraintLayout ) 应用 约束集 ( ConstraintSet ) 时 , 约束布局中的所有组件都会按照约束集中的约束属性进行重新布局绘制...获取约束集 : 从 约束布局 ( ConstraintLayout ) 中 , 可以获取 约束集 ( ConstraintSet ) , 约束集可以从当前现有组件中获取 , 也可以从布局文件中获取 ,...下面代码是从布局文件中获取的 ; //1 ....约束集中的约束属性 : R.layout.constraintlayout 布局就是如下代码 , 从下面的布局中获取 约束集 ConstraintSet , 该约束集中封装了 button1 , button2

    3.2K10

    Android 中的LayoutInflater(布局服务)

    本节引言: 本节继续带来的是Android系统服务中的LayoutInflater(布局服务),说到布局,大家第一时间 可能想起的是写完一个布局的xml,然后调用Activity的setContentView...()加载布局,然后把他显示 到屏幕上是吧~其实这个底层走的还是这个LayoutInflater,用的Android内置的Pull解析器来解析 布局。...一般在Android动态加载布局或者添加控件用得较多,本节我们就来学习下他在实际开发中 的一些用法~ 1.LayoutInflater的相关介绍 1)Layout是什么鬼?...又或者设置margin等等,这个由你决定~ 2.纯Java代码加载布局 我们早已习惯了使用XML生成我们需要的布局,但是在一些特定的情况下,我们 需要使用Java代码往我们的布局中动态的添加组件或者布局...中的LayoutInflater(布局服务),以及动态加载View和控件 相关的东西,相信对初学控件的朋友带来帮助~好的,就说这么多,谢谢

    83510

    Android开发笔记(一百四十九)约束布局ConstraintLayout

    约束布局ConstraintLayout是Android Studio 2.2推出的新布局,并从Android Studio 2.3开始成为默认布局文件的根布局,...由此可见Android官方对其寄予厚望,那么约束布局究竟具备哪些激动人心的特性呢?...开发者使用约束布局之时,有多种手段往该布局内添加和拖动控件,既能像原型设计软件AxureRP那样在画板上任意拖曳控件,也能像传统布局那样在XML文件中调整控件布局,还能在代码中动态修改控件对象的位置状态...在XML文件中调整控件布局 传统布局如线性布局、相对布局基本是在XML文件中手工添加控件节点,约束布局当然也允许在布局文件中指定控件的相对位置,这跟相对布局内部的控件位置调整类似,只不过用来表示位置的属性换了个名字罢了...在代码中添加控件 若要利用代码给约束布局动态添加控件,则可照常调用addView方法,不同之处在于,新控件的布局参数必须使用约束布局的布局参数,即ConstraintLayout.LayoutParams

    2.1K20

    Python|GUI编程中组件的布局

    在tkinter里有三种布局管理,分别是pack、grid、和place,这三种方式各有各的好处,需要注意的是这三种布局管理在同一个父容器里面一定不能混用,在一个父容器里选择一种方式便足够了。...下面依次介绍这三种方式吧: 1.pack pack是三种布局管理中最常用的,ack布局可以指定相对位置,精确的位置会由pack系统自动完成。这也使得pack布局没有另外两种布局方式灵活....所以 pack 是简单应用的首选布局。...行号相同而列号不同的几个控件会被彼此上下排列; 列号相同而行号不同的几个控件会被彼此左右排列. 使用Grid布局的过程就是为各个控件指定行号和列号的过程....图2 grid布局 3.place Place 布局管理可以显式的指定控件的绝对位置或相对于其他控件的位置. 要使用 Place 布局,调用相应控件的 place() 方法就可以了。

    89630

    Android开发中TableLayout表格布局

    Android开发中TableLayout表格布局 一、引言         在移动端应用程序开发中,常常会使用到表格布局,iOS和Android开发框架中都提供了独立的表格视图控件供开发者使用,例如...iOS中的UITableView、UICollectionView,Android中的ListView、GridView等。...除了独立的视图控件外,Android中还提供了一个布局容器类TableLayout,使用其也可以进行方便的表格布局。        ...,其中每个视图元素作为当前行中的一列,结合使用TableLayout与TableRow,就实现了行列的表格布局。...二、关于TableRow         TableRow可以简单理解为TableLayout布局中的一行,当然,TableLayout中也可以直接添加任意的View视图,但是默认添加的View视图将独占一行

    1.6K30

    Android开发中RelativeLayout相对布局

    Android开发中RelativeLayout相对布局         RelativeLayout布局是Android界面布局中应用最广也最强大的一种布局,其不仅十分灵活,可以解决开发中各种界面布局需求...在iOS开发中,Autolayout技术总是被赞不绝口,RelativeLayout布局就是Andriod系统中的Autolayout,其又被称为相对布局。        ...所谓相对布局,是指其坐标的确定并不是开发者写死的,而是有系统自动计算出来的,那么系统如何计算每个视图控件的位置呢?...RelativeLayout布局中视图位置的配置主要使用其内部类LayoutParams,这个内部类LayoutParams是继承自MarginLayoutParams。...void addRule(int verb, int anchor) //移除一个布局规则 public void removeRule(int verb) 用于进行布局规则配置的参数如下: /*=

    1.2K20

    智能设计之NDN:基于约束的布局生成

    该论文也是GNN(图神经网络)在视觉的探索,作者提出基于用户指定约束条件的布局生成方法:神经设计网络(NDN)。NDN由三个模块组成: ? 上图是关键的技术架构。...使用方向图(directional graph)作为表示组件(上图的Design Components)及约束条件(上图Specified Constraints)的特征。...- 模块 bounding box prediction 预测布局,预测表示为矩形的组件(bounding boxes)组成的布局图 - 模块 refinement 微调布局,此步可以加入一些美学规则。...最后,定量和定性实验表明,生成的布局在视觉上与实际设计布局相似。 ? 上图可见:添加约束与无约束的差别 ?...自动布局的效果 另外,补充下作者所使用的数据: - Magazine数据集 4千张设计图,有6类的组件 (texts, images, headlines, over-image texts, over-image

    1.3K30

    Android开发-Listview中显示不同的视图布局

    使用场景 在重写ListView的BaseAdapter时,我们常常在getView()方法中复用convertView,以提高性能。...convertView在Item为单一的同种类型布局时,能够回收并重用,但是多个Item布局类型不同时,convertView的回收和重用会出现问题。...比如有些行为纯文本,有些行则是图文混排,这里纯文本行为一类布局,图文混排的行为第二类布局。单一类型的ListView很简单,下面着重介绍一下ListView包含多种类型视图布局的情形。...2.ListView包含不同Item的布局 我们需要做这些工作:   1)重写 getViewTypeCount() – 该方法返回多少个不同的布局   2)重写 getItemViewType...(int) – 根据position返回相应的Item   3)根据view item的类型,在getView中创建正确的convertView 3.案例 import java.util.ArrayList

    2.3K30

    Android中的通知和自定义通知布局

    Android中的通知(Notification)是Android中的重要一部分,应用程序通过通知来提醒用户或者向用户传达信息,下面让我们来看一下怎么在我们的程序中使用通知和自定义通知的布局。...:text="发送第二种通知"/> 布局中的两个按钮分别用来发送系统布局的通知和我们自定义布局的通知,接下来是我们自定义的通知布局,新建一个布局文件notification.xml..."/> 这个布局中我们采用横向布局,用来模拟一个音乐播放器的横栏,两个按钮分别对应 播放/暂停,下一曲 。...,总体思路是对布局文件中的两个按钮进行事件处理,定义 notifyFirstNotification() 方法和 notifySecondNotification() 方法分别用于创建系统提供布局的通知和自定义布局的通知...言归正传,这个广播干什么用的呢:在自定义通知布局中我们要对两个按钮进行事件处理,在自定义通知布局中,我们必须使用RemoteViews的对象来对布局文件中的两个按钮进行事件处理,而 RemoteViews

    3.6K20

    【Android 屏幕适配】屏幕适配通用解决方案 ⑥ ( 约束布局 ConstraintLayout 百分比布局方案 | 将设计稿尺寸自动转为约束布局百分比标签属性 | 将输出结果设置到组件标签中 )

    文章目录 一、将设计稿尺寸自动转为约束布局百分比标签属性 二、将输出结果设置到组件标签中 参考文档 : 设备兼容性概览 屏幕兼容性概览 支持不同的像素密度 声明受限屏幕支持 约束布局 bias 计算公式参考...【约束布局】ConstraintLayout 偏移 ( Bias ) 计算方式详解 ( 缝隙比例 | 计算公式 | 图解 | 测量图 + 公式 ) 方案 ; 约束布局 百分比 屏幕适配案例参考 【约束布局...】ConstraintLayout 屏幕适配案例 ( 使用代码生成约束布局控件属性 ) 博客 ; 一、将设计稿尺寸自动转为约束布局百分比标签属性 ---- 美工给出的设计稿尺寸 720 \times...: 屏幕 宽高 , 其比例肯定是相对于父控件进行计算 float width = 1280, height = 720; width_inner 和 height_inner 是用于计算组件在约束布局中的位置的...数组存放的是组件 左上角顶点位置 , float[][] width_height_data 数组存放的是宽高位置 ; 有了上述 4 组数据之后 , 就可以自动生成约束布局百分比标签属性 ; 使用如下代码生成

    1.6K10

    C++20中的约束与概念:开启模板编程的新篇章

    C++20作为C++语言的一个重要更新版本,引入了许多新特性,其中“约束”和“概念”是备受瞩目的特性之一。它们为模板编程带来了革命性的变化,让模板代码更加清晰、易读,并且能够在编译期更早地发现错误。...一、什么是约束与概念在C++20中,约束(Constraint)可以关联到类模板、函数模板、类模板成员函数,指定了对模板实参的一些要求。而概念(Concept)则是这些要求的集合。...(三)简化模板编程概念简化了模板元编程的复杂性,使得开发者可以更加专注于算法和逻辑的实现,而不是复杂的类型推导和模板实例化过程。...(三)错误提示在模板实例化时,如果参数不符合概念约束,可以提供更具描述性的错误信息。五、总结C++20的约束与概念特性为模板编程带来了巨大的变革。...它们不仅提高了代码的可读性和可维护性,还增强了代码的健壮性,并简化了模板编程的复杂性。随着C++20的普及和应用,约束与概念将在C++编程中发挥越来越重要的作用。

    8810
    领券