Android仿智聯(lián)詳情

很久沒有發(fā)文章了测蘑,這一年多一直在卷灌危。最近由于疫情的原因,很多公司都在給員工發(fā)“畢業(yè)證”碳胳,我也很榮幸拿到了“畢業(yè)證”勇蝙。不知道是應該開心還是桑心,北京最近因為疫情基本都居家辦公固逗,而我也開始了做簡歷浅蚪,刷面試題的道路。??

最近在投簡歷的時候發(fā)現(xiàn)智聯(lián)招聘的公司詳情頁設計的很有意思烫罩,雖然很簡單惜傲,但是也忍不住仿一下,

智聯(lián)的效果


zhilian.gif

仿的效果(基本效果一致)


custom.gif

效果需求分析:
1贝攒、剛進入界面時盗誊,“在招職位”布局在底部露頭,并距離屏幕左邊一半屏幕寬度的距離隘弊。
2哈踱、當詳情滑動到最底部,然后再向上滑動時梨熙,展開“在招職位”布局开镣。
3、“在招職位”布局支持手勢拖動咽扇,向上時布局距離屏幕左邊越來越近(最終距離屏幕左邊距離為0)邪财,向下時布局距離越來越遠(最終是屏幕的寬度的一半)陕壹。

根據(jù)上面的分析,主要的功能其實就是這個“在招職位”布局的收起和展開树埠,默認收起糠馆,然后手勢控制展開。說到這里其實我們就知道如何實現(xiàn)了怎憋,那就是behavior又碌,它默認已經(jīng)給我們處理了收起展開狀態(tài)及拖動操作,我們只需要監(jiān)聽拖動和狀態(tài)來設置布局的位置變化就可以了绊袋。開干~

為了省事底部布局我就直接截圖放到布局了

XML

<?xml version="1.0" encoding="utf-8"?>
<androidx.coordinatorlayout.widget.CoordinatorLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:background="#0099cc">
    <androidx.core.widget.NestedScrollView
        android:id="@+id/scrollview"
        android:layout_width="match_parent"
        android:layout_height="wrap_content">
        <androidx.appcompat.widget.AppCompatImageView
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            android:adjustViewBounds="true"
            app:srcCompat="@drawable/icon_detail_zhilian" />
    </androidx.core.widget.NestedScrollView>
    <androidx.appcompat.widget.LinearLayoutCompat
        android:id="@+id/bottom_sheet"
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:orientation="vertical"
        android:paddingTop="50dp"
        android:visibility="visible"
        app:behavior_hideable="true"
        app:behavior_peekHeight="110dp"
        app:layout_behavior="@string/bottom_sheet_behavior"
        tools:ignore="MissingPrefix">

        <androidx.constraintlayout.widget.ConstraintLayout
            android:layout_width="match_parent"
            android:layout_height="60dp"
            android:background="@drawable/shape_header">

            <androidx.appcompat.widget.AppCompatTextView
                android:id="@+id/layout_bottom_sheet"
                android:layout_width="wrap_content"
                android:layout_height="wrap_content"
                android:layout_alignParentBottom="true"
                android:gravity="center"
                android:orientation="vertical"
                android:text="在招職位-54個"
                android:textColor="@android:color/black"
                android:textSize="14sp"
                android:layout_margin="24dp"
                app:layout_constraintLeft_toLeftOf="parent"
                app:layout_constraintTop_toTopOf="parent" />

            <androidx.appcompat.widget.AppCompatImageView
                android:id="@+id/drag"
                android:layout_width="16dp"
                android:layout_height="16dp"
                android:layout_margin="8dp"
                app:layout_constraintLeft_toLeftOf="parent"
                app:layout_constraintTop_toTopOf="parent"
                app:srcCompat="@mipmap/ic_launcher_round" />
        </androidx.constraintlayout.widget.ConstraintLayout>
        <androidx.recyclerview.widget.RecyclerView
            android:id="@+id/recyclerview"
            android:layout_width="match_parent"
            android:layout_height="wrap_content" />
    </androidx.appcompat.widget.LinearLayoutCompat>
