1. 分段控制(SegmentView)android
首先咱們先看看什麼是SegmentView的效果,以下:ios
分段控制這個View控件是ios7的分段控制,和QQ消息頁面頂部的效果同樣,android沒有這個控件,不過實現起來也比較簡單,下面來實現這個樣式,實現的樣式最終效果以下:app
2. SegmentView自定義實現的邏輯過程:
ide
(1)首先咱們要定義文字的顏色,文字是交給TextView顯示的,當TextView選中和沒有選中二者顏色是不同的,咱們在res/color下:佈局
新建segment_text_color_selector.xml文件:post
1 <?xml version="1.0" encoding="utf-8"?> 2 <selector 3 xmlns:android="http://schemas.android.com/apk/res/android"> 4 5 <item 6 android:state_selected="true" 7 android:color="#ffffff"> 8 </item> 9 10 <item 11 android:color="#288455"> 12 </item> 13 14 </selector>
(2)而後在res/drawable下新建segment_left_background.xml和segment_right_background.xml字體
這兩個都是Segment-消息 和 Segment-電話 選中和沒有選中兩種狀態對應的不一樣背景填充ui
segment_left_background.xml:this
1 <?xml version="1.0" encoding="utf-8"?> 2 <selector 3 xmlns:android="http://schemas.android.com/apk/res/android"> 4 5 <item android:state_selected="true"> 6 <shape> 7 <solid android:color="#00c17c" /> 8 9 <corners 10 android:bottomLeftRadius="15dp" 11 android:bottomRightRadius="0dp" 12 android:topLeftRadius="15dp" 13 android:topRightRadius="0dp" /> 14 </shape> 15 </item> 16 17 <item> 18 <shape> 19 <stroke android:width="1dp" android:color="#00c17c" /> 20 <solid android:color="#ffffff" /> 21 <corners android:bottomLeftRadius="15dp" 22 android:bottomRightRadius="0dp" 23 android:topLeftRadius="15dp" 24 android:topRightRadius="0dp" /> 25 </shape> 26 </item> 27 28 </selector>
segment_right_background.xml:spa
1 <?xml version="1.0" encoding="utf-8"?> 2 <selector xmlns:android="http://schemas.android.com/apk/res/android"> 3 4 <item android:state_selected="true"> 5 <shape> 6 <solid android:color="#00c17c" /> 7 8 <corners 9 android:bottomLeftRadius="0dp" 10 android:bottomRightRadius="15dp" 11 android:topLeftRadius="0dp" 12 android:topRightRadius="15dp" /> 13 </shape> 14 </item> 15 16 <item> 17 <shape> 18 <stroke android:width="1dp" android:color="#00c17c" /> 19 <solid android:color="#ffffff" /> 20 <corners 21 android:bottomLeftRadius="0dp" 22 android:bottomRightRadius="15dp" 23 android:topLeftRadius="0dp" 24 android:topRightRadius="15dp" /> 25 </shape> 26 </item> 27 28 </selector>
(3)Ok,上面資源文件都定義好了,接下來咱們就能夠自定義SegmentView,因爲使用到了weight屬性,咱們讓SegmentView繼承自LinearLayout,使用兩個TextView,以下:
1 package com.himi.segmentviewdemo; 2 3 import android.content.Context; 4 import android.content.res.ColorStateList; 5 import android.util.AttributeSet; 6 import android.util.TypedValue; 7 import android.view.Gravity; 8 import android.view.View; 9 import android.widget.LinearLayout; 10 import android.widget.TextView; 11 12 public class SegmentView extends LinearLayout { 13 private TextView leftTextView; 14 private TextView rightTextView; 15 private onSegmentViewClickListener segmentListener; 16 17 // 這是代碼加載ui必須重寫的方法 18 public SegmentView(Context context) { 19 super(context); 20 initView(); 21 } 22 23 // 這是在xml佈局使用必須重寫的方法 24 public SegmentView(Context context, AttributeSet attrs) { 25 super(context, attrs); 26 initView(); 27 } 28 29 private void initView() { 30 leftTextView = new TextView(getContext()); 31 rightTextView = new TextView(getContext()); 32 33 // 設置textview的佈局寬高並設置爲weight屬性都爲1 34 leftTextView.setLayoutParams(new LayoutParams(0, LayoutParams.WRAP_CONTENT, 1)); 35 rightTextView.setLayoutParams(new LayoutParams(0, LayoutParams.WRAP_CONTENT, 1)); 36 37 // 初始化的默認文字 38 leftTextView.setText("消息"); 39 rightTextView.setText("電話"); 40 41 // 實現不一樣的按鈕狀態,不一樣的顏色 42 ColorStateList csl = getResources().getColorStateList(R.color.segment_text_color_selector); 43 leftTextView.setTextColor(csl); 44 rightTextView.setTextColor(csl); 45 46 // 設置textview的內容位置居中 47 leftTextView.setGravity(Gravity.CENTER); 48 rightTextView.setGravity(Gravity.CENTER); 49 50 // 設置textview的內邊距 51 leftTextView.setPadding(5, 6, 5, 6); 52 rightTextView.setPadding(5, 6, 5, 6); 53 54 // 設置文字大小 55 setSegmentTextSize(16); 56 57 // 設置背景資源 58 leftTextView.setBackgroundResource(R.drawable.segment_left_background); 59 rightTextView.setBackgroundResource(R.drawable.segment_right_background); 60 61 // 默認左側textview爲選中狀態 62 leftTextView.setSelected(true); 63 64 // 加入textview 65 this.removeAllViews(); 66 this.addView(leftTextView); 67 this.addView(rightTextView); 68 this.invalidate();//從新draw() 69 70 leftTextView.setOnClickListener(new OnClickListener() { 71 @Override 72 public void onClick(View v) { 73 if (leftTextView.isSelected()) { 74 return; 75 } 76 leftTextView.setSelected(true); 77 rightTextView.setSelected(false); 78 if (segmentListener != null) { 79 segmentListener.onSegmentViewClick(leftTextView, 0); 80 } 81 } 82 }); 83 84 rightTextView.setOnClickListener(new OnClickListener() { 85 @Override 86 public void onClick(View v) { 87 if (rightTextView.isSelected()) { 88 return; 89 } 90 rightTextView.setSelected(true); 91 leftTextView.setSelected(false); 92 if (segmentListener != null) { 93 segmentListener.onSegmentViewClick(rightTextView, 1); 94 } 95 } 96 }); 97 98 } 99 100 /** 101 * 設置字體大小 102 * 103 * @param dp 104 */ 105 private void setSegmentTextSize(int dp) { 106 leftTextView.setTextSize(TypedValue.COMPLEX_UNIT_DIP, dp); 107 rightTextView.setTextSize(TypedValue.COMPLEX_UNIT_DIP, dp); 108 } 109 110 /** 111 * 手動設置選中的狀態 112 * 113 * @param i 114 */ 115 public void setSelect(int i) { 116 if (i == 0) { 117 leftTextView.setSelected(true); 118 rightTextView.setSelected(false); 119 } else { 120 leftTextView.setSelected(false); 121 rightTextView.setSelected(true); 122 } 123 } 124 125 /** 126 * 設置控件顯示的文字 127 * 128 * @param text 129 * @param position 130 */ 131 public void setSegmentText(CharSequence text, int position) { 132 if (position == 0) { 133 leftTextView.setText(text); 134 } 135 if (position == 1) { 136 rightTextView.setText(text); 137 } 138 } 139 140 // 定義一個接口接收點擊事件 141 public interface onSegmentViewClickListener { 142 public void onSegmentViewClick(View view, int postion); 143 } 144 145 public void setOnSegmentViewClickListener(onSegmentViewClickListener segmentListener) { 146 this.segmentListener = segmentListener; 147 } 148 }
(4)上面定義好了SegmentView,接下來去xml佈局直接使用就能夠了,以下:
1 <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android" 2 xmlns:tools="http://schemas.android.com/tools" 3 android:layout_width="match_parent" 4 android:layout_height="match_parent" 5 android:paddingBottom="@dimen/activity_vertical_margin" 6 android:paddingLeft="@dimen/activity_horizontal_margin" 7 android:paddingRight="@dimen/activity_horizontal_margin" 8 android:paddingTop="@dimen/activity_vertical_margin" 9 tools:context="com.himi.segmentviewdemo.MainActivity" > 10 11 <com.himi.segmentviewdemo.SegmentView 12 android:id="@+id/segmentview" 13 android:layout_width="wrap_content" 14 android:layout_height="wrap_content" 15 android:layout_centerHorizontal="true" > 16 </com.himi.segmentviewdemo.SegmentView> 17 18 </RelativeLayout>
(5)來到MainActivity,設置點擊事件,事件能夠切換fragment等等
1 package com.himi.segmentviewdemo; 2 3 import android.app.Activity; 4 import android.os.Bundle; 5 import android.view.View; 6 import android.widget.Toast; 7 8 public class MainActivity extends Activity { 9 10 private SegmentView mSegmentView; 11 12 @Override 13 protected void onCreate(Bundle savedInstanceState) { 14 super.onCreate(savedInstanceState); 15 setContentView(R.layout.activity_main); 16 17 mSegmentView = (SegmentView) findViewById(R.id.segmentview); 18 mSegmentView.setOnSegmentViewClickListener(new SegmentView.onSegmentViewClickListener() { 19 @Override 20 public void onSegmentViewClick(View view, int postion) { 21 switch (postion) { 22 case 0: 23 Toast.makeText(MainActivity.this, "點擊了消息" + postion, 24 Toast.LENGTH_SHORT).show(); 25 break; 26 case 1: 27 Toast.makeText(MainActivity.this, "點擊了電話" + postion, 28 Toast.LENGTH_SHORT).show(); 29 break; 30 default: 31 break; 32 } 33 } 34 }); 35 } 36 37 }
部署程序到手機上,以下: