欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  移动技术

Android仿淘宝头条基于TextView实现上下滚动通知效果

程序员文章站 2023-11-27 08:52:34
最近有个项目需要实现通知栏的上下滚动效果,仿淘宝头条的那种。 我从网上看了一些代码,把完整的效果做了出来。如图所示: 具体代码片段如下: 1.在res文件夹下新建...

最近有个项目需要实现通知栏的上下滚动效果,仿淘宝头条的那种。

我从网上看了一些代码,把完整的效果做了出来。如图所示:

Android仿淘宝头条基于TextView实现上下滚动通知效果

具体代码片段如下:

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实现上下滚动通知效果,希望对大家有所帮助