上一篇
是不帶滑動效果的,這次更新一下,帶滑動效果的。喜歡什么隨便挑。
注意:目前工程里的代碼可是最新的。8.4 5:00
用法:這里要注意selectedPosition不再是自定義屬性了,所以不能設置初始化的時候選種哪個!也就是說初始化的時候只能選擇第一個選項,只有這點與上一篇不同。
利用這個功能也可以實現滑塊的效果,只不過xml布局變一下而已,看下圖:
注意:目前工程里的代碼可是最新的。8.4 5:00
package com.ql.view;
import android.content.Context;
import android.content.res.TypedArray;
import android.graphics.Color;
import android.util.AttributeSet;
import android.util.Log;
import android.view.Gravity;
import android.view.View;
import android.view.animation.LinearInterpolator;
import android.view.animation.TranslateAnimation;
import android.widget.FrameLayout;
import android.widget.ImageView;
import android.widget.LinearLayout;
import android.widget.TextView;
import android.widget.ImageView.ScaleType;
import com.ql.app.R;
public class TabSwitcher extends FrameLayout{
private static final String tag="TabSwitcher";
private Context context;
private String[] texts;
private int arrayId;
private int selectedPosition=0;
private int oldPosition=selectedPosition;
private ImageView iv;
private LinearLayout.LayoutParams params;
private LinearLayout layout;
private int iv_width;
public TabSwitcher(Context context) {
super(context);
// TODO Auto-generated constructor stub
init();
}
public TabSwitcher(Context context, AttributeSet attrs) {
super(context, attrs);
// TODO Auto-generated constructor stub
Log.i(tag, "--------------TabSwitcher2---------------------");
init();
TypedArray a=context.obtainStyledAttributes(attrs,R.styleable.custom);
arrayId=a.getResourceId(R.styleable.custom_arrayId, 0);
// selectedPosition=a.getInt(R.styleable.custom_selectedPosition, 0);
a.recycle();
}
private void init(){
context=getContext();
FrameLayout.LayoutParams params=new FrameLayout.LayoutParams(FrameLayout.LayoutParams.FILL_PARENT,FrameLayout.LayoutParams.WRAP_CONTENT);
setLayoutParams(params);
setBackgroundResource(R.drawable.tabswitcher_long);
}
@Override
protected void onFinishInflate() {
// TODO Auto-generated method stub
super.onFinishInflate();
Log.i(tag, "--------------onFinishInflate---------------------");
if(arrayId!=0){
texts=getResources().getStringArray(arrayId);
}else{
texts=new String[]{};
}
}
OnClickListener listener = new OnClickListener(){
@Override
public void onClick(View v) {
// TODO Auto-generated method stub
selectedPosition=(Integer)v.getTag();
if(selectedPosition!=oldPosition){
//
doAnimation();
oldPosition=selectedPosition;
if(onItemClickLisener!=null){
onItemClickLisener.onItemClickLisener(v, selectedPosition);
}
}
}
};
@Override
protected void onSizeChanged(int w, int h, int oldw, int oldh) {
// TODO Auto-generated method stub
super.onSizeChanged(w, h, oldw, oldh);
Log.i("tag", "---------------onSizeChanged--------------------");
if(selectedPosition>texts.length-1){
throw new IllegalArgumentException("The selectedPosition can't be > texts.length.");
}
layout=new LinearLayout(context);
params=new LinearLayout.LayoutParams(LinearLayout.LayoutParams.FILL_PARENT,this.getMeasuredHeight());//為了居中顯示文字
params.weight=1;
params.gravity=Gravity.CENTER_VERTICAL;
for(int i=0;i<texts.length;i++){
TextView child=new TextView(context);
child.setTag(i);
child.setText(texts[i]);
child.setTextSize(16);
child.setTextColor(Color.BLACK);
child.setGravity(Gravity.CENTER);
child.setOnClickListener(listener);
layout.addView(child,params);
}
oldPosition=selectedPosition;
//
iv_width=this.getMeasuredWidth()/texts.length;//計算ImageView的寬
//LinearLayout.LayoutParams p=new LinearLayout.LayoutParams(iv_width,LinearLayout.LayoutParams.FILL_PARENT);
LinearLayout.LayoutParams p=new LinearLayout.LayoutParams(iv_width,this.getMeasuredHeight());
// p.leftMargin=selectedPosition*iv_width;//無效,因為FrameLayout必須對齊左上角。
iv=new ImageView(context);
//iv.setImageResource(R.drawable.tabswitcher_short);
//iv.setScaleType(ScaleType.FIT_XY);
iv.setBackgroundResource(R.drawable.tabswitcher_short);
this.addView(iv,p);
this.addView(layout,params);
}
private void doAnimation(){
TranslateAnimation animation = new TranslateAnimation(oldPosition*iv_width, selectedPosition*iv_width, 0, 0);
animation.setInterpolator(new LinearInterpolator());
animation.setDuration(400);
animation.setFillAfter(true);
iv.startAnimation(animation);
}
private OnItemClickLisener onItemClickLisener;
public void setOnItemClickLisener(OnItemClickLisener onItemClickLisener) {
this.onItemClickLisener = onItemClickLisener;
}
public interface OnItemClickLisener{
void onItemClickLisener(View view,int position);
}
public void setTexts(String[] texts) {
this.texts = texts;
}
// public void setSelectedPosition(int selectedPosition) {
// this.selectedPosition = selectedPosition;
// }
}
用法:這里要注意selectedPosition不再是自定義屬性了,所以不能設置初始化的時候選種哪個!也就是說初始化的時候只能選擇第一個選項,只有這點與上一篇不同。
package com.ql.app;
import android.app.Activity;
import android.content.Context;
import android.os.Bundle;
import android.view.View;
import android.widget.Toast;
import com.ql.view.TabSwitcher;
import com.ql.view.TabSwitcher.OnItemClickLisener;
public class App extends Activity{
private Context context;
private TabSwitcher tabSwitcher;
/** Called when the activity is first created. */
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.main);
context=this;
tabSwitcher=(TabSwitcher)findViewById(R.id.tabSwitcher);
tabSwitcher.setOnItemClickLisener(onItemClickLisener);
// tabSwitcher.setTexts(new String[]{"1","2","3"});
}
OnItemClickLisener onItemClickLisener=new OnItemClickLisener(){
@Override
public void onItemClickLisener(View view, int position) {
// TODO Auto-generated method stub
//
switch (position) {
case 0:
case 1:
case 2:
Toast.makeText(context, "position clicked:"+position, Toast.LENGTH_SHORT).show();
break;
default:
break;
}
}
};
}
利用這個功能也可以實現滑塊的效果,只不過xml布局變一下而已,看下圖:
更多文章、技術交流、商務合作、聯系博主
微信掃碼或搜索:z360901061
微信掃一掃加我為好友
QQ號聯系: 360901061
您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點擊下面給點支持吧,站長非常感激您!手機微信長按不能支付解決辦法:請將微信支付二維碼保存到相冊,切換到微信,然后點擊微信右上角掃一掃功能,選擇支付二維碼完成支付。
【本文對您有幫助就好】元

