首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

自定义实现垂直滚动的TextView

需求 当TextView限制最大行数的时候,文本内容超过最大行数可自动实现文本内容向上滚动 随着TextView的文本内容的改变,可自动计算换行并实时的向上滚动 文字向上滚动后可向下滚动回到正确的水平位置...自定义方法 自定义一个View,继承自View,定重写里面的onDraw方法 文字的滚动是用Canvas对象的drawText方法去实现的 public void drawText(@NonNull...paint.mBidiFlags, paint.getNativeInstance(), paint.mNativeTypeface); } 通过控制y参数可实现文字不同的垂直距离...*/ private boolean scrolling; /** * 文字滚动方向,支持上下滚动 */ private int scrollDirect...的值是由255/51得来的,要保证文字透明度的变化速度和文字滚动的速度要保持一致 // 否则可能造成透明度已经变化完了,文字还在滚动或者透明度还没变化完成

1.9K20

有意思的水平横向溢出滚动

来看看这么一种情况: 我们有一个垂直方向溢出滚动的容器,以及一个水平方向溢出滚动的容器: 如果使用的是非触控板(大部分用户没有触控板),而是使用鼠标来进行操作,会发现,这两个容器中,只有垂直方向溢出滚动的容器...,是可以响应鼠标滚轮的: 垂直方向溢出滚动的容器,正常响应鼠标滚轮,可滚动内容 水平方向溢出滚动的容器,不会响应鼠标滚轮,不可滚动内容 那么,这里可能就是一个用户痛点。...那是必须的,本文就将介绍一种可能可行的技巧,在特定场景下在水平方向溢出滚动的容器,依然可以用鼠标滚轮进行滚动。 旋转大法 是的,既然只有垂直方向的溢出,才能响应滚轮操作。那我们不妨从这个角度入手。...要想变成水平方向的,我们只需要给容器旋转 90° 不就行了吗?...,就变成了水平的容器,图中鼠标没有在滚动条上容器的运动就是通过滚轮实现的。

