实现文字循环横向滚动效果(当显示到最后一个字时从头再次开始)

 nameAnimation : 需要添加动画效果的元素的id; 

页面引入了decimal.js的加减乘除方法

     // 动态设置动画效果
    handleGetStyle(nameAnimation) {
      // 获取到当前需要添加动画的id
     let nameAnimationDom = document.getElementById(nameAnimation);
     // 获取当前名字的宽度
     let myWidth = nameAnimationDom.offsetWidth
     // 获取父元素的宽度
     let myParentWidth = nameAnimationDom.parentNode.offsetWidth
     // 获取实际计算的宽度
     let computedWidth = myWidth<myParentWidth?myParentWidth:myWidth
     // 计算需要移动的百分比
     let myPercent = except(Math.abs(reduce(myWidth - myParentWidth)),computedWidth)*100
     var ss = document.styleSheets;
     // 追加动画属性
     ss[0].insertRule(`@keyframes ${nameAnimation} { 
				0% {
          transform: translateX(5%);
          -webkit-transform: translateX(5%);
        }

        100% {
          transform: translateX(-${myPercent}%);
          -webkit-transform: translateX(-${myPercent}%);
        }
				}`, 0);
        // 给当前元素添加动画样式
      nameAnimationDom.setAttribute('style',`animation: 8s ${nameAnimation} linear infinite normal;`);
    },

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
实现当鼠标移动到某段文字上时文字横向滚动显示,可以按照以下步骤进行操作: 1. 创建一个UI Text组件,并将文本内容填写进去。 2. 在UI Text组件上添加一个Scrollbar组件,用于控制文本的横向滚动。 3. 在UI Text组件上添加一个Event Trigger组件,在PointerEnter事件下添加一个回调函数。 4. 编写回调函数,实现当鼠标移动到文本上时,控制Scrollbar组件的值,让文本横向滚动。 以下是一个简单的实现示例: ```csharp using UnityEngine; using UnityEngine.EventSystems; using UnityEngine.UI; public class TextScroll : MonoBehaviour, IPointerEnterHandler { public Scrollbar scrollbar; public float scrollSpeed = 0.1f; private bool isScrolling = false; public void OnPointerEnter(PointerEventData eventData) { isScrolling = true; } private void Update() { if (isScrolling) { scrollbar.value += Time.deltaTime * scrollSpeed; if (scrollbar.value >= 1f) { isScrolling = false; } } } } ``` 在这个示例中,我们创建了一个名为TextScroll的脚本,用于控制文本的横向滚动。我们需要在Inspector面板中将Scrollbar组件和scrollSpeed参数赋值给脚本。 在OnPointerEnter函数中,我们将isScrolling标记设置为true,表示鼠标已经移动到文本上了。在Update函数中,我们通过控制Scrollbar组件的value值来实现文本的横向滚动。当Scrollbar的value值达到1时,表示文本已经滚动到了最右边,我们将isScrolling标记设置为false,停止滚动。 在UI Text组件上添加TextScroll脚本,当鼠标移动到文本上时,就会触发指定的回调函数,从而实现文本的横向滚动

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值