Android仿淘宝头条基于TextView实现上下滚动通知效果
程序员文章站
2023-12-12 11:20:28
最近有个项目需要实现通知栏的上下滚动效果,仿淘宝头条的那种。
我从网上看了一些代码,把完整的效果做了出来。如图所示:
具体代码片段如下:
1.在res文件夹下新建...
最近有个项目需要实现通知栏的上下滚动效果,仿淘宝头条的那种。
我从网上看了一些代码,把完整的效果做了出来。如图所示:
具体代码片段如下:
1.在res文件夹下新建anmin文件夹,在这个文件夹里创建两个文件
(1).anim_marquee_in.xml进入时动画
<?xml version="1.0" encoding="utf-8"?> <set xmlns:android="http://schemas.android.com/apk/res/android" > <translate android:duration="1500" android:fromydelta="100%p" android:toydelta="0"> </translate> </set>
(2).anim_marquee_out.xml退出时动画
<?xml version="1.0" encoding="utf-8"?> <set xmlns:android="http://schemas.android.com/apk/res/android"> <translate android:duration="1500" android:fromydelta="0" android:toydelta="-100%p"> </translate> </set>
2.activity_main.xml
<relativelayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns:tools="http://schemas.android.com/tools" android:id="@+id/activity_main" android:layout_width="match_parent" android:layout_height="match_parent" tools:context="com.spore.marqueeview.mainactivity" > <viewflipper android:id="@+id/marquee_view" android:layout_width="match_parent" android:layout_height="wrap_content" android:autostart="true" android:background="#fff" android:flipinterval="2500" android:inanimation="@anim/anim_marquee_in" android:outanimation="@anim/anim_marquee_out" > </viewflipper> </relativelayout>
3.noticelayout.xml
<?xml version="1.0" encoding="utf-8"?> <linearlayout xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="match_parent" android:layout_height="wrap_content" android:orientation="horizontal" > <imageview android:layout_width="wrap_content" android:layout_height="wrap_content" android:padding="5dp" android:src="@drawable/icon_home_notice" /> <textview android:layout_width="match_parent" android:layout_height="match_parent" android:gravity="center_vertical" android:paddingleft="10dp" android:singleline="true" android:text="[2017-02-28 08:00]通知:上午九点整开会!" android:textsize="18sp" /> </linearlayout>
4.mainactivity.java
package com.iponkan.textviewupdown; import com.example.textviewupdown.r; import android.os.bundle; import android.app.activity; import android.view.menu; import android.view.view; import android.widget.viewflipper; public class mainactivity extends activity { @override protected void oncreate(bundle savedinstancestate) { super.oncreate(savedinstancestate); setcontentview(r.layout.activity_main); // 为viewflipper添加广告条 viewflipper vf = (viewflipper) findviewbyid(r.id.marquee_view); vf.addview(view.inflate(this, r.layout.noticelayout, null)); vf.addview(view.inflate(this, r.layout.noticelayout, null)); vf.addview(view.inflate(this, r.layout.noticelayout, null)); } @override public boolean oncreateoptionsmenu(menu menu) { // inflate the menu; this adds items to the action bar if it is present. getmenuinflater().inflate(r.menu.main, menu); return true; } }
以上所述是小编给大家介绍的android仿淘宝头条基于textview实现上下滚动通知效果,希望对大家有所帮助