下載本文檔
版權說明:本文檔由用戶提供并上傳,收益歸屬內容提供方,若內容存在侵權,請進行舉報或認領
文檔簡介
1、擰恥和演技井飢拒硼斑剜- jgU不必*4磚歲仍獨守空房20it內地黑房破 m 億比去年WtUiiOO萬簡單使用恥幻的下 Tt 皈齊正住畫母更魏也幵炭當中=啟管 在爺陋車中,很多慨柞苻丼未友生窪代.可現(xiàn) 隸時 It(absHvabr creatiDnh訂冋理(su bEfiptiofimanagement)(hackpressure)林&行 了站氏沏曜堆改迸.在辛決 GOTO Copan 貼鈔A加圧的融演 中,蟲賑將焦訶嵌蟲褲 2 遲行了月神改進,戲段電些 改逍甘聞的犀區(qū)淡將學習*1 誦如何將驚三方躍抑應用 同時違移到取上沖 2 耳申,以段謹帕何在訴介 R*Jp 辟 版客之間亙用環(huán)添加庫
2、依賴dependencies compile com.astuetz:pagerslidingtabstrip:1.0.1 定義布局文件vcom.astuet z. PagerSlidingTabStrip android:id=+id/psts_i ndicatorandroid:layout_width=match_parent android:layout_height=40dp/關聯(lián) ViewPagerpublic class MainActivity extends AppCompatActivity BindView(R.id.psts_indicator)PagerSliding
3、TabStrip從頭到腳fl N% M 28QRflLU*H4RR災吉障挾菁襲201$年竄可確醴獎Android方便的憐移 MtWJ 序詞帶諜記置到遠用岡?UTi#琨非*1 的 D59er2 入門 It 畀,miicSjH瑕陰上蛉藝劃發(fā)趣鞍戰(zhàn)謀力吐權 節(jié)才沒底毎事冰冰過壘渤曬全窩福殊域舷外Jake Wharton 奔 Jff 笊 fif 的 Rx !訂 1 苻:. I - :.:OHFTWOTHIWrvdeclare-styleable name=PagerSlidingTabStripvattr name=pstsIndicatorColor format=color /vattr name
4、=pstsUnderlineColor format=color /vattr name=pstsDividerColor format=color /vattr name=pstslndicatorHeight format=dimension /v!-底部區(qū)域的咼度-vattr name=pstsUnderlineHeight format=dimension /v!-分割線與上下的間距-vattr name=pstsDividerPadding format=dimension /v!-每個 Tab 的左右邊距-vattr name=pstsTabPaddingLeftRight for
5、mat=dimension /v!-選中 tab 的滾動偏移量,個人基本沒有用到過-vattr name=pstsScrollOffset format=dimension /v!-每個 Tab 的背景圖,StateListDrawable-vattr name=pstsTabBackground format=reference /v!-是否根據 tab 均為位置,true 的時候均分,默認為 false,一般都是使用默認值-vattr name=pstsShouldExpand format=boolean /v!-標題文本是否大寫,默認為true-vattr name=pstsTextA
6、IICaps format=boolean /v/declare-styleablev/resources看下犬致的布局和雇性對號入座tablMckgroundetividec diidarpiaddingIndicatorunderhneW! )puj63gquj)puno6v電e門 3 乂比*戶1人丄*戶”丄0 ooM popoixaipe .oPJOA彳比1心譏Pl嚴片QoP5M:ftU!) )*Op丄那Q.o址:Om$A丄見oM*彳料陽/廠丄9,oL 如啊ooqDfV Qo吟ooq彷dnvix* 9ouerooq Jputd*3ppo4$6QoPJOAfuzjoocUpuMqppOii
7、W1ooPJOA gM勺Q|6SA$ 4.o比:06ujppjnOWJOtOJdpyMQ*2pU26 0oPJOA (lUpAHXqpOpnXhpunps 9.oPJOA JMIpOpJppunRS Qo比:SH如屮 O 沙松產6PJOA :(u6屮oiupug 0eWJ X)Poepujp6QoPOA.(vjj3jnosa40|0j04ripund5QoPJOA:Z!po( (o Aogpu w C類中的駅U眥和方法,基本上和上面的自定義屬性可以對上粵,不僅可以在布局文伸中建義,還可以通過代 咼謹廳設豈.ATT1RS? WQ =MWFtO (= drffluhTiibLAyDuiiflFAn
8、nii:UtyMrtPiFinmi tKpadncMT|&LyQut*rdm LnxftP*nn p*glkfc?rMrr: P*gifUftHr = ngF tfbCwnt: iirat cwrrtrtcifibof ini 0OM rntPq $ rEuxOdlfct flQart=優(yōu) 地酣匕沁Piirt寸鬲旅用*:咤Pint pnditiffiCMColar: iriri = DKFF666666 “JM*沁比出(甘!in# = DvIAOOOOQO drvidkrCalan i-rrt = Chi/MXKMOO呻腫#:bo權床I訂=卡*育KeMtAJlCdprsc boalri
9、w = Inuc- wrolOftwf iintE52 tfKlicdrto-Hghfc irtit = B wiHcfen*H*gHi in寒2 dnAderPAddfingz inrt = 12 ubPAdiild int 2*4 dndWtcfth:H = 1ub7?nSize: 12UtbTcxfColqcHTE = thfFF-&66666 HbTyp屛粒也Typ呂*更a hull LabTpcBc-Slylfi:int = Tpefafe.iBDLD LSCFO1DC: i rt = 0類中使用到的變量,大部分都是和自定義屬性掛鉤的,主要關注幾個吏坦JVTTRS弓I用Aiu
10、Zi孫野的兩亍麗性,文本字體大小和字體顏色pageLi stener內部使用SJOnf agerChangeLi stener,通過set% ewFager實現(xiàn)和i ewfager的聯(lián)動delegat eFageLi stener暴壽給開炭者的接口, 類本身使用到了兩個OnPageChgeLiztener,一個用來實現(xiàn)自己的邏 輯而遠平則是留緒開水者實現(xiàn)自己需要針對“我連鈦的頁面孌化的倉輯t&bsCont&in 電 f內部客器,用尸所見文本指示盞和國標指示爲的父書點所以,如果需要軒對文本指示器或 者是圖標指示器做卄么操作,邇過這催找孩子節(jié)點即可bttA曲呂甘aM&tiT
11、 ftEceinTAbPrwiderv gelPdgrkcmA.4-Kld(nll!r:irrtV 0 PnffUhervr1bi cmP旳eScrcIkdlj憾 怡貞fn|J:C*d IO丁空產kangetntenr-占(HiP些ef口void “PgerL-沖亡Lili訥 hO b coPjgeSlwlediirvtA:wid FO-VAq t*ZTJng-Li ilB-rM* i督金Sartdtate6 由SrvcFdStatcf PdrcdflblJ0 n S*rtdlSlatrR irt色CftEATORi CvWtovcSflwdSllte* Mw Crvutor3 4 P吋日常i
12、苗ngTflb5?np(CMr*l* PsgetSdgTMlnpCMeEt. Att/rbyteSetiO P*9frTSdrngTd bStripi:Coniekl AshibueSet iM.0 HtelVwwa g e riView?qer); oidO & 5rrlOn?.fg?i!OiaftgictLlTrfKTj On*grChiric Listener):v4d a ncFtrffltiSrtC KfingsdO7& h iddTe*rtT*b(iM. String):怕0O b ddkcmTflbl ifil.e 依voidQaddTb(nn, Vwwh rti
13、d updatevodIconTabProvider類中比較關鍵的一些內容,接口IconTabProvider, ViewPager 對應的 Adapter 實現(xiàn)該方法并返回每個ViewPager 對應的圖標即可實現(xiàn)圖標指示器。PageListener private class PageListener implements OnPageChangeListener Overridepublic void onPageScrolled(int position, float positionOffset, int positionOffsetPixels) /存儲當前位置信息currentP
14、osition = position;currentPositionOffset = positionOffset;/滑動到子視圖scrollToChild(position, (int) (positionOffset * tabsContainer.getChildAt(position).getWidth();invalidate。;/ 觸發(fā)重繪/用戶自定義的 OnPagerChangeListener 事件之 onPagerScrolledif (delegatePageListener != ull) delegatePageListener.onPageScrolled(posit
15、ion,positionOffset, positionOffsetPixels);Overridepublic void onPageScrollStateChanged(int state) /已經滑動完成,offset 歸 0if (state = ViewPager.SCROLL_STATE_IDLE) scrollToChild(pager.getCurrentItem(), 0);/用戶自定義的 OnPagerChangeListener 事件之 onPageScrollStateChanged if(delegatePageListener != null) delegatePa
16、geListener.onPageScrollStateChanged(state);Overridepublic void onPageSelected(int position) 這里類內部沒有做什么處理,只處理用戶自定義的OnPagerSelected 方法if (delegatePageListener != null) delegatePageListener.onPageSelected(position);/*滑動指定子視圖*/private void scrollToChild(int position, int offset) if (tabCount = 0) return
17、;int newScrollX = tabsContainer.getChildAt(position).getLeft() + offset;if (position 0 | offset 0) newScrollX -= scrollOffset;if (newScrollX != lastScrollX) lastScrollX = newScrollX;scrollTo(newScrollX, 0);PagerSlidingTabStrip 構造方法 構造方法的內容不多,基本上全是基本屬性的獲取,自定義View 中常用的TypedArray ,記得回收recycle。,這里關注一下Ty
18、pedValue.applyDimension 方法的使用,全部轉換成 px。public PagerSlidingTabStrip(Context context, AttributeSet attrs, int defStyle) super(context, attrs, defStyle);setFillViewport(true);setWillNotDraw(false);tabsContainer = new LinearLayout(context);tabsContainer.setOrientation(LinearLayout.HORIZONTAL);tabsContai
19、ner.setLayoutParams(new LayoutParams(LayoutParams.MATCH_PARENT,LayoutParams.MA TCH_PARENT);addView(tabsContainer);DisplayMetrics dm = getResources().getDisplayMetrics();scrollOffset = (int) TypedValue.applyDimension(TypedValue.COMPLEX_UNIT_DIP, scrollOffset,dividerPadding, dm);tabPadding = (int) Typ
20、edValue.applyDimension(TypedValue.COMPLEX_UNIT_DIP, tabPadding,dm);dividerWidth = (int) TypedValue.applyDimension(TypedValue.COMPLEX_UNIT_DIP, dividerWidth,dm);tabTextSize = (int) TypedValue.applyDimension(TypedValue.COMPLEX_UNIT_SP, tabTextSize,dm);/ get system attrs (android:textSize and android:t
21、extColor)TypedArray a = context.obtainStyledAttributes(attrs, A TTRS); tabTextSize =a.getDimensionPixelSize(0, tabTextSize);tabTextColor = a.getColor(1, tabTextColor);a.recycle();/ get custom attrsa = context.obtainStyledAttributes(attrs, R.styleable.PagerSlidingTabStrip);indicatorColor = a.getColor
22、(R.styleable.PagerSlidingTabStrip_pstsIndicatorColor, indicatorColor);underlineColor = a.getColor(R.styleable.PagerSlidingTabStrip_pstsUnderlineColor,dm);indicatorHeight = (int)indicatorHeight, dm);underlineHeight = (int)underlineHeight, dm);dividerPadding = (int)TypedValue.applyDimension(TypedValue
23、.COMPLEX_UNIT_DIP,TypedValue.applyDimension(TypedValue.COMPLEX_UNIT_DIP,TypedValue.applyDimension(TypedValue.COMPLEX_UNIT_DIP,underlineColor);dividerColor = a.getColor(R.styleable.PagerSlidingTabStrip_pstsDividerColor, dividerColor);indicatorHeight = a.getDimensionPixelSize(R.styleable.PagerSlidingT
24、abStrip_pstsIndicatorHeight, indicatorHeight);underlineHeight = a.getDimensionPixelSize(R.styleable.PagerSlidingTabStrip_pstsUnderlineHeight,underlineHeight);dividerPadding = a.getDimensionPixelSize(R.styleable.PagerSlidingTabStrip_pstsDividerPadding,dividerPadding);tabPadding = a.getDimensionPixelS
25、ize(R.styleable.PagerSlidingTabStrip_pstsTabPaddingLeftRight,tabPadding);tabBackgroundResId = a.getResourceId(R.styleable.PagerSlidingTabStrip_pstsTabBackground,tabBackgroundResId);shouldExpand = a.getBoolean(R.styleable.PagerSlidingTabStrip_pstsShouldExpand, shouldExpand);scrollOffset = a.getDimens
26、ionPixelSize(R.styleable.PagerSlidingTabStrip_pstsScrollOffset,scrollOffset);textAllCaps = a.getBoolean(R.styleable.PagerSlidingTabStrip_pstsTextAllCaps, textAllCaps);a.recycle();/* 初始化矩形 Paint */rectPaint = new Paint();rectPaint.setAntiAlias(true); rectPaint.setStyle(Style.FILL);/* 初始化分割線 Paint */
27、dividerPaint = new Paint(); dividerPaint.setAntiAlias(true);dividerPaint.setStrokeWidth(dividerWidth);/* 是否延伸,默認 WRAP_CONTENT, 這種比較合理 */ defaultTabLayoutParams = newLinearLayout.LayoutParams(LayoutParams.WRAP_CONTENT, LayoutParams.MA TCH_PARENT);expandedTabLayoutParams = new LinearLayout.LayoutParam
28、s(0, LayoutParams.MA TCH_PARENT,1.0f);if (locale = null) locale = getResources().getConfiguration().locale;onDrawOverrideprotected void onDraw(Canvas canvas) super.onDraw(canvas);if (isInEditMode() | tabCount = 0) return;final int height = getHeight();/ 設置 Indicator 顏色 rectPaint.setColor(indicatorCo
29、lor);/ 獲取當前選中 TabView currentTab = tabsContainer.getChildAt(currentPosition);/獲取 Left,Right 值float lineLeft = currentTab.getLeft();float lineRight = currentTab.getRight();/ if there is an offset, start interpolating left and right coordinates between current and next tabif (currentPositionOffset 0f
30、& currentPosition tabCount - 1) /結合下一個 Tab 獲取當前要繪制的 indicator 的位置 , 這里的 currentPositionOffset 比較關 鍵,可以看到這個值是與 ViewPager 相關的,在 onPagerScrolled 方法中,這個值在不斷的更新View nextTab = tabsContainer.getChildAt(currentPosition + 1);final float nextTabLeft = nextTab.getLeft();final float nextTabRight = nextTab.g
31、etRight();lineLeft = (currentPositionOffset * nextTabLeft + (1f - currentPositionOffset) * lineLeft); lineRight =(currentPositionOffset * nextTabRight + (1f - currentPositionOffset) * lineRight);/ 繪制 Indicator canvas.drawRect(lineLeft, height - indicatorHeight, lineRight, height, rectPaint);/ 繪制 Und
32、erLine rectPaint.setColor(underlineColor);canvas.drawRect(0, height - underlineHeight, tabsContainer.getWidth(), height, rectPaint);/ 繪制分割線 dividerPaint.setColor(dividerColor);for (int i = 0; i tabCount - 1; i+) View tab = tabsContainer.getChildAt(i);canvas.drawLine(tab.getRight(), dividerPadding, t
33、ab.getRight(), height - dividerPadding,dividerPaint);setViewPager, setOnPageChangeListener 一個用來與 ViewPager 聯(lián)動,一個用來處理自定義的OnPagerListener 邏輯public void setViewPager(ViewPager pager) this.pager = ager;if (pager.getAdapter() = null) throw new lllegalStateException(ViewPager does not have adapter instanc
34、e.);pager.setOnPageChangeListener(pageListener); notifyDataSetChanged(); public void setOnPageChangeListener(OnPageChangeListener listener) this.delegatePageListener = listener;3. PagerS 1 i dingTabStrip環(huán)口關鍵點在于實現(xiàn)自己的OnPagerListenerOverrideprotected void onCreate(Bundle savedInstanceState) super.onCre
35、ate(savedInstanceState);setContentView(R.layout.activity_main);文本指示器選中后文本大小和酸色變化IndicaforDmoButterKnife.bind(this);MainPagerAdapter mainPagerAdapter = new MainPagerAdapter(getSupportFragmentManager();vpContent.setAdapter(mainPagerAdapter);pstsIndicator.setViewPager(vpContent); vpContent.addOnPageChangeListener(newViewPager.OnPageChangeListener() Overridepublic void onPageScrolled(int position, float positionOffset, int positionOffsetPixel
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網頁內容里面會有圖紙預覽,若沒有圖紙預覽就沒有圖紙。
- 4. 未經權益所有人同意不得將文件中的內容挪作商業(yè)或盈利用途。
- 5. 人人文庫網僅提供信息存儲空間,僅對用戶上傳內容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內容本身不做任何修改或編輯,并不能對任何下載內容負責。
- 6. 下載文件中如有侵權或不適當內容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 公司職員轉正工作總結范文(7篇)
- 2024年股權轉讓協(xié)議:股東權益與股權交接
- 2024年運動鞋品牌授權區(qū)域市場運營管理合同3篇
- 2024年高科技項目融資咨詢服務合同范本3篇
- 2025版高科技研發(fā)中心項目經理聘用合同3篇
- 2024年私教專業(yè)健身訓練服務協(xié)議版B版
- 2025年度智能穿戴設備研發(fā)IT外包合同3篇
- 2025年度小學運動會用品租賃合同模板3篇
- 2024年適用繪畫藝術品交易協(xié)議范本一
- 2024年網絡安全技術咨詢服務居間合同3篇
- (八省聯(lián)考)河南省2025年高考綜合改革適應性演練 化學試卷(含答案)
- 2025中國電信山東青島分公司校園招聘高頻重點提升(共500題)附帶答案詳解
- 2025年八省聯(lián)考高考語文作文真題及參考范文
- 新課標(水平三)體育與健康《籃球》大單元教學計劃及配套教案(18課時)
- 開題報告-鑄牢中華民族共同體意識的學校教育研究
- 計件工勞務合同范例
- 2024年公交車開通儀式講話例文(4篇)
- 2024-2025學年八年級上冊物理 第五章 透鏡以及其應用 測試卷(含答案)
- 《中華人民共和國政府采購法》專題培訓
- 《自理理論orem》課件
- 科研倫理與學術規(guī)范(研究生)期末試題庫及答案
評論
0/150
提交評論