热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

位子|间隔时间_BannerViewAndroid只一个方向

篇首语:本文由编程笔记#小编为大家整理,主要介绍了BannerView Android 只一个方向相关的知识,希望对你有一定的参考价值。 居中 LAYOUT_MODE_CENTER 顶部 LAYOU

篇首语:本文由编程笔记#小编为大家整理,主要介绍了BannerView Android 只一个方向相关的知识,希望对你有一定的参考价值。



居中 LAYOUT_MODE_CENTER


顶部 LAYOUT_MODE_TOP


底部 LAYOUT_MODE_BOTTOM


右往左布局 LAYOUT_RIGHT_TO_LEFT


BannerView

package com.example.bannerdemo;
import android.animation.Animator;
import android.animation.ValueAnimator;
import android.content.Context;
import android.util.AttributeSet;
import android.util.Log;
import android.view.MotionEvent;
import android.view.View;
import android.view.ViewGroup;
import android.view.animation.DecelerateInterpolator;
import android.view.animation.Interpolator;
public class BannerView extends ViewGroup implements Runnable
private final float SCALE_0 = 0.833333333333f;
private final float SCALE_1 = 0.916666667f;
private final float SCALE_2 = 1f;
private final float ALPHA_0 = 0.4f;
private final float ALPHA_1 = 0.8f;
private final float ALPHA_2 = 1.0f;
private final int DEFAULT_BASELINE = 30;
// index=0 child baseline
private int BASELINE_0 = 0;
// index=1 child baseline
private int BASELINE_1 = 0;
// index=2 child baseline
private int BASELINE_2 = 0;
//动画间隔时间
private int waitTime=1000;
// 只能向左滑动
private final int SCROLL_ORIENTATION_LEFT = 0;
// 只能向右滑动
private final int SCROLL_ORIENTATION_RIGHT = 1;
// 双向滑动
private final int SCROLL_ORIENTATION_ALL = 2;
private final int LAYOUT_MODE_TOP = 0;
private final int LAYOUT_MODE_CENTER = 1;
private final int LAYOUT_MODE_BOTTOM = 2;
private final int LAYOUT_LEFT_TO_RIGHT = 3;
private final int LAYOUT_RIGHT_TO_LEFT = 4;
// 布局模式
int layoutMode = LAYOUT_MODE_CENTER;
// 布局方向
int layoutOrientation = LAYOUT_LEFT_TO_RIGHT;
// 滑动方向
int scrollOrientation = SCROLL_ORIENTATION_LEFT;
// baseLine offset 子view偏移量
int baseLineOffset = DEFAULT_BASELINE;
// 最上面的左边距
int topLeftBaseLine = 0;
//item 点击事件
private OnItemClickListener onItemClickListener;
public BannerView(Context context)
this(context, null);

public BannerView(Context context, AttributeSet attrs)
this(context, attrs, 0);

public BannerView(Context context, AttributeSet attrs, int defStyleAttr)
super(context, attrs, defStyleAttr);
init();

private void init()

@Override
protected void onMeasure(int widthMeasureSpec, int heightMeasureSpec)
measureChildren(widthMeasureSpec, heightMeasureSpec);
setMeasuredDimension(measureWidth(widthMeasureSpec), measureHeight(heightMeasureSpec));

@Override
protected void onLayout(boolean changed, int l, int t, int r, int b)
for (int i &#61; 0; i < getChildCount(); i&#43;&#43;)
View child &#61; getChildAt(i);
int baseLeftLine &#61; getBaseLeftLine(child);
getBaseTopLine(i);
layoutChild(child, baseLeftLine);
if (i &#61;&#61; 2)
child.setOnClickListener(new OnClickListener()
&#64;Override
public void onClick(View v)
if (onItemClickListener !&#61; null)
LayoutParams lp &#61; (LayoutParams) child.getLayoutParams();
onItemClickListener.onItemClick(lp.dataPosition);


);
else
child.setOnClickListener(null);



private int getBaseLeftLine(View child)
LayoutParams lp &#61; (LayoutParams) child.getLayoutParams();
int baseLine &#61; 0;
switch (lp.fromIndex)
case 0:
if (mOffsetPercent > 0)
baseLine &#61; (int) (BASELINE_0 - mOffsetPercent * BASELINE_1);
if (baseLine < BASELINE_1)
baseLine &#61; BASELINE_1;

lp.scale &#61; (float) (SCALE_0 &#43; ((SCALE_1 - SCALE_0) * mOffsetPercent));
if (lp.scale > SCALE_1)
lp.scale &#61; SCALE_1;

else
baseLine &#61; (int) (BASELINE_0 &#43; mOffsetPercent * BASELINE_1);
if (baseLine < BASELINE_1)
baseLine &#61; BASELINE_1;

lp.scale &#61; (float) (SCALE_0 - ((SCALE_1 - SCALE_0) * mOffsetPercent));
if (lp.scale > SCALE_1)
lp.scale &#61; SCALE_1;


break;
case 1:
// toIndex&#61;2
if (mOffsetPercent > 0)
baseLine &#61; (int) (BASELINE_1 - mOffsetPercent * BASELINE_1);
if (baseLine < BASELINE_2)
baseLine &#61; BASELINE_2;

lp.scale &#61; (float) (SCALE_1 &#43; ((SCALE_2 - SCALE_1) * mOffsetPercent));
if (lp.scale > SCALE_2)
lp.scale &#61; SCALE_2;

lp.alpha &#61; (float) (ALPHA_1 &#43; ((ALPHA_2 - ALPHA_1) * mOffsetPercent));
if (lp.alpha > ALPHA_2)
lp.alpha &#61; ALPHA_2;

else
baseLine &#61; (int) (BASELINE_1 &#43; mOffsetPercent * BASELINE_1);
if (baseLine < BASELINE_2)
baseLine &#61; BASELINE_2;

lp.scale &#61; (float) (SCALE_1 - ((SCALE_2 - SCALE_1) * mOffsetPercent));
if (lp.scale > SCALE_2)
lp.scale &#61; SCALE_2;

lp.alpha &#61; (float) (ALPHA_1 - ((ALPHA_2 - ALPHA_1) * mOffsetPercent));
if (lp.alpha > ALPHA_2)
lp.alpha &#61; ALPHA_2;


break;
case 2:
// toIndex&#61; 0
if (mOffsetPercent > 0)
baseLine &#61; (int) (BASELINE_2 &#43; mOffsetPercent * BASELINE_0);
if (baseLine >&#61; BASELINE_0)
baseLine &#61; BASELINE_0;
else
baseLine &#61; (int) (BASELINE_2 &#43; mOffsetPercent * child.getWidth());

lp.scale &#61; (float) (SCALE_2 - ((SCALE_2 - SCALE_0) * mOffsetPercent));
if (lp.scale <&#61; SCALE_0)
lp.scale &#61; SCALE_0;
else
lp.scale &#61; SCALE_2;

lp.alpha &#61; (float) (ALPHA_2 - ((ALPHA_2 - ALPHA_0) * mOffsetPercent));
if (lp.alpha >&#61; ALPHA_0)
lp.alpha &#61; ALPHA_0;
else
lp.alpha &#61; ALPHA_2;

else
baseLine &#61; (int) (BASELINE_2 &#43; mOffsetPercent * BASELINE_0);
if (baseLine >&#61; BASELINE_0)
baseLine &#61; BASELINE_0;
else
baseLine &#61; (int) (BASELINE_2 &#43; mOffsetPercent * child.getWidth());

lp.scale &#61; (float) (SCALE_2 &#43; ((SCALE_2 - SCALE_0) * mOffsetPercent));
if (lp.scale <&#61; SCALE_0)
lp.scale &#61; SCALE_0;
else
lp.scale &#61; SCALE_2;

lp.alpha &#61; (float) (ALPHA_2 &#43; ((ALPHA_2 - ALPHA_0) * mOffsetPercent));
if (lp.alpha <&#61; ALPHA_0)
lp.alpha &#61; ALPHA_0;
else
lp.alpha &#61; ALPHA_2;


break;

return baseLine;

private int getBaseTopLine(int index)
int baseLine &#61; 0;
switch (index)
case 0:
baseLine &#61; 40;
break;
case 1:
baseLine &#61; 20;
break;
case 2:
baseLine &#61; 0;
break;

return baseLine;

private void layoutChild(View child, int baseLeftLine)
LayoutParams lp &#61; (LayoutParams) child.getLayoutParams();
child.setAlpha(lp.alpha);
int childWidth &#61; child.getMeasuredWidth();
int childHeight &#61; (int) (child.getMeasuredHeight() * lp.scale);
int top &#61; 0;
int bottom &#61; 0;
if (layoutMode &#61;&#61; LAYOUT_MODE_CENTER)
top &#61; (int) (getHeight() / 2.0f - childHeight / 2.0f);
bottom &#61; (int) (getHeight() / 2.0f &#43; childHeight / 2.0f);
else if (layoutMode &#61;&#61; LAYOUT_MODE_BOTTOM)
top &#61; getHeight() - childHeight;
bottom &#61; getHeight();
else if (layoutMode &#61;&#61; LAYOUT_MODE_TOP)
top &#61; 0;
bottom &#61; childHeight;

int left &#61; 0;
int right &#61; 0;
if (layoutOrientation &#61;&#61; LAYOUT_LEFT_TO_RIGHT)
left &#61; baseLeftLine;
right &#61; left &#43; childWidth;
else if (layoutOrientation &#61;&#61; LAYOUT_RIGHT_TO_LEFT)
right &#61; getWidth() - baseLeftLine;
left &#61; right - childWidth;

child.layout(left &#43; lp.leftMargin, top &#43; lp.topMargin, right &#43; lp.rightMargin, bottom &#43; lp.bottomMargin);

private int measureWidth(int widthMeasureSpec)
int width &#61; 0;
int mode &#61; MeasureSpec.getMode(widthMeasureSpec);
int size &#61; MeasureSpec.getSize(widthMeasureSpec);
if (mode &#61;&#61; MeasureSpec.EXACTLY)
width &#61; size;
else
int maxChildWidth &#61; 0;
for (int i &#61; 0; i < getChildCount(); i&#43;&#43;)
View child &#61; getChildAt(i);
LayoutParams layoutParams &#61; (LayoutParams) child.getLayoutParams();
maxChildWidth &#61; Math.max(maxChildWidth, child.getMeasuredWidth() &#43; layoutParams.leftMargin &#43; layoutParams.rightMargin);

width &#61; maxChildWidth &#43; 60;

return width;

private int measureHeight(int heightMeasureSpec)
int height &#61; 0;
int mode &#61; MeasureSpec.getMode(heightMeasureSpec);
int size &#61; MeasureSpec.getSize(heightMeasureSpec);
if (mode &#61;&#61; MeasureSpec.EXACTLY)
height &#61; size;
else
int maxChildHeight &#61; 0;
for (int i &#61; 0; i < getChildCount(); i&#43;&#43;)
View child &#61; getChildAt(i);
LayoutParams layoutParams &#61; (LayoutParams) child.getLayoutParams();
maxChildHeight &#61; Math.max(maxChildHeight, child.getMeasuredHeight() &#43; layoutParams.topMargin &#43; layoutParams.bottomMargin);

height &#61; maxChildHeight;

return height;

&#64;Override
public void addView(View child, int index, ViewGroup.LayoutParams params)
if (index > 2)
return;

LayoutParams lp &#61; params instanceof LayoutParams ? (LayoutParams) params : new LayoutParams(params);
lp.fromIndex &#61; index;
switch (index)
case 0:
lp.scale &#61; SCALE_0;
lp.alpha &#61; ALPHA_0;
BASELINE_0 &#61; baseLineOffset * 2;
break;
case 1:
lp.scale &#61; SCALE_1;
lp.alpha &#61; ALPHA_1;
BASELINE_1 &#61; bas

推荐阅读
  • 本文讨论了一个关于cuowu类的问题,作者在使用cuowu类时遇到了错误提示和使用AdjustmentListener的问题。文章提供了16个解决方案,并给出了两个可能导致错误的原因。 ... [详细]
  • Java太阳系小游戏分析和源码详解
    本文介绍了一个基于Java的太阳系小游戏的分析和源码详解。通过对面向对象的知识的学习和实践,作者实现了太阳系各行星绕太阳转的效果。文章详细介绍了游戏的设计思路和源码结构,包括工具类、常量、图片加载、面板等。通过这个小游戏的制作,读者可以巩固和应用所学的知识,如类的继承、方法的重载与重写、多态和封装等。 ... [详细]
  • android listview OnItemClickListener失效原因
    最近在做listview时发现OnItemClickListener失效的问题,经过查找发现是因为button的原因。不仅listitem中存在button会影响OnItemClickListener事件的失效,还会导致单击后listview每个item的背景改变,使得item中的所有有关焦点的事件都失效。本文给出了一个范例来说明这种情况,并提供了解决方法。 ... [详细]
  • Java容器中的compareto方法排序原理解析
    本文从源码解析Java容器中的compareto方法的排序原理,讲解了在使用数组存储数据时的限制以及存储效率的问题。同时提到了Redis的五大数据结构和list、set等知识点,回忆了作者大学时代的Java学习经历。文章以作者做的思维导图作为目录,展示了整个讲解过程。 ... [详细]
  • 欢乐的票圈重构之旅——RecyclerView的头尾布局增加
    项目重构的Git地址:https:github.comrazerdpFriendCircletreemain-dev项目同步更新的文集:http:www.jianshu.comno ... [详细]
  • Android系统源码分析Zygote和SystemServer启动过程详解
    本文详细解析了Android系统源码中Zygote和SystemServer的启动过程。首先介绍了系统framework层启动的内容,帮助理解四大组件的启动和管理过程。接着介绍了AMS、PMS等系统服务的作用和调用方式。然后详细分析了Zygote的启动过程,解释了Zygote在Android启动过程中的决定作用。最后通过时序图展示了整个过程。 ... [详细]
  • 基于Socket的多个客户端之间的聊天功能实现方法
    本文介绍了基于Socket的多个客户端之间实现聊天功能的方法,包括服务器端的实现和客户端的实现。服务器端通过每个用户的输出流向特定用户发送消息,而客户端通过输入流接收消息。同时,还介绍了相关的实体类和Socket的基本概念。 ... [详细]
  • 本文介绍了MVP架构模式及其在国庆技术博客中的应用。MVP架构模式是一种演变自MVC架构的新模式,其中View和Model之间的通信通过Presenter进行。相比MVC架构,MVP架构将交互逻辑放在Presenter内部,而View直接从Model中读取数据而不是通过Controller。本文还探讨了MVP架构在国庆技术博客中的具体应用。 ... [详细]
  • 如何自行分析定位SAP BSP错误
    The“BSPtag”Imentionedintheblogtitlemeansforexamplethetagchtmlb:configCelleratorbelowwhichi ... [详细]
  • Iamtryingtomakeaclassthatwillreadatextfileofnamesintoanarray,thenreturnthatarra ... [详细]
  • JavaSE笔试题-接口、抽象类、多态等问题解答
    本文解答了JavaSE笔试题中关于接口、抽象类、多态等问题。包括Math类的取整数方法、接口是否可继承、抽象类是否可实现接口、抽象类是否可继承具体类、抽象类中是否可以有静态main方法等问题。同时介绍了面向对象的特征,以及Java中实现多态的机制。 ... [详细]
  • 本文介绍了Android 7的学习笔记总结,包括最新的移动架构视频、大厂安卓面试真题和项目实战源码讲义。同时还分享了开源的完整内容,并提醒读者在使用FileProvider适配时要注意不同模块的AndroidManfiest.xml中配置的xml文件名必须不同,否则会出现问题。 ... [详细]
  • Java学习笔记之面向对象编程(OOP)
    本文介绍了Java学习笔记中的面向对象编程(OOP)内容,包括OOP的三大特性(封装、继承、多态)和五大原则(单一职责原则、开放封闭原则、里式替换原则、依赖倒置原则)。通过学习OOP,可以提高代码复用性、拓展性和安全性。 ... [详细]
  • 本文整理了Java面试中常见的问题及相关概念的解析,包括HashMap中为什么重写equals还要重写hashcode、map的分类和常见情况、final关键字的用法、Synchronized和lock的区别、volatile的介绍、Syncronized锁的作用、构造函数和构造函数重载的概念、方法覆盖和方法重载的区别、反射获取和设置对象私有字段的值的方法、通过反射创建对象的方式以及内部类的详解。 ... [详细]
  • Netty源代码分析服务器端启动ServerBootstrap初始化
    本文主要分析了Netty源代码中服务器端启动的过程,包括ServerBootstrap的初始化和相关参数的设置。通过分析NioEventLoopGroup、NioServerSocketChannel、ChannelOption.SO_BACKLOG等关键组件和选项的作用,深入理解Netty服务器端的启动过程。同时,还介绍了LoggingHandler的作用和使用方法,帮助读者更好地理解Netty源代码。 ... [详细]
author-avatar
hanhan2502883243
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有