2.5K10
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    ST7789 SPI LCD硬件垂直滚动功能的使用

    滚动?发现新大陆! 根据手册中的8.14章节描述,旋转滚动仅仅是垂直滚动的一种模式,由垂直滚动区域定义指令(0x33H)和垂直滚动起始地址指令(0x77)决定。...设置滚动区域 小熊派板载LCD屏幕的大小是240x240,水平和垂直都有240个像素点,但是ST7789驱动IC的显存大小为320x240,垂直有320行像素点,水平有240行像素点,平常我们只是用到了显存的前面一部分...滚动显示首先需要设置滚动区域,显存垂直的320行像素点被划分为三个部分: ?...TFA为顶部固定显示区域,这部分指定后会固定显示,不会滚动显示;VSA为滚动区域,这部分指定后会滚动显示;BFA为底部固定显示区域,这部分指定后会固定显示,不会滚动显示。...因为整个显存垂直有320行像素点,显然一个字节8位是装不下的,所以「TFA、VSA、BFA三个区域的值设置都是16位,并且三个值加起来要等于320,否则滚动区域定义失败」。

    3.4K21

    ST7789 SPI LCD硬件垂直滚动功能的使用

    滚动?发现新大陆! 根据手册中的8.14章节描述,旋转滚动仅仅是垂直滚动的一种模式,由垂直滚动区域定义指令(0x33H)和垂直滚动起始地址指令(0x77)决定。...设置滚动区域 小熊派板载LCD屏幕的大小是240x240,水平和垂直都有240个像素点,但是ST7789驱动IC的显存大小为320x240,垂直有320行像素点,水平有240行像素点,平常我们只是用到了显存的前面一部分...滚动显示首先需要设置滚动区域,显存垂直的320行像素点被划分为三个部分: ?...TFA为顶部固定显示区域,这部分指定后会固定显示,不会滚动显示;VSA为滚动区域,这部分指定后会滚动显示;BFA为底部固定显示区域,这部分指定后会固定显示,不会滚动显示。...因为整个显存垂直有320行像素点,显然一个字节8位是装不下的,所以「TFA、VSA、BFA三个区域的值设置都是16位,并且三个值加起来要等于320,否则滚动区域定义失败」。

    1.9K20

    创建水平滚动的正确方式【CSS 网格布局】

    水平滚动容器(列表)已经成为了一种常见的布局做法,而不是将东西都堆叠在页面上,这将减少占用小屏幕设备垂直的空间。...本文,我们探讨 CSS 网格的弹性布局,它是如何帮助我们实现水平滚动的,同时处理它带来的缺陷。...但是,当采用水平滚动布局时,至少需要满足两点 UX 原则: 你的设计必须在视觉上提醒他人,这是一组可以水平滚动的内容。最好的方法,就是让可滚动的内容露出一部分。 用户知道什么时候滚到末尾,这很重要。...滚动的部分内容,必须在容器边缘露出来。 滚动时,容器的内容必须从屏幕的边缘滑出来。 容器内两个内容之间的距离要小于边缘的距离,这样容器两端都会有更大的空间(这提示用户他们已经滑到最后)。...还记得不,当水平滚动的时候,我们希望可滚动的内容是从屏幕的边缘滑出。 所以,我们在容器中添加 .full 类,并填补缺失的内边距。

    2.6K50

    iOS流水布局UICollectionView简单使用引实现结

    首先看每个方块,也就是每个cell怎么呈现,这里的cell明显是自定义的,我们用一张图片填满cell,同时在底部居中的位置放置一个label。...不同之处在于UICollectionView需要一个布局参数来决定cell是如何布局的,默认是流水布局,也就是我们最常见的形式,也就是上面图里的形式;此外,UICollectionView除了垂直滚动,...还可以设置为水平滚动,只需要改变布局参数的设置就可以了;UICollectionView的cell只能通过注册来确定重用标识符,什么叫注册,我们还是看代码: - (void)viewDidLoad {...*layout = [[UICollectionViewFlowLayout alloc] init]; // 设置滚动方式为水平,默认是垂直滚动 // [layout setScrollDirection...代码中注释了一行,就是用来设置滚动方向为水平的,效果如下: 同样的内容,滚动方式变化后,呈现的效果也会变化。

    1.1K00

    iOS---UICollectionView详解和常用API翻译

    Collection View的构成,我们能看到的有三个部分: Cells Supplementary Views 追加视图 (类似Header或者Footer) Decoration Views 装饰视图...@property (nonatomic) CGSize itemSize; @property (nonatomic) CGSize estimatedItemSize // 滚动方向,默认是水平...// 垂直滚动时section间宽度为该尺寸的高,而水平滚动时为宽度起作用, @property (nonatomic) CGSize headerReferenceSize; @property (nonatomic...之后,-(CGSize) collectionViewContentSize将被调用, 以确定collection应该占据的尺寸。注意这里的尺寸不是指可视部分的尺寸,而应该是所有内容所占的尺寸。...collectionView的本质是一个scrollView,因此需要这个尺寸来配置滚动行为。

    2.2K110

    【IOS开发基础系列】UICollectionView专题

    Views 追加视图 如果你对UITableView比较熟悉的话,可以理解为每个Section的Header或者Footer,用来标记每个section的view     • Decoration Views...每个cell现在有独立的高亮事件和选中事件的delegate,用户点击cell的时候,现在会按照以下流程向delegate进行询问:     • -collectionView: shouldHighlightItemAtIndexPath...需要注意根据滚动方向不同,header和footer的高和宽中只有一个会起作用。垂直滚动时section间宽度为该尺寸的高,而水平滚动时为宽度起作用,如图。     ...* kMyInfoCollectionCellHeight + 10;     //确定是水平滚动,还是垂直滚动     UICollectionViewFlowLayout *flowLayout=...、设置sizeForItemAtIndexPath; //定义每个UICollectionViewCell 的大小 - (CGSize) collectionView: (UICollectionView

    90530

    iOS商品经营类目选择视图:上部分展示已经选择的类目信息(悬浮),下部分展示待选择的类目数据列表(支持滚动选中类目)

    2.1 自定义展示已经选择的类目信息 2.1.1 空心圆和实心圆 2.1.2 展示已经选择的类目信息cell的核心代码ERPSelectCategoryInfoV 2.2 VM 的定义 2.3 类目的层级...2.4 类目Model的定义 3.1 处理点击事件及创建视图 3.1.1 处理点击已经选择类目事件 3.1.2 处理选择类目事件 3.1.3 处理点击确定事件 ,传递选择的信息到发布商品控制器...: 1、发布商品时选择商品类目 2、商户进件选择经营类目 3、购物类app下单界面的商品类目筛选 在发布商品的时候,选择类目界面的要求视图分为上下部分。...1、 上部分:展示已经选择的类目信息,并清晰的从上倒下罗列对应层级类目信息(悬浮),点击类目的时候,下部分的展示的类目信息切换为同级类目信息供选择。...2、 下部分:展示可供选择的类目信息(支持滚动选中类目) ? 支持清空数据功能 ?

    79120

    使用 UICollectionView 实现首页卡片轮播效果

    ;相比 UITbleView,UICollectionView 的功能比它要强大的多,它支持水平与垂直俩种方向的布局,开发者可以完全自定义一套 layout 布局方案,实现出意想不到的效果。...思路分析 通过观察上面的图我们可以得出,这个网易云的轮播控件有三个特点,分别是: 1.支持图片手动横向滚动2.支持图片自动的滚动播放3.底部的分页控件会高亮显示出当前的图片是哪一张 好了,既然已经分析出来了它的特点...JUST DO IT 想到滚动,大家首先想到的肯定是用 UIScrollView + UIImageView 的方式来实现,但是 UICollectionView 给我们提供了更好的选择,因为它本身继承自...UIScrollView 然后又支持横向滚动,所以使用 UICollectionView 来实现横向滚动效果是最好不过的。...[BannerModel] self.placeholderImage = placeholderImage } 结尾 今天文章的到这里就结束了,内容相对来说比较简单,里面阐述的文字部分比较少

    2.1K20

    iOS 封装跑马灯和轮播效果

    iOS UICollectionView实现跑马灯和轮播效果.gif 功能描述:WSL_RollView 是基于UICollectionView实现的支持水平和垂直两个方向上的的分页和渐进循环轮播效果...一、实现方法 ①、 首先用UICollectionView和计时器实现一个基本的水平滚动效果,如下图,这个太简单就不在此详述。...iOS UICollectionView ②、对比上面的效果图,我们还需要解决分页的宽度和循环滚动的问题。.../** 返回值决定了collectionView停止滚动时的偏移量 手指松开后执行 * proposedContentOffset:原本情况下,collectionView停止滚动时最终的偏移量 *...,后边首尾相连需要UICollectionView可见范围内的数据源前边的元素cell //获取首尾相连循环滚动时需要用到的元素,并重组数据源 - (void)resetDataSourceForLoop

    4.2K40

    iOS 仿Excel 实现

    今天有个需求需要实现Excel的效果:如图 ? image.png 提醒 这只是一个demo,没有考虑那么多需求,也只是提供一个学习的思路。有具体的需求可以修改代码,避免重复造轮子。...实现的思路 顶部的Header 最左侧[左上头]放的是一个UILabel,后面就放的是一个UICollectionView。...头部下面 头部下面整体是一个UITableView,然后每个Cell的Header部分也是UlLabel,后面也是一个UICollectionView 难的部分 左右滚动 左右滚动的时候左边Header...和顶部Header最左边固定,其他部分跟随滚动 上下滚动 顶部Header固定,其他部分跟随滚动 滚动部分核心代码 整个滚动Demo就这部分难一点,其他的都很简单,看看都懂的。...= (UICollectionView *)view; collectionView.contentOffset = scrollView.contentOffset

    1K20

    Ceph集群的组成架构以及每个组成部分的作用和关系

    Ceph集群的组成架构如下:1. Ceph Monitors (监视器):作用:监控集群中每个OSD的状态、位置和负载,并维护PGmap和CRUSH map等重要的元数据。...关系:监视器是集群中的关键组件,至少需要3个监视器以实现容错性,通过选举机制来选择一个活跃的监视器。2. Ceph OSDs (对象存储守护进程):作用:负责存储和管理数据,以及执行数据的读写操作。...关系:OSD负责将数据根据CRUSH map的规则分布到正确的位置,并处理数据副本、数据修复、数据恢复等任务。3....这些组成部分的关系如下图所示: +------------------+ | Ceph Monitors | +---------...,OSD负责数据的存储和管理,CRUSH map定义了数据的分布规则,元数据服务器管理文件系统的元数据,网关提供对象存储的访问接口。

    60721

    手把手带你撸一个网易云音乐首页(三)

    这里我想了一个比较好的办法,只需要调用一次绘制方法即可,那就是将我们的 headView 实现在我们的 tableViewCell 中,如下所示: image 另外,因为每个 Section 都有 headView...在现实中,每个 Cell 所展示的视图样式都是非常丰富的,于是我们必须为 Cell 创建不同的 UI 样式,每种样式对应自己的数据 Model。...,决定了 UICollectionView 停止滚动时的偏移量,可以通过重写这个函数来实现自定义的分页滚动,重写这个函数的逻辑思路如下: 定义一个坐标点 CGPoint 来记录最新滚动的偏移坐标 定义俩个值分别为...记录了滚动的目标位移坐标,通过这个坐标和记录的上次滚动的坐标可以判断出是向左滚动还是向右滚动 如果俩坐标的水平方向相减的绝对值大于某个固定值(譬如说 item 宽度的 8 分之一),则可以判断发生了分页...decelerationRate = .fast } // 这个方法的返回值,决定了 CollectionView 停止滚动时的偏移量 override func targetContentOffset

    2.3K10

    【玩转嵌入式屏幕显示】(六)ST7789 SPI LCD硬件垂直滚动功能的使用

    滚动?发现新大陆! 根据手册中的8.14章节描述,旋转滚动仅仅是垂直滚动的一种模式,由垂直滚动区域定义指令(0x33H)和垂直滚动起始地址指令(0x77)决定。...设置滚动区域 小熊派板载LCD屏幕的大小是240240,水平和垂直都有240个像素点,但是ST7789驱动IC的显存大小为320240,垂直有320行像素点,水平有240行像素点,平常我们只是用到了显存的前面一部分...滚动显示首先需要设置滚动区域,显存垂直的320行像素点被划分为三个部分: TFA为顶部固定显示区域,这部分指定后会固定显示,不会滚动显示;VSA为滚动区域,这部分指定后会滚动显示;BFA为底部固定显示区域...,这部分指定后会固定显示,不会滚动显示。...因为整个显存垂直有320行像素点,显然一个字节8位是装不下的,所以TFA、VSA、BFA三个区域的值设置都是16位,并且三个值加起来要等于320,否则滚动区域定义失败。

    6.3K40

    iOS开发之窥探UICollectionViewController(五) --一款炫酷的图片浏览组件

    如何实现 上面介绍了如何去使用该自定义组件,接下来就是“造车”的过程了。本篇博客的第三部分介绍如何去实现这个自定义布局。 1. ...滚动区域的大小。...其中transform的值是根据CollectionView的滚动偏移量来计算的,所以在滚动CollectionView时,Cell也会跟着旋转。...该方法返回YES意味着当滚动时,会再次执行上面(4)的方法,重新为每个Cell的属性赋值。所以重写下面的方法,并返回YES(下面的表达式也是一样的)才可以运动起来呢。...CGRectEqualToRect(newBounds, self.collectionView.bounds); 4 } (6).重写下面的方法是为了修正CollectionView滚动的偏移量,使当前显示的

    1.5K80

    iOS流布局UICollectionView系列六——将布局从平面应用到空间

    如果我们将系统的pickerView沿着y轴旋转90°,你会发现侧面的它是一个规则的正多边形,这里的radius就是这个多边形中心到其边的垂直距离,也是内切圆的半径,所有的item拼成了一个正多边形,示例如下...一个滑动的范围,我们以一屏collectionView的滑动距离来当做滚轮滚动一下的参照,我们在布局类中的如下方法中返回滑动区域: -(CGSize)collectionViewContentSize{... numberOfItemsInSection:0]); } 这时我们的collectionView已经可以进行滑动,但是并不是我们想要的效果,滚轮并没有滚动,而是随着滑动出了屏幕,因此,我们需要在滑动的时候不停的动态布局...四、让其循环滚动的逻辑         我们再进一步,如果滚动可以循环,这个控件将更加炫酷,添加这样的逻辑也很简单,通过监测scrollView的偏移量,我们可以对齐进行处理,因为collectionView...collectionView的偏移量设置为1屏的偏移量 collect.contentOffset = CGPointMake(0, 400); 在layout类中: //将滚动范围设置为(item总数

    1.4K20

    添加多个屏幕-创建格线布局

    在上一节中,我们学习了如何使用按钮更改iPhone的屏幕。让我们进一步推动!我们将实现一个CollectionView,我们将能够切换到您想要的壁纸。该的CollectionView将是滚动的水平。...现在,选择尺寸检查器,我们将给我们的cell大小:( 宽度:140高度:250)。设置cell的Min Spacing和左侧的Section Insets为20。它会在每个cell之间留出一些空间。...文本是iPhone X并将底部约束为0并将容器中的水平中心约束。在“ 属性”检查器中,将“滚动方向”更改为“ 水平”并取消选中“ 显示”指示器。...到目前为止,如果您运行该应用程序,您将看到3个类似的cell,并且它是可滚动的。问题是它现在做的不多。 ?...这部分是一个非常漫长而艰难的部分。我们学到了很多关于如何实现Collection View的知识。我们还学会了如何委派。这是ARKit 2扩展的结束,我们已经走了很长的路!我希望你喜欢这门课程!

    2.9K40
    领券