view向上滚动
之前本来是打算做TextView垂直向上滚动的,后来发现一位大神做得很好,https://github.com/sfsheng0322/MarqueeView 孙福生大神,然后自己要用到多个View向上滚动,也就是类似淘宝首页头条的那种滚动,所以就按照那个思路想了系啊,可以把View拿来滚动,这样可以自己随意的修改View里面的内容,还比较简单一些。所以这个整个思路就是把View就行循环滚动。
看一下循环滚动View的内容咋写的吧,非常简单。
- package com.dreamlive.upmarqueeview;
- import android.content.Context;
- import android.util.AttributeSet;
- import android.view.View;
- import android.view.animation.Animation;
- import android.view.animation.AnimationUtils;
- import android.widget.ViewFlipper;
- import java.util.List;
- /**
- * 仿淘宝首页的 淘宝头条滚动的自定义View
- *
- * Created by dreamlive on 2016/7/20.
- */
- public class UPMarqueeView extends ViewFlipper {
- private Context mContext;
- private boolean isSetAnimDuration = false;
- private int interval = 2000;
- /**
- * 动画时间
- */
- private int animDuration = 500;
- public UPMarqueeView(Context context, AttributeSet attrs) {
- super(context, attrs);
- init(context, attrs, 0);
- }
- private void init(Context context, AttributeSet attrs, int defStyleAttr) {
- this.mContext = context;
- setFlipInterval(interval);
- Animation animIn = AnimationUtils.loadAnimation(mContext, R.anim.anim_marquee_in);
- if (isSetAnimDuration) animIn.setDuration(animDuration);
- setInAnimation(animIn);
- Animation animOut = AnimationUtils.loadAnimation(mContext, R.anim.anim_marquee_out);
- if (isSetAnimDuration) animOut.setDuration(animDuration);
- setOutAnimation(animOut);
- }
- /**
- * 设置循环滚动的View数组
- *
- * @param views
- */
- public void setViews(List<View> views) {
- if (views == null || views.size() == 0) return;
- removeAllViews();
- for (int i = 0; i < views.size(); i++) {
- addView(views.get(i));
- }
- startFlipping();
- }
- }

package com.dreamlive.upmarqueeview; import android.content.Context;
import android.util.AttributeSet;
import android.view.View;
import android.view.animation.Animation;
import android.view.animation.AnimationUtils;
import android.widget.ViewFlipper; import java.util.List; /**
* 仿淘宝首页的 淘宝头条滚动的自定义View
*
* Created by dreamlive on 2016/7/20.
*/
public class UPMarqueeView extends ViewFlipper { private Context mContext;
private boolean isSetAnimDuration = false;
private int interval = 2000;
/**
* 动画时间
*/
private int animDuration = 500; public UPMarqueeView(Context context, AttributeSet attrs) {
super(context, attrs);
init(context, attrs, 0);
} private void init(Context context, AttributeSet attrs, int defStyleAttr) {
this.mContext = context;
setFlipInterval(interval);
Animation animIn = AnimationUtils.loadAnimation(mContext, R.anim.anim_marquee_in);
if (isSetAnimDuration) animIn.setDuration(animDuration);
setInAnimation(animIn);
Animation animOut = AnimationUtils.loadAnimation(mContext, R.anim.anim_marquee_out);
if (isSetAnimDuration) animOut.setDuration(animDuration);
setOutAnimation(animOut);
} /**
* 设置循环滚动的View数组
*
* @param views
*/
public void setViews(List<View> views) {
if (views == null || views.size() == 0) return;
removeAllViews();
for (int i = 0; i < views.size(); i++) {
addView(views.get(i));
}
startFlipping();
} }
MainActivity的内容:
- package com.dreamlive.upmarqueeviewdemo;
- import android.os.Bundle;
- import android.support.v7.app.AppCompatActivity;
- import android.view.LayoutInflater;
- import android.view.View;
- import android.widget.LinearLayout;
- import android.widget.TextView;
- import com.dreamlive.upmarqueeview.UPMarqueeView;
- import java.util.ArrayList;
- import java.util.List;
- /**
- * 仿淘宝首页的 淘宝头条滚动的自定义View
- * Created by dreamlive on 2016/7/20.
- */
- public class MainActivity extends AppCompatActivity {
- private UPMarqueeView upview1;
- List<String> data = new ArrayList<>();
- List<View> views = new ArrayList<>();
- @Override
- protected void onCreate(Bundle savedInstanceState) {
- super.onCreate(savedInstanceState);
- setContentView(R.layout.activity_main);
- initParam();
- initdata();
- initView();
- }
- /**
- * 实例化控件
- */
- private void initParam() {
- upview1 = (UPMarqueeView) findViewById(R.id.upview1);
- }
- /**
- * 初始化界面程序
- */
- private void initView() {
- setView();
- upview1.setViews(views);
- }
- /**
- * 初始化需要循环的View
- * 为了灵活的使用滚动的View,所以把滚动的内容让用户自定义
- * 假如滚动的是三条或者一条,或者是其他,只需要把对应的布局,和这个方法稍微改改就可以了,
- */
- private void setView() {
- for (int i = 0; i < data.size(); i = i + 2) {
- //设置滚动的单个布局
- LinearLayout moreView = (LinearLayout) LayoutInflater.from(this).inflate(R.layout.item_view, null);
- //初始化布局的控件
- TextView tv1 = (TextView) moreView.findViewById(R.id.tv1);
- TextView tv2 = (TextView) moreView.findViewById(R.id.tv2);
- //进行对控件赋值
- tv1.setText(data.get(i).toString());
- if (data.size() > i + 1) {
- //因为淘宝那儿是两条数据,但是当数据是奇数时就不需要赋值第二个,所以加了一个判断,还应该把第二个布局给隐藏掉
- tv2.setText(data.get(i + 1).toString());
- }else {
- moreView.findViewById(R.id.rl2).setVisibility(View.GONE);
- }
- //添加到循环滚动数组里面去
- views.add(moreView);
- }
- }
- /**
- * 初始化数据
- */
- private void initdata() {
- data = new ArrayList<>();
- data.add("家人给2岁孩子喝这个,孩子智力倒退10岁!!!");
- data.add("iPhone8最感人变化成真,必须买买买买!!!!");
- data.add("简直是白菜价!日本玩家33万甩卖15万张游戏王卡");
- data.add("iPhone7价格曝光了!看完感觉我的腰子有点疼...");
- data.add("主人内疚逃命时没带够,回废墟狂挖30小时!");
- // data.add("竟不是小米乐视!看水抢了骁龙821首发了!!!");
- }
- }

package com.dreamlive.upmarqueeviewdemo; import android.os.Bundle;
import android.support.v7.app.AppCompatActivity;
import android.view.LayoutInflater;
import android.view.View;
import android.widget.LinearLayout;
import android.widget.TextView; import com.dreamlive.upmarqueeview.UPMarqueeView; import java.util.ArrayList;
import java.util.List; /**
* 仿淘宝首页的 淘宝头条滚动的自定义View
* Created by dreamlive on 2016/7/20.
*/
public class MainActivity extends AppCompatActivity { private UPMarqueeView upview1;
List<String> data = new ArrayList<>();
List<View> views = new ArrayList<>(); @Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
initParam();
initdata();
initView();
} /**
* 实例化控件
*/
private void initParam() {
upview1 = (UPMarqueeView) findViewById(R.id.upview1);
} /**
* 初始化界面程序
*/
private void initView() {
setView();
upview1.setViews(views);
} /**
* 初始化需要循环的View
* 为了灵活的使用滚动的View,所以把滚动的内容让用户自定义
* 假如滚动的是三条或者一条,或者是其他,只需要把对应的布局,和这个方法稍微改改就可以了,
*/
private void setView() {
for (int i = 0; i < data.size(); i = i + 2) {
//设置滚动的单个布局
LinearLayout moreView = (LinearLayout) LayoutInflater.from(this).inflate(R.layout.item_view, null);
//初始化布局的控件
TextView tv1 = (TextView) moreView.findViewById(R.id.tv1);
TextView tv2 = (TextView) moreView.findViewById(R.id.tv2);
//进行对控件赋值
tv1.setText(data.get(i).toString());
if (data.size() > i + 1) {
//因为淘宝那儿是两条数据,但是当数据是奇数时就不需要赋值第二个,所以加了一个判断,还应该把第二个布局给隐藏掉
tv2.setText(data.get(i + 1).toString());
}else {
moreView.findViewById(R.id.rl2).setVisibility(View.GONE);
} //添加到循环滚动数组里面去
views.add(moreView);
}
} /**
* 初始化数据
*/
private void initdata() {
data = new ArrayList<>();
data.add("家人给2岁孩子喝这个,孩子智力倒退10岁!!!");
data.add("iPhone8最感人变化成真,必须买买买买!!!!");
data.add("简直是白菜价!日本玩家33万甩卖15万张游戏王卡");
data.add("iPhone7价格曝光了!看完感觉我的腰子有点疼...");
data.add("主人内疚逃命时没带够,回废墟狂挖30小时!");
// data.add("竟不是小米乐视!看水抢了骁龙821首发了!!!"); }
}
github地址:https://github.com/dreamlivemeng/UpMarqueeTextView-master 欢迎star,fork,提pr, issues。
view向上滚动的更多相关文章
- Android CoordinatorLayout + AppBarLayout(向上滚动隐藏指定的View)
在新的Android Support Library里面,新增了CoordinatorLayout, AppBarLayout等. 实现的效果: 向下滚动RecylerView,Tab会被隐藏,向上滚 ...
- View的滚动原理简单解析
一直对View的滚动了解的不深,说明确了吧也能说出个所以然来,所以我就花了点时间做了一个小小的总结,言归正传,view的滑动分为下面三种: 1)View本身不滚动,指滚动View的内容,这也是View ...
- Android View中滚动相关
方法 scrollTo: (内容的左上角)达到某个地点 scrollBy: 根据当前位置,再移动多少 属性: mScrollX, 以下是文档解释 The offset, in pixels ...
- 高仿京东APP首页“京东快报”自己主动向上滚动的广告条
转载请标明出处: http://blog.csdn.net/hai_qing_xu_kong/article/details/51013562 本文出自:[顾林海的博客] 前言 上次在京东APP上买东 ...
- UpMarqueeTextView-模仿淘宝client向上滚动的广告条
UpMarqueeTextView一个简单的向上滚动的相似跑马灯效果,项目中用到的时候是接受到推送过来的消息向上滚动一次.没有做动态的gif效果,所以都是一些纯文字的简单记录. UpMarqueeTe ...
- 向上滚动或者向下滚动分页异步加载数据(Ajax + lazyload)[上拉加载组件]
/**** desc : 分页异步获取列表数据,页面向上滚动时候加载前面页码,向下滚动时加载后面页码 ajaxdata_url ajax异步的URL 如data.php page_val_name a ...
- 移动手机端H5无缝间歇平滑向上滚动js代码
在没结合css3的transform实现平滑过渡前,我都是用的jquery的animate方法,此方法在PC端基本看不出来有稍微卡顿的现象,但是在性能不高的手机上使用该方法,就会有明显的卡顿现象,不够 ...
- iscroll双重滚动,向上滚动隐藏一部分,下拉后显示
最近项目需求:下面是页面,当用户向上滚动时候,[隐藏的]部分也向上滚动直至消失,这时候[标题]和[搜索框]在最顶部,而[内部的]可以继续滚动,而当[内部的]滚动到最顶部时候,也就是[这个是内部1]时候 ...
- js判断鼠标向上滚动并浮动导航
<div id="Jnav"> <ul class="nav"> <li><a href="#"& ...
随机推荐
- YUV与像素值之间的关系
一幅彩色图像的基本要素是什么? 说白了,一幅图像包括的基本东西就是二进制数据,其容量大小实质即为二进制数据的多少.一幅1920x1080像素的YUV422的图像,大小是1920X1080X2=4147 ...
- 《实时控制软件设计》第一周作业 欧梓峰 U201317662 (更新)
CNC 插补计算程序分析 前言:插补(Interpolation),即机床数控系统依照一定方法确定刀具运动轨迹的过程.一般是已知起点坐标.终点坐标和轨迹,由数控插补计算程序实时的算出各个中间的坐标来拟 ...
- ASP.Net一键自动化更新代码、编译、合并dll、压缩js、css、混淆dll、zip打包、发布到测试环境的bat批处理
不废话,直接代码: D: cd D:\src\testproj\PrecompiledWeb svn revert ../ -R svn update .. rmdir BS /S /Q C:\Win ...
- 给Source Insight做个外挂系列之三--构建外挂软件的定制代码框架
上一篇文章介绍了“TabSiPlus”是如何进行代码注入的,本篇将介绍如何构建一个外挂软件最重要的部分,也就是为其扩展功能的定制代码.本文前面提到过,由于windows进程管理的限制,扩展代码必须以动 ...
- Qt动画效果展示(文艺IT男)
该程序使用应用程序单窗口,主窗口继承于QMainWindow:主窗口有5个QToolButton部件(窗口底部的四个以及窗口中央的一个),单击窗口底部的QToolButton部件可以使窗口中央的那个Q ...
- 在命令行下使用perl
http://blog.sina.com.cn/s/blog_4af3f0d20100g9oz.html aaa@domain.com 2aaa@domain.com 111bbb@home.com ...
- oracle 参考
create or replace function fun_try(v_name varchar,v_outname out varchar)return varchar2 is Result va ...
- angularJs之service
自定义服务: 方法一:controller中返回值,service中return <!DOCTYPE html> <html> <head> <meta ch ...
- linq操作文件方法
备忘 string directory = Environment.GetFolderPath(Environment.SpecialFolder.MyDocuments); List<File ...
- mac常用的命令
1.递归查找⽂文件内容: grep -r target_string absolute_path 2.移动所有⽂文件(包括隐藏⽂文件): mv * .[^.]* targetDir 3.⽂文件分割合并 ...