android 上下自动滚动效果,Android自定义View实现广告信息上下滚动效果

先看看效果:

1271ce42f21ac873f6238458307dbd39.gif

实现代码:

public class ScrollBanner extends LinearLayout {

private TextView mBannerTV1;

private TextView mBannerTV2;

private Handler handler;

private boolean isShow;

private int startY1, endY1, startY2, endY2;

private Runnable runnable;

private List list;

private int position = 0;

private int offsetY = 100;

public ScrollBanner(Context context) {

this(context, null);

}

public ScrollBanner(Context context, AttributeSet attrs) {

this(context, attrs, 0);

}

public ScrollBanner(Context context, AttributeSet attrs, int defStyleAttr) {

super(context, attrs, defStyleAttr);

View view = LayoutInflater.from(context).inflate(R.layout.view_scroll_banner, this);

mBannerTV1 = (TextView) view.findViewById(R.id.tv_banner1);

mBannerTV2 = (TextView) view.findViewById(R.id.tv_banner2);

handler = new Handler();

runnable = new Runnable() {

@Override

public void run() {

isShow = !isShow;

if (position == list.size())

position = 0;

if (isShow) {

mBannerTV1.setText(list.get(position++));

} else {

mBannerTV2.setText(list.get(position++));

}

startY1 = isShow ? 0 : offsetY;

endY1 = isShow ? -offsetY : 0;

ObjectAnimator.ofFloat(mBannerTV1, "translationY", startY1, endY1).setDuration(300).start();

startY2 = isShow ? offsetY : 0;

endY2 = isShow ? 0 : -offsetY;

ObjectAnimator.ofFloat(mBannerTV2, "translationY", startY2, endY2).setDuration(300).start();

handler.postDelayed(runnable, 3000);

}

};

}

public List getList() {

return list;

}

public void setList(List list) {

this.list = list;

}

public void startScroll() {

handler.post(runnable);

}

public void stopScroll() {

handler.removeCallbacks(runnable);

}

}

view_scroll_banner.xml:

android:layout_width="match_parent"

android:layout_height="match_parent"

android:orientation="horizontal"

android:padding="10dp">

android:id="@+id/tv_title"

android:layout_width="wrap_content"

android:layout_height="wrap_content"

android:layout_centerVertical="true"

android:text="公告"

android:textColor="#e76712"

android:textSize="16sp" />

android:id="@+id/view_divider"

android:layout_width="1dp"

android:layout_height="match_parent"

android:layout_marginLeft="10dp"

android:layout_marginRight="10dp"

android:layout_toRightOf="@id/tv_title"

android:background="#DDDDDD" />

android:id="@+id/tv_banner1"

android:layout_width="match_parent"

android:layout_height="wrap_content"

android:layout_centerVertical="true"

android:layout_toRightOf="@+id/view_divider"

android:ellipsize="end"

android:singleLine="true"

android:text="热烈欢迎领导光临" />

android:id="@+id/tv_banner2"

android:layout_width="match_parent"

android:layout_height="wrap_content"

android:layout_centerVertical="true"

android:layout_toRightOf="@+id/view_divider"

android:ellipsize="end"

android:singleLine="true"

android:text="喜庆国庆欢乐大酬宾" />

使用方法:

scrollBanner.setList(list);

scrollBanner.startScroll();

以上就是本文的全部内容,希望对大家学习Android软件编程有所帮助,也希望大家多多支持脚本之家。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
实现弧形滚动和中间缩小的效果需要自定义LayoutManager。具体步骤如下: 1. 继承LinearLayoutManager,重写calculateExtraLayoutSpace方法,将多余空间分配给中间的item。 ```java public class ArcLayoutManager extends LinearLayoutManager { private float mShrinkAmount = 0.15f; private float mShrinkDistance = 0.9f; private int mVerticalOffset; private Context mContext; public ArcLayoutManager(Context context) { super(context); mContext = context; } @Override protected int calculateExtraLayoutSpace(RecyclerView.State state, int extraLayoutSpace, int[] extraLayoutSpaceInOther) { int height = getHeight(); int width = getWidth(); int itemCount = getItemCount(); int extra = (int) (width * (1 - Math.pow(1 - mShrinkAmount, itemCount))) / 2; return Math.max(extra, extraLayoutSpace); } } ``` 2. 重写scrollVerticallyBy方法,实现滚动时弧形效果。 ```java @Override public int scrollVerticallyBy(int dy, RecyclerView.Recycler recycler, RecyclerView.State state) { int scrolled = super.scrollVerticallyBy(dy, recycler, state); mVerticalOffset += scrolled; float midpoint = getHeight() / 2.f; float d0 = 0.f; float d1 = mShrinkDistance * midpoint; float s0 = 1.f; float s1 = 1.f - mShrinkAmount; for (int i = 0; i < getChildCount(); i++) { View child = getChildAt(i); float childMidpoint = (getDecoratedBottom(child) + getDecoratedTop(child)) / 2.f; float d = Math.min(d1, Math.abs(midpoint - childMidpoint)); float scale = s0 + (s1 - s0) * (d - d0) / (d1 - d0); child.setScaleX(scale); child.setScaleY(scale); } return scrolled; } ``` 3. 在LayoutManager中重写generateDefaultLayoutParams方法,设置item的宽高。 ```java @Override public RecyclerView.LayoutParams generateDefaultLayoutParams() { return new RecyclerView.LayoutParams(ViewGroup.LayoutParams.WRAP_CONTENT, ViewGroup.LayoutParams.WRAP_CONTENT); } ``` 4. 在RecyclerView中设置LayoutManager为自定义的ArcLayoutManager。 ```java recyclerView.setLayoutManager(new ArcLayoutManager(this)); ``` 5. 最后,在RecyclerView的Adapter中为item设置宽高和布局参数。 ```java @Override public void onBindViewHolder(@NonNull ViewHolder holder, int position) { ViewGroup.LayoutParams layoutParams = holder.itemView.getLayoutParams(); layoutParams.width = (int) (mContext.getResources().getDisplayMetrics().widthPixels * 0.7f); layoutParams.height = (int) (layoutParams.width * 1.2f); holder.itemView.setLayoutParams(layoutParams); } ``` 这样,就可以实现弧形滚动和中间缩小的效果了。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值