Android自定義四個方向滾動的跑馬燈MarqueeViewLibrary

在大佬MarqueeViewLibrary框架的基礎(chǔ)上實(shí)現(xiàn)控件的各項(xiàng)參數(shù)動態(tài)配置;
原文地址:
https://gitcode.net/mirrors/gongwen/MarqueeViewLibrary

實(shí)現(xiàn)后效果圖:


配置參數(shù) 動態(tài)替換下面的值即可

 Boolean isPlayAnim = true;//是否滾動
        int width = 600;//控件寬度dp
        int heigh = 80;//控件高度dp
        int margin_left = 5;//左邊距 dp
        int margin_right = 0;//右邊距 dp
        int margin_top = 5;//上邊距 dp
        int margin_bottom = 0;//下邊距 dp
        String backgroundColor = "#cccccc";//控件背景色
        int fontSize = 14;//字體大小dp
        String textColor = "#000000";//字體顏色
        int scrollSpeed = 4000;//翻頁速度 毫秒
        int scrollDirection = 4;//滾動方向:1上2下3左4右 其他默認(rèn)左;
        int animSpeed = 2000;//動畫持續(xù)時間 毫秒
        boolean isSingleLine = true;//是否單行
        int textAlineType = 1;//文字居中方式:1居中,2橫向居中3縱向居中 默認(rèn)1
        //設(shè)置數(shù)據(jù)源
        final List<String> datas = Arrays.asList("《賦得古原草送別》", "離離原上草磅废,一歲一枯榮免都。", "野火燒不盡,春風(fēng)吹又生贮泞。", "遠(yuǎn)芳侵古道资昧,晴翠接荒城酬土。",
 "又送王孫去,萋萋滿別情格带。", "文字顯示不下時撤缴,系統(tǒng)的處理方式(可選:none,start叽唱,middle屈呕,end)");

配置控制

//本地父布局
        RelativeLayout rl_main_layout = findViewById(R.id.rl_main_layout);
        int widthPx = MyUtils.px2dip(this, width);
        int heighPx = MyUtils.px2dip(this, heigh);
            
        SimpleMarqueeView marqueeView = new SimpleMarqueeView(this);
        RelativeLayout.LayoutParams layoutParams = (RelativeLayout.LayoutParams) rl_main_layout.getLayoutParams();
        layoutParams.width = widthPx;
        layoutParams.height = heighPx;
        layoutParams.setMargins(MyUtils.dip2px(this, margin_left), MyUtils.dip2px(this, margin_top),
                MyUtils.dip2px(this, margin_right), MyUtils.dip2px(this, margin_bottom));
        marqueeView.setLayoutParams(layoutParams);//設(shè)置寬高及margin
        rl_main_layout.setBackgroundColor(Color.parseColor(backgroundColor));//設(shè)置背景色
        rl_main_layout.addView(marqueeView);
        /**
         * 設(shè)置動畫
         * SimpleMarqueeView marqueeView SimpleMarqueeView控件
         * int scrollDirection 滾動方向
         * int animSpeed 動畫持續(xù)時間
         * int width控件寬度
         * */
        setAnimation(marqueeView, scrollDirection, animSpeed, widthPx, heighPx);
        marqueeView.setFlipInterval(scrollSpeed);//翻頁時間間隔
        marqueeView.setTextColor(Color.parseColor(textColor));//字體顏色
        marqueeView.setTextSize(MyUtils.dip2px(this, fontSize));
        marqueeView.setTextEllipsize(TextUtils.TruncateAt.END);//文字顯示不下時,系統(tǒng)的處理方式
        switch (textAlineType) {//1居中,2橫向居中3縱向居中 默認(rèn)1
            case 1:
                marqueeView.setTextGravity(Gravity.CENTER);
                break;
            case 2:
                marqueeView.setTextGravity(Gravity.CENTER_HORIZONTAL);
                break;
            case 3:
                marqueeView.setTextGravity(Gravity.CENTER_VERTICAL);
                break;
            default:
                marqueeView.setTextGravity(Gravity.CENTER);
                break;
        }
        marqueeView.setTextSingleLine(isSingleLine);//是否單行
        SimpleMF<String> marqueeFactory = new SimpleMF(this);
        marqueeFactory.setData(datas);
        marqueeView.setMarqueeFactory(marqueeFactory);
        if (isPlayAnim && datas != null || datas.size() > 0) {
            marqueeView.startFlipping();
        } else {
            marqueeView.stopFlipping();
        }

