Android 固定式底部上滑抽屉view,2024年最新面试完整版

先自我介绍一下,小编浙江大学毕业,去过华为、字节跳动等大厂,目前阿里P7

深知大多数程序员,想要提升技能,往往是自己摸索成长,但自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

因此收集整理了一份《2024年最新Android移动开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友。
img
img
img
img
img
img
img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,涵盖了95%以上Android开发知识点,真正体系化!

由于文件比较多,这里只是将部分目录截图出来,全套包含大厂面经、学习笔记、源码讲义、实战项目、大纲路线、讲解视频,并且后续会持续更新

如果你需要这些资料,可以添加V获取:vip204888 (备注Android)
img

正文

final int bottomBound = getHeight() - mBottomView.getHeight();

final int newTop = Math.min(Math.max(top, topBound), bottomBound);

return newTop;

}

@Override

public void onViewCaptured(View capturedChild, int activePointerId) {

super.onViewCaptured(capturedChild, activePointerId);

}

@Override

public void onViewReleased(View releasedChild, float xvel, float yvel) {

// Log.i(TAG, “onViewReleased:” + “xvel:” + xvel + “,yvel:” + yvel);

//yvel Fling产生的值,yvel > 0 则是快速往下Fling || yvel < 0 则是快速往上Fling

int top = mParentHeight - mDrawerHeight - mBottomHeight;

if (yvel > 0 || (yvel == 0 && mDragOffset > 0.5f)/* 后面这个小括号里判断处理拖动之后停下来但是未松手的情况 */) {

top += mDrawerHeight;

}

mDragHelper.settleCapturedViewAt(releasedChild.getLeft(), top);

invalidate();//important 不加,就不会刷新View的位置

}

@Override

public void onViewDragStateChanged(int state) {

super.onViewDragStateChanged(state);

}

@Override

public void onViewPositionChanged(View changedView, int left, int top, int dx, int dy) {

mCurTop = top;

mDragOffset = ((float) top -(mParentHeight - mDrawerHeight - mBottomHeight))/ mDrawerHeight;

// Log.d(TAG, “onViewPositionChanged: mDragOffset:” + mDragOffset);

//旋转与透明跟随效果

mDrawerView.setAlpha(1-mDragOffset);

// mRotateView.setRotation((1-mDragOffset)*180);

requestLayout();

if (onDrawerStatusChanged != null) {

onDrawerStatusChanged.onChanged(mParentHeight,top);

}

// if(onDrawerStatusChanged !=null){

// if(mDragOffset == 0 || mDragOffset == 1){

// onDrawerStatusChanged.onChanged(mParentHeight,top);

// }

// }

}

}

public interface OnDrawerStatusChanged{

void onChanged(int parentHeight, int drawerTop);

}

public void maximize()

{

smoothSlideTo(0.0f);

}

public void minimize()

{

smoothSlideTo(1.0f);

}

private boolean smoothSlideTo(float slideOffset) {

final int topBound = mParentHeight - mDrawerHeight - mBottomHeight;

int y = (int) (topBound + slideOffset * mDrawerHeight);

if(mDragHelper.smoothSlideViewTo(mDrawerView, mDrawerView.getLeft(), y))

{

ViewCompat.postInvalidateOnAnimation(this);

return true;

}

return false;

}

@Override

public boolean dispatchTouchEvent(MotionEvent ev) {

return super.dispatchTouchEvent(ev);

}

@Override

public boolean onInterceptTouchEvent(MotionEvent event) {

int act = MotionEventCompat.getActionMasked(event);

// final int action = event.getAction();

switch (act) {

//由于很多情况不能拦截事件,这种时候系统不会调用onTouchEvent()

// 手动把事件传递给mDragHelper.processTouchEvent

case MotionEvent.ACTION_DOWN:

mInitialX = event.getX();

mInitialY = event.getY();

//Feed the down event to the detector so it has

// context when/if dragging begins

// mDetector.onTouchEvent(event);

mDragHelper.processTouchEvent(event);

isUnderBottomView = mDragHelper.isViewUnder(mBottomView, (int)mInitialX, (int)mInitialY);

isUnderDrawerView = mDragHelper.isViewUnder(mDrawerView, (int)mInitialX, (int)mInitialY);

break;

case MotionEvent.ACTION_POINTER_DOWN:

mDragHelper.processTouchEvent(event) ;

break;

case MotionEvent.ACTION_POINTER_UP:

mDragHelper.processTouchEvent(event) ;

break;

case MotionEvent.ACTION_MOVE:

final float x = event.getX();

final float y = event.getY();

final int yDiff = (int) Math.abs(y - mInitialY);

final int xDiff = (int) Math.abs(x - mInitialX);

//Verify that either difference is enough to be a drag

if ((yDiff > mTouchSlop || xDiff > mTouchSlop) && (isUnderBottomView || isUnderDrawerView) ){

//Start capturing events

return true;

}

break;

}

//父类是viewgroup,返回的false

return super.onInterceptTouchEvent(event);

}

@Override

public boolean onTouchEvent(MotionEvent event) {

mDragHelper.processTouchEvent(event);

//down事件返回false,让其底部的平行层级的view能够接收到点击事件

switch (event.getAction()) {

case MotionEvent.ACTION_DOWN:

return false;

case MotionEvent.ACTION_UP:

return false;

//只有当手指达到拖动阈值时this才确定消耗此系列事件

//若未达到阈值也返回true,则与其平行的view不会收到click事件

case MotionEvent.ACTION_MOVE:

final float x = event.getX();

final float y = event.getY();

final int yDiff = (int) Math.abs(y - mInitialY);

final int xDiff = (int) Math.abs(x - mInitialX);

//Verify that either difference is enough to be a drag

if ((yDiff > mTouchSlop || xDiff > mTouchSlop) && (isUnderBottomView || isUnderDrawerView) ){

//Start capturing events

return true;

}

break;

}

return false;

}

@Override

protected void onFinishInflate() {

super.onFinishInflate();

mBottomView = findViewById(R.id.layout_bottom_bar);

mDrawerView = findViewById(R.id.layout_price_detail);

// mRotateView = findViewById(R.id.img_spread_out);

mBottomView.setOnClickListener(new OnClickListener() {

@Override

public void onClick(View v) {

maximize();

}

});

mDrawerView.setOnClickListener(new OnClickListener() {

@Override

public void onClick(View v) {

minimize();

}

});

}

@Override

protected void onMeasure(int widthMeasureSpec, int heightMeasureSpec) {

measureChildren(widthMeasureSpec,heightMeasureSpec);

super.onMeasure(widthMeasureSpec, heightMeasureSpec);

}

@Override

protected void onLayout(boolean changed, int l, int t, int r, int b) {

mParentHeight = this.getHeight();

mBottomHeight = mBottomView.getMeasuredHeight();

mDrawerHeight = mDrawerView.getMeasuredHeight();

// Log.d(TAG, “onLayout: drawHeight:”+drawHeight);

mBottomView.layout(l,mParentHeight - mBottomHeight,r,b);

if(mCurTop == -1){

mCurTop = mParentHeight - mBottomHeight;

}

mDrawerView.layout(l,mCurTop,r,mCurTop + mDrawerHeight);

}

@Override

最后

今天关于面试的分享就到这里,还是那句话,有些东西你不仅要懂,而且要能够很好地表达出来,能够让面试官认可你的理解,例如Handler机制,这个是面试必问之题。有些晦涩的点,或许它只活在面试当中,实际工作当中你压根不会用到它,但是你要知道它是什么东西。

最后在这里小编分享一份自己收录整理上述技术体系图相关的几十套腾讯、头条、阿里、美团等公司2021年的面试题,把技术点整理成了视频和PDF(实际上比预期多花了不少精力),包含知识脉络 + 诸多细节,由于篇幅有限,这里以图片的形式给大家展示一部分。

还有 高级架构技术进阶脑图、Android开发面试专题资料,高级进阶架构资料 帮助大家学习提升进阶,也节省大家在网上搜索资料的时间来学习,也可以分享给身边好友一起学习。

【Android核心高级技术PDF文档,BAT大厂面试真题解析】

【算法合集】

【延伸Android必备知识点】

【Android部分高级架构视频学习资源】

Android精讲视频领取学习后更加是如虎添翼!进军BATJ大厂等(备战)!现在都说互联网寒冬,其实无非就是你上错了车,且穿的少(技能),要是你上对车,自身技术能力够强,公司换掉的代价大,怎么可能会被裁掉,都是淘汰末端的业务Curd而已!现如今市场上初级程序员泛滥,这套教程针对Android开发工程师1-6年的人员、正处于瓶颈期,想要年后突破自己涨薪的,进阶Android中高级、架构师对你更是如鱼得水,赶快领取吧!

网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。

需要这份系统化的资料的朋友,可以添加V获取:vip204888 (备注Android)
img

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!

Android精讲视频领取学习后更加是如虎添翼!进军BATJ大厂等(备战)!现在都说互联网寒冬,其实无非就是你上错了车,且穿的少(技能),要是你上对车,自身技术能力够强,公司换掉的代价大,怎么可能会被裁掉,都是淘汰末端的业务Curd而已!现如今市场上初级程序员泛滥,这套教程针对Android开发工程师1-6年的人员、正处于瓶颈期,想要年后突破自己涨薪的,进阶Android中高级、架构师对你更是如鱼得水,赶快领取吧!

网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。

需要这份系统化的资料的朋友,可以添加V获取:vip204888 (备注Android)
[外链图片转存中…(img-P3HSs4vF-1713669915229)]

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!

  • 20
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值