Swift 滾動(dòng)label

<pre>
/// 滾動(dòng)label
class USTradeScrollLabelView: USBaseView {
fileprivate let scrollLabel: UILabel = UILabel()
var scrollText: String = ""

fileprivate var rectMark1: CGRect = CGRect.zero
fileprivate var rectMark2: CGRect = CGRect.zero

fileprivate var arrLabel: [UILabel] = []
var timeInterval: TimeInterval = 0.0
var isStop: Bool = false

init(info: String, frame: CGRect) {
    super.init(frame: frame)

// self.scrollText = info
self.scrollText = info
self.setupUI()
}

required public init?(coder aDecoder: NSCoder) {
    fatalError("init(coder:) has not been implemented")
}

func setupUI() {

// super.setup()

    self.scrollText = "   \(self.scrollText)   "
    self.timeInterval = self.displayDurationForString(self.scrollText)
    self.clipsToBounds = true
    
    self.scrollLabel.us.customize { (view) in
        view.text = self.scrollText
        view.font = USFont.t05.font
        view.us.handleTheme {
            view.textColor = USColor.c301.color
        }
    }
    
    let sizeOfText = self.scrollLabel.sizeThatFits(CGSize.zero)
    self.rectMark1 = CGRect(x: 0, y: 0, width: sizeOfText.width, height: self.bounds.size.height)
    self.rectMark2 = CGRect(x: self.rectMark1.origin.x + self.rectMark1.size.width, y: 0, width: sizeOfText.width, height: self.bounds.size.height)
    
    self.scrollLabel.frame = self.rectMark1
    self.addSubview(self.scrollLabel)
    
    self.arrLabel.append(self.scrollLabel)
    
    let useReserve = sizeOfText.width > self.frame.size.width ? true: false
    
    if useReserve {
        let reserveTextLabel = UILabel(frame: self.rectMark2)
        reserveTextLabel.us.customize({ (view) in
            view.text = self.scrollText
            view.font = USFont.t05.font
            view.us.handleTheme {
                view.textColor = USColor.c301.color
            }
            self.addSubview(view)
            self.arrLabel.append(reserveTextLabel)
            // label滾動(dòng)
            self.scrollLabelIfNeeded()
        })
        
    }
    
}

fileprivate func scrollLabelIfNeeded() {
    if !self.isStop {
        let label1 = self.arrLabel[0]
        let label2 = self.arrLabel[1]
        
        UIView.transition(with: self, duration: self.timeInterval, options: [.curveLinear], animations: {
            label1.frame = CGRect(x: -self.rectMark1.size.width, y: 0, width: self.rectMark1.size.width, height: self.rectMark1.size.height)
            label2.frame = CGRect(x: label1.frame.origin.x + label1.frame.size.width, y: 0, width: label1.frame.size.width, height: label1.frame.size.height)
            
        }, completion: { [weak self](finished) in
            guard let `self` = self else {
                return
            }
            label1.frame = self.rectMark2
            label2.frame = self.rectMark1
            
            self.arrLabel[0] = label2
            self.arrLabel[1] = label1
            
            self.scrollLabelIfNeeded()
        })
    }
}

fileprivate func displayDurationForString(_ string: String) -> TimeInterval {
    let inter: TimeInterval = Double(string.characters.count / 3)
    return inter
}

func start() {
    self.isStop = false
    let label1 = self.arrLabel[0]
    let label2 = self.arrLabel[1]
    label1.frame = self.rectMark2
    label2.frame = self.rectMark1
    
    self.arrLabel[0] = label2
    self.arrLabel[1] = label1
    
    self.scrollLabelIfNeeded()
}

func stop() {
    self.isStop = true
}

}

</pre>

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末般此,一起剝皮案震驚了整個(gè)濱河市蚪战,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌铐懊,老刑警劉巖邀桑,帶你破解...
    沈念sama閱讀 218,284評(píng)論 6 506
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異科乎,居然都是意外死亡壁畸,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,115評(píng)論 3 395
  • 文/潘曉璐 我一進(jìn)店門茅茂,熙熙樓的掌柜王于貴愁眉苦臉地迎上來瓤摧,“玉大人,你說我怎么就攤上這事玉吁≌彰郑” “怎么了?”我有些...
    開封第一講書人閱讀 164,614評(píng)論 0 354
  • 文/不壞的土叔 我叫張陵进副,是天一觀的道長这揣。 經(jīng)常有香客問我,道長影斑,這世上最難降的妖魔是什么给赞? 我笑而不...
    開封第一講書人閱讀 58,671評(píng)論 1 293
  • 正文 為了忘掉前任,我火速辦了婚禮矫户,結(jié)果婚禮上片迅,老公的妹妹穿的比我還像新娘。我一直安慰自己皆辽,他們只是感情好柑蛇,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,699評(píng)論 6 392
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著驱闷,像睡著了一般耻台。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上空另,一...
    開封第一講書人閱讀 51,562評(píng)論 1 305
  • 那天盆耽,我揣著相機(jī)與錄音,去河邊找鬼。 笑死摄杂,一個(gè)胖子當(dāng)著我的面吹牛坝咐,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播析恢,決...
    沈念sama閱讀 40,309評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼墨坚,長吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來了氮昧?” 一聲冷哼從身側(cè)響起框杜,我...
    開封第一講書人閱讀 39,223評(píng)論 0 276
  • 序言:老撾萬榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎袖肥,沒想到半個(gè)月后咪辱,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,668評(píng)論 1 314
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡椎组,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,859評(píng)論 3 336
  • 正文 我和宋清朗相戀三年油狂,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片寸癌。...
    茶點(diǎn)故事閱讀 39,981評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡专筷,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出蒸苇,到底是詐尸還是另有隱情磷蛹,我是刑警寧澤,帶...
    沈念sama閱讀 35,705評(píng)論 5 347
  • 正文 年R本政府宣布溪烤,位于F島的核電站味咳,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏檬嘀。R本人自食惡果不足惜槽驶,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,310評(píng)論 3 330
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望鸳兽。 院中可真熱鬧掂铐,春花似錦、人聲如沸揍异。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,904評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽蒿秦。三九已至烤镐,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間棍鳖,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 33,023評(píng)論 1 270
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留渡处,地道東北人镜悉。 一個(gè)月前我還...
    沈念sama閱讀 48,146評(píng)論 3 370
  • 正文 我出身青樓,卻偏偏與公主長得像医瘫,于是被迫代替她去往敵國和親侣肄。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,933評(píng)論 2 355

推薦閱讀更多精彩內(nèi)容