Android自定義控件(實現(xiàn)視圖樹繪制指示器)
之前寫輪播條或者指示器的時候都是UI圖里面直接有,這樣的效果并不好,給用戶的體驗比較差,所以閑暇之余自己寫了個指示器,可以展現(xiàn)出一個優(yōu)雅的效果,當手指 當手指滑動的時候小圓點會跟著一點一點的滑動,當手指停下時,小紅點也跟著停下來。首先我說說我實現(xiàn)的這個原理吧
首先在布局文件里面寫上線性布局,表示底部的小圓點,方向和位置,然后再在shape里面自繪小圓點。再在代碼里面里用布局寫出,具體步驟如下:
1、使用LayParams給布局里面添加未選中的小圓點,例如灰色;
2、設置小紅點,表示滑動后的狀態(tài)。
3、獲取小圓點之間的距離,這里要獲取小圓點的距離不能簡單地getWidth,getHeiget,這樣是獲取不到的 ,這里要用到視圖樹來觀察兩個點距離左側屏幕之間的距離,然后求差獲取距離。
4、在監(jiān)聽viewpager的時候獲取兩者的距離。
代碼如下:
一、布局文件
<!--小紅點,小圓點的滑動,具體布局在代碼里面寫的--> <?xml version="1.0" encoding="utf-8"?> <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns:tools="http://schemas.android.com/tools" android:layout_width="match_parent" android:layout_height="match_parent"> <android.support.v4.view.ViewPager android:id="@+id/vp_pager" android:layout_width="match_parent" android:layout_height="match_parent"/> <Button android:id="@+id/btn_start" android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_alignParentBottom="true" android:layout_centerHorizontal="true" android:layout_marginBottom="60dp" android:background="#FFF107" android:paddingLeft="10dp" android:paddingRight="10dp" android:textSize="20sp" android:text="開始體驗" android:visibility="gone"/> <!--小紅點,小圓點的滑動,具體布局在代碼里面寫的--> <RelativeLayout android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_alignParentBottom="true" android:layout_centerHorizontal="true" android:layout_marginBottom="20dp"> <LinearLayout android:id="@+id/ll_point_group" android:layout_width="wrap_content" android:layout_height="wrap_content" android:orientation="horizontal"> </LinearLayout> <View android:id="@+id/view_red_point" android:layout_width="10dp" android:layout_height="10dp" android:background="@drawable/shape_guide_point_selected"/> </RelativeLayout> </RelativeLayout> <!--普通的圓點--> <?xml version="1.0" encoding="utf-8"?> <shape xmlns:android="http://schemas.android.com/apk/res/android" android:shape="oval" > <solid android:color="@android:color/darker_gray" /> </shape> <!--小紅點的圓點--> <?xml version="1.0" encoding="utf-8"?> <shape xmlns:android="http://schemas.android.com/apk/res/android" android:shape="oval" > <solid android:color="#f00" /> </shape>
二、代碼
/**
* 初始化viewpager的數(shù)據(jù)
*/
private void initView() {
int[] icons = {R.mipmap.guide1,R.mipmap.guide2,R.mipmap.guide3,R.mipmap.guide4};
mList = new ArrayList<>();
for (int i = 0; i < icons.length; i++) {
ImageView view = new ImageView(this);
view.setBackgroundResource(icons[i]); //只有設置了背景才能填充滿屏幕
mList.add(view);
//設置,灰色的小圓點,表示滑動時候的狀態(tài)
View point = new View(this);
point.setBackgroundResource(R.drawable.shape_guide_point_default); //設置背景
LinearLayout.LayoutParams params = new LinearLayout.LayoutParams(DensityUtils.dp2px(this,10), DensityUtils.dp2px(this,10));
point.setLayoutParams(params);
if (i != 0) {
params.leftMargin = DensityUtils.dp2px(this, 10);
}
llpointGroup.addView(point);
}
}
三、獲取小紅點之間的距離
/**
* 初始化小紅點之間的距離
*/
private void initPoint() {
// measure -> layout -> draw
viewRedPoint.getViewTreeObserver().addOnGlobalLayoutListener(new ViewTreeObserver.OnGlobalLayoutListener() {
//完成布局后回調該方法,該方法有可能被多次回調
@Override
public void onGlobalLayout() {
viewRedPoint.getViewTreeObserver().removeGlobalOnLayoutListener(this);
mPointWidth = llpointGroup.getChildAt(1).getLeft() - llpointGroup.getChildAt(0).getLeft();
}
});
}
四、讓小紅點聯(lián)動
/**
* viewpager的頁面滑動的監(jiān)聽
*/
private void initScrollListen() {
viewPager.setOnPageChangeListener(new ViewPager.OnPageChangeListener() {
//當頁面被滑動的時候
//參數(shù)一:當前頁面的位置 參數(shù)二:偏移的百分比 參數(shù)三:偏移的距離
@Override
public void onPageScrolled(int position,float positionOffset,int positionOffsetPixels) {
int leftMargin = (int) (mPointWidth * (position + positionOffset));
RelativeLayout.LayoutParams lp = (RelativeLayout.LayoutParams) viewRedPoint.getLayoutParams();
lp.leftMargin = leftMargin;
viewRedPoint.setLayoutParams(lp);
}
//當頁面被選擇
@Override
public void onPageSelected(int position) {
}
//當頁面狀態(tài)改變的時候
@Override
public void onPageScrollStateChanged(int state) {
}
});
}
以上就是本文的全部內容,希望本文的內容對大家的學習或者工作能帶來一定的幫助,同時也希望多多支持腳本之家!
相關文章
Android ADT和SDK Manager無法更新下載解決方案
這篇文章主要介紹了Android ADT和SDK Manager無法更新下載解決方案的相關資料,需要的朋友可以參考下2017-04-04
Android結合kotlin使用coroutine的方法實例
這篇文章主要給大家介紹了關于Android結合kotlin使用coroutine的相關資料,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2020-12-12
Android實現(xiàn)志愿者系統(tǒng)詳細步驟與代碼
這篇文章主要介紹了Android實現(xiàn)志愿者系統(tǒng),本系統(tǒng)采用MVC架構設計,SQLite數(shù)據(jù)表有用戶表、成員表和活動表,有十多個Activity頁面。打開應用,進入歡迎界面,3s后跳轉登錄界面,用戶先注冊賬號,登錄成功后進入主界面2023-02-02
Android使用Volley框架定制PostUploadRequest上傳文件
這篇文章主要為大家詳細介紹了Android使用Volley框架定制PostUploadRequest上傳文件或圖片,具有一定的參考價值,感興趣的小伙伴們可以參考一下2018-12-12