</androidx.coordinatorlayout.widget.CoordinatorLayout>

Activity

package com.study.fangdemo.zhilian

import android.os.Bundle
import android.view.MotionEvent
import android.view.View
import android.view.ViewConfiguration
import android.view.ViewGroup.MarginLayoutParams
import androidx.appcompat.app.AppCompatActivity
import androidx.core.view.isVisible
import com.google.android.material.bottomsheet.BottomSheetBehavior
import com.google.android.material.bottomsheet.BottomSheetBehavior.*
import com.study.fangdemo.databinding.ActivityMainBinding
import com.study.fangdemo.utils.RecyclerDataUtils


class ZhiLianActivity : AppCompatActivity() {
    private var binding: ActivityMainBinding? = null
    override fun onCreate(savedInstanceState: Bundle?) {
        super.onCreate(savedInstanceState)
        binding = ActivityMainBinding.inflate(layoutInflater)
        setContentView(binding?.root)
        initView()
        initListener()

    }

    private fun initListener() {
        val behavior = from(binding!!.bottomSheet)
        behavior?.addBottomSheetCallback(object : BottomSheetBehavior.BottomSheetCallback() {
            override fun onStateChanged(bottomSheet: View, newState: Int) {
                //左邊圖標顯示
                binding?.drag?.isVisible = true
                when (newState) {
                    STATE_DRAGGING -> {}
                    STATE_SETTLING -> {}
                    STATE_EXPANDED -> {
                        //展開狀態(tài)時隱藏左邊圖標
                        binding?.drag?.isVisible = false
                    }
                    STATE_COLLAPSED -> {}
                    STATE_HIDDEN -> {}
                    STATE_HALF_EXPANDED -> {}
                }
            }

            override fun onSlide(bottomSheet: View, slideOffset: Float) {
                val width = windowManager.defaultDisplay.width
                val margin = ((0.5 - slideOffset / 2) * width).toInt()
                margin(bottomSheet, margin)
            }
        })

        //詳情滑動到底部 再往上滑動時展開
        binding?.scrollview?.setOnTouchListener(object : View.OnTouchListener {
            var startX: Float = 0.0f
            var startY: Float = 0.0f
            var offsetX: Float = 0.0f
            var offsetY: Float = 0.0f
            var touchSlop = ViewConfiguration.get(baseContext).scaledTouchSlop
            override fun onTouch(view: View?, event: MotionEvent?): Boolean {
                when (event?.action) {
                    MotionEvent.ACTION_DOWN -> {
                        startX = event.x
                        startY = event.y

                    }
                    MotionEvent.ACTION_UP -> {
                        offsetX = event.x - startX
                        offsetY = event.y - startY
                        if (Math.abs(offsetX) > Math.abs(offsetY)) {
                            // left
                            if (offsetX < -touchSlop) {

                            }
                            // right
                            else if (offsetX > touchSlop) {
                            }
                        } else {
                            // up
                            if (offsetY < -touchSlop) {
                                if (isScrollViewEnd()) {
                                    behavior.state = STATE_EXPANDED
                                }
                            }
                            // down
                            else if (offsetY > touchSlop) {
                            }
                        }
                    }
                }
                return false
            }

        })

    }

    /**
     * NestedScrollView 是否滾動到底部
     */
    private fun isScrollViewEnd(): Boolean {
        binding?.apply {
            var scrollY = scrollview?.scrollY
            var onlyChild = scrollview?.getChildAt(0)
            if (onlyChild?.height!! <= (scrollY!! + scrollview?.height!!)) {
                return true
            }
        }
        return false
    }

    private fun initView() {
        binding?.apply {
            //設置測試列表數(shù)據(jù)
            RecyclerDataUtils.setRecyclerAdater(baseContext, recyclerview, "測試數(shù)據(jù)", 30)

            //設置屏幕寬
            bottomSheet?.post {
                val params = bottomSheet.layoutParams
                params.width = windowManager.defaultDisplay.width
                bottomSheet.layoutParams = params
            }

            //默認外左邊距是屏幕寬度一半
            margin(bottomSheet, windowManager.defaultDisplay.width / 2)
        }

    }

