ViewPager和Tabhost结合,可滑动的tabhost

 TabHost 实现滑动切换的APP主界面实现方式。

(这个方法啊比较过时且代码比较晦涩,关于新的实现方法请参照我的其他博客)

viewpager+FragmentAdapter实现App主界面Tab

Fragment实现APP主界面Tab页面切换和点击事件

Fragment+viewpagerIndicator第三方控件实现APP主界面

ViewPager实现App主界面Tab菜单页面切换和点击事件


import android.app.Activity;
import android.app.TabActivity;
import android.content.Intent;
import android.os.Bundle;
import android.util.Log;
import android.view.GestureDetector;
import android.view.GestureDetector.SimpleOnGestureListener;
import android.view.Menu;
import android.view.MenuItem;
import android.view.MotionEvent;
import android.view.View;
import android.widget.;
import android.widget.TabHost.TabSpec;


//auther yang

public class MainActivity extends TabActivity {
private TabSpec tabSpec;   
   private TabHost tabHost;   
   private Intent intent;   
   private static final int SWIPE_MIN_DISTANCE = 120;   
   private static final int SWIPE_MAX_OFF_PATH = 250;   
   private static final int SWIPE_THRESHOLD_VELOCITY = 200;   
   private GestureDetector gestureDetector;   
   View.OnTouchListener gestureListener;   
 
   int currentView = 0;   
   private static int maxTabIndex = 2;   
 
  private String TAG="MainActivity";


    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        
        
       gestureDetector = new GestureDetector(new MyGestureDetector());   
        gestureListener = new View.OnTouchListener() {   
            public boolean onTouch(View v, MotionEvent event) {   
                if (gestureDetector.onTouchEvent(event)) {   
                    return true;   
                }   
                return false;   
            }   
        };   
  
      
  
    /**  
     * tablehost的初始化,代码完成  
     */  
    
  
tabHost = this.getTabHost();
TabHost.TabSpec spec;
Intent intent;


intent = new Intent().setClass(this, ActivityList.class);
spec = tabHost
.newTabSpec("0")
.setIndicator(
"",
getResources().getDrawable(
R.drawable.ic_launcher))
.setContent(intent);
tabHost.addTab(spec);


intent = new Intent().setClass(this, ActivityPlaying.class);
spec = tabHost
.newTabSpec("1")
.setIndicator(
"",
getResources().getDrawable(
R.drawable.ic_launcher))
.setContent(intent);
tabHost.addTab(spec);


intent = new Intent().setClass(this,ActivityLyric.class);
spec = tabHost
.newTabSpec("2")
.setIndicator(
"",
getResources().getDrawable(
R.drawable.ic_launcher))
.setContent(intent);
tabHost.addTab(spec);





tabHost.setCurrentTab(2);


}
   
    // 左右滑动刚好页面也有滑动效果   
  public class MyGestureDetector extends SimpleOnGestureListener {   
        @Override  
        public boolean onFling(MotionEvent e1, MotionEvent e2, float velocityX,   
                float velocityY) {   
            TabHost tabHost = getTabHost();   
            try {   
                if (Math.abs(e1.getY() - e2.getY()) > SWIPE_MAX_OFF_PATH)   
                    return false;   
                // right to left swipe   
                if (e1.getX() - e2.getX() > SWIPE_MIN_DISTANCE   
                        && Math.abs(velocityX) > SWIPE_THRESHOLD_VELOCITY) {   
                    Log.i("test", "right");   
                    if (currentView == maxTabIndex) {   
                        currentView = 0;   
                    } else {   
                        currentView++;   
                    }   
                    tabHost.setCurrentTab(currentView);   
                } else if (e2.getX() - e1.getX() > SWIPE_MIN_DISTANCE   
                        && Math.abs(velocityX) > SWIPE_THRESHOLD_VELOCITY) {   
                    Log.i("test", "left");   
                    if (currentView == 0) {   
                        currentView = maxTabIndex;   
                    } else {   
                        currentView--;   
                    }   
                    tabHost.setCurrentTab(currentView);   
                }   
            } catch (Exception e) {   
            }   
            return false;   
        }   
    }   
  
    @Override  
    public boolean dispatchTouchEvent(MotionEvent event) {   
        if (gestureDetector.onTouchEvent(event)) {   
            event.setAction(MotionEvent.ACTION_CANCEL);   
        }   
        return super.dispatchTouchEvent(event);   
    }   
  
 




    @Override
    public boolean onOptionsItemSelected(MenuItem item) {
        // Handle action bar item clicks here. The action bar will
        // automatically handle clicks on the Home/Up button, so long
        // as you specify a parent activity in AndroidManifest.xml.
        int id = item.getItemId();
        if (id == R.id.action_settings) {
            return true;
        }
        return super.onOptionsItemSelected(item);
    }
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值