動畫配置

  private void setAnimation(SimpleMarqueeView marqueeView, int scrollDirection, int animSpeed, int width, int heigh) {
        switch (scrollDirection) {
            case 1://上
                setBottomToTop(marqueeView, animSpeed, heigh);
                break;
            case 2://下
                setTopToBottom(marqueeView, animSpeed, heigh);
                break;
            case 3://左
                setRightToLeftAnim(marqueeView, animSpeed, width);
                break;
            case 4://右
                setLeftToRoght(marqueeView, animSpeed, width);
                break;
            default://左
                setRightToLeftAnim(marqueeView, animSpeed, width);
                break;
        }
    }

    //從下到上
    private void setBottomToTop(SimpleMarqueeView marqueeView, int animSpeed, int heigth) {
        AlphaAnimation alphaAnim = new AlphaAnimation(0f, 1f);
        TranslateAnimation translateAnim = new TranslateAnimation(0, 0f, heigth, 0);
        AnimationSet in_bottom = new AnimationSet(true);
        in_bottom.addAnimation(alphaAnim);
        in_bottom.addAnimation(translateAnim);
        in_bottom.setDuration(animSpeed);

        AlphaAnimation alphaAnim1 = new AlphaAnimation(1, 0f);
        TranslateAnimation translateAnim1 = new TranslateAnimation(0f, 0, 0, -heigth);
        AnimationSet out_top = new AnimationSet(true);
        out_top.addAnimation(alphaAnim1);
        out_top.addAnimation(translateAnim1);
        out_top.setDuration(animSpeed);
        marqueeView.setInAndOutAnim(in_bottom, out_top);
    }
    //從上到下
    private void setTopToBottom(SimpleMarqueeView marqueeView, int animSpeed, int heigth) {
        AlphaAnimation alphaAnim = new AlphaAnimation(0f, 1f);
        TranslateAnimation translateAnim = new TranslateAnimation(0, 0f, -heigth, 0);
        AnimationSet in_bottom = new AnimationSet(true);
        in_bottom.addAnimation(alphaAnim);
        in_bottom.addAnimation(translateAnim);
        in_bottom.setDuration(animSpeed);

        AlphaAnimation alphaAnim1 = new AlphaAnimation(1, 0f);
        TranslateAnimation translateAnim1 = new TranslateAnimation(0f, 0, 0,heigth);
        AnimationSet out_top = new AnimationSet(true);
        out_top.addAnimation(alphaAnim1);
        out_top.addAnimation(translateAnim1);
        out_top.setDuration(animSpeed);
        marqueeView.setInAndOutAnim(in_bottom, out_top);
    }
    //從右到左
    private void setRightToLeftAnim(SimpleMarqueeView marqueeView, int animSpeed, int width) {
        TranslateAnimation translateAnim = new TranslateAnimation(width, 0f, 0, 0);
        AnimationSet in_right = new AnimationSet(true);
        in_right.addAnimation(translateAnim);
        in_right.setDuration(animSpeed);

        TranslateAnimation translateAnim1 = new TranslateAnimation(0f, -width, 0, 0);
        AnimationSet out_left = new AnimationSet(true);
        out_left.setDuration(animSpeed);
        out_left.addAnimation(translateAnim1);
        marqueeView.setInAndOutAnim(in_right, out_left);
    }
    //從左到右
    private void setLeftToRoght(SimpleMarqueeView marqueeView, int animSpeed, int width) {
        TranslateAnimation translateAnim = new TranslateAnimation(-width, 0, 0, 0);
        AnimationSet in_right = new AnimationSet(true);
        in_right.addAnimation(translateAnim);
        in_right.setDuration(animSpeed);

        TranslateAnimation translateAnim1 = new TranslateAnimation(0, width, 0, 0);
        AnimationSet out_left = new AnimationSet(true);
        out_left.setDuration(animSpeed);
        out_left.addAnimation(translateAnim1);
        marqueeView.setInAndOutAnim(in_right, out_left);
    }
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末棺亭,一起剝皮案震驚了整個濱河市虎眨,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖嗽桩,帶你破解...
    沈念sama閱讀 218,682評論 6 507
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件岳守,死亡現(xiàn)場離奇詭異,居然都是意外死亡碌冶,警方通過查閱死者的電腦和手機(jī)湿痢,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,277評論 3 395
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來扑庞,“玉大人譬重,你說我怎么就攤上這事」薨保” “怎么了臀规?”我有些...
    開封第一講書人閱讀 165,083評論 0 355
  • 文/不壞的土叔 我叫張陵,是天一觀的道長栅隐。 經(jīng)常有香客問我塔嬉,道長,這世上最難降的妖魔是什么约啊? 我笑而不...
    開封第一講書人閱讀 58,763評論 1 295
  • 正文 為了忘掉前任邑遏,我火速辦了婚禮,結(jié)果婚禮上恰矩,老公的妹妹穿的比我還像新娘。我一直安慰自己憎蛤,他們只是感情好外傅,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,785評論 6 392
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著俩檬,像睡著了一般萎胰。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上棚辽,一...
    開封第一講書人閱讀 51,624評論 1 305
  • 那天技竟,我揣著相機(jī)與錄音,去河邊找鬼屈藐。 笑死榔组,一個胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的联逻。 我是一名探鬼主播搓扯,決...
    沈念sama閱讀 40,358評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼包归!你這毒婦竟也來了锨推?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 39,261評論 0 276
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎换可,沒想到半個月后椎椰,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,722評論 1 315
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡沾鳄,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,900評論 3 336
  • 正文 我和宋清朗相戀三年慨飘,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片洞渔。...
    茶點(diǎn)故事閱讀 40,030評論 1 350
  • 序言:一個原本活蹦亂跳的男人離奇死亡套媚,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出磁椒,到底是詐尸還是另有隱情堤瘤,我是刑警寧澤,帶...
    沈念sama閱讀 35,737評論 5 346
  • 正文 年R本政府宣布浆熔,位于F島的核電站本辐,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏医增。R本人自食惡果不足惜慎皱,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,360評論 3 330
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望叶骨。 院中可真熱鬧茫多,春花似錦、人聲如沸忽刽。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,941評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽跪帝。三九已至今膊,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間伞剑,已是汗流浹背斑唬。 一陣腳步聲響...
    開封第一講書人閱讀 33,057評論 1 270
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留黎泣,地道東北人恕刘。 一個月前我還...
    沈念sama閱讀 48,237評論 3 371
  • 正文 我出身青樓,卻偏偏與公主長得像聘裁,于是被迫代替她去往敵國和親雪营。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,976評論 2 355

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