    /**
     * 設置左邊Margin
     */
    private fun margin(v: View, l: Int) {
        if (v.layoutParams is MarginLayoutParams) {
            val p = v.layoutParams as MarginLayoutParams
            p.leftMargin = l
            v.requestLayout()
        }
    }
}

代碼其實還是比較少的毕匀,其實主要是通過監(jiān)聽拖動來設置“在招職位”布局距離左邊的margin值就可以了,希望能對新入手的同學有點幫助愤炸,我也算復習了下期揪。

具體的測試APK可以通過這個鏈接測試下:
http://d.firim.pro/7by9

github:https://github.com/yixiaolunhui/FangDemo

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市规个,隨后出現(xiàn)的幾起案子凤薛,更是在濱河造成了極大的恐慌,老刑警劉巖诞仓,帶你破解...
    沈念sama閱讀 212,454評論 6 493
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件缤苫,死亡現(xiàn)場離奇詭異,居然都是意外死亡墅拭,警方通過查閱死者的電腦和手機活玲,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,553評論 3 385
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來谍婉,“玉大人舒憾,你說我怎么就攤上這事∷氚荆” “怎么了镀迂?”我有些...
    開封第一講書人閱讀 157,921評論 0 348
  • 文/不壞的土叔 我叫張陵,是天一觀的道長唤蔗。 經(jīng)常有香客問我探遵,道長,這世上最難降的妖魔是什么妓柜? 我笑而不...
    開封第一講書人閱讀 56,648評論 1 284
  • 正文 為了忘掉前任箱季,我火速辦了婚禮,結(jié)果婚禮上棍掐,老公的妹妹穿的比我還像新娘藏雏。我一直安慰自己,他們只是感情好作煌,可當我...
    茶點故事閱讀 65,770評論 6 386
  • 文/花漫 我一把揭開白布诉稍。 她就那樣靜靜地躺著蝠嘉,像睡著了一般。 火紅的嫁衣襯著肌膚如雪杯巨。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 49,950評論 1 291
  • 那天努酸,我揣著相機與錄音服爷,去河邊找鬼。 笑死获诈,一個胖子當著我的面吹牛仍源,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播舔涎,決...
    沈念sama閱讀 39,090評論 3 410
  • 文/蒼蘭香墨 我猛地睜開眼笼踩,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了亡嫌?” 一聲冷哼從身側(cè)響起嚎于,我...
    開封第一講書人閱讀 37,817評論 0 268
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎挟冠,沒想到半個月后于购,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 44,275評論 1 303
  • 正文 獨居荒郊野嶺守林人離奇死亡知染,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 36,592評論 2 327
  • 正文 我和宋清朗相戀三年肋僧,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片控淡。...
    茶點故事閱讀 38,724評論 1 341
  • 序言:一個原本活蹦亂跳的男人離奇死亡嫌吠,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出掺炭,到底是詐尸還是另有隱情辫诅,我是刑警寧澤,帶...
    沈念sama閱讀 34,409評論 4 333
  • 正文 年R本政府宣布竹伸,位于F島的核電站泥栖,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏勋篓。R本人自食惡果不足惜吧享,卻給世界環(huán)境...
    茶點故事閱讀 40,052評論 3 316
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望譬嚣。 院中可真熱鬧钢颂,春花似錦、人聲如沸拜银。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,815評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至操灿,卻和暖如春锯仪,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背趾盐。 一陣腳步聲響...
    開封第一講書人閱讀 32,043評論 1 266
  • 我被黑心中介騙來泰國打工庶喜, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人救鲤。 一個月前我還...
    沈念sama閱讀 46,503評論 2 361
  • 正文 我出身青樓久窟,卻偏偏與公主長得像,于是被迫代替她去往敵國和親本缠。 傳聞我的和親對象是個殘疾皇子斥扛,可洞房花燭夜當晚...
    茶點故事閱讀 43,627評論 2 350