自定义View仿TabHost的实现(一)

本文介绍了一种自定义的底部菜单视图组件,该组件模仿了TabHost的功能,并通过切换不同的LinearLayout来实现Activity间的跳转。文章详细展示了如何创建四个不同的Activity以及如何通过底部菜单在这些Activity之间进行导航。

Activity1如下:

package cn.com;
import android.app.Activity;
import android.os.Bundle;
public class Activity1 extends Activity{
     @Override
    protected void onCreate(Bundle savedInstanceState) {
    	super.onCreate(savedInstanceState);
    	//设置setTitle应该在setTitle之前
    	//否则不起作用
    	setTitle("Activity1");
    	setContentView(R.layout.activity_1);
    }
}


Activity2如下:

package cn.com;
import android.app.Activity;
import android.os.Bundle;
public class Activity2 extends Activity{
     @Override
    protected void onCreate(Bundle savedInstanceState) {
    	super.onCreate(savedInstanceState);
    	//设置setTitle应该在setTitle之前
    	//否则不起作用
    	setTitle("Activity2");
    	setContentView(R.layout.activity_2);
    }
}


Activity3如下:

package cn.com;
import android.app.Activity;
import android.os.Bundle;
public class Activity3 extends Activity{
     @Override
    protected void onCreate(Bundle savedInstanceState) {
    	super.onCreate(savedInstanceState);
    	//设置setTitle应该在setTitle之前
    	//否则不起作用
    	setTitle("Activity3");
    	setContentView(R.layout.activity_3);
    }
}


Activity4如下:

package cn.com;
import android.app.Activity;
import android.os.Bundle;
public class Activity4 extends Activity{
     @Override
    protected void onCreate(Bundle savedInstanceState) {
    	super.onCreate(savedInstanceState);
    	//设置setTitle应该在setTitle之前
    	//否则不起作用
    	setTitle("Activity4");
    	setContentView(R.layout.activity_4);
    }
}


BottomMenuView如下:

package cn.com;
import android.app.Activity;
import android.content.Context;
import android.content.Intent;
import android.util.AttributeSet;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.LinearLayout;
//自定义View.仿TabHost的实现
public class BottomMenuView extends LinearLayout{
	private Context mContext;
	private LinearLayout mLinearLayout1;
	private LinearLayout mLinearLayout2;
	private LinearLayout mLinearLayout3;
	private LinearLayout mLinearLayout4;
	private String mCurrentActivityTitle;
	private final static String ACTIVITY_NAME_1="Activity1";
	private final static String ACTIVITY_NAME_2="Activity2";
	private final static String ACTIVITY_NAME_3="Activity3";
	private final static String ACTIVITY_NAME_4="Activity4";
	public BottomMenuView(Context context, AttributeSet attrs) {
		super(context, attrs);
		mContext=context;
		initView();
	}
	private void initView(){
		View bottomMenuView=
		LayoutInflater.from(mContext).inflate(R.layout.bottommenu, null, false);
		ViewGroup.LayoutParams params=
		new LayoutParams(LayoutParams.WRAP_CONTENT, LayoutParams.FILL_PARENT);
		this.addView(bottomMenuView,params);
		
		mLinearLayout1=(LinearLayout)
		bottomMenuView.findViewById(R.id.menu_LinearLayout1);
		mLinearLayout2=(LinearLayout)
		bottomMenuView.findViewById(R.id.menu_LinearLayout2);
		mLinearLayout3=(LinearLayout)
		bottomMenuView.findViewById(R.id.menu_LinearLayout3);
		mLinearLayout4=(LinearLayout)
		bottomMenuView.findViewById(R.id.menu_LinearLayout4);
		
		BottomMenuOnClickListener clickListener=new BottomMenuOnClickListener();
		mLinearLayout1.setOnClickListener(clickListener);
		mLinearLayout2.setOnClickListener(clickListener);
		mLinearLayout3.setOnClickListener(clickListener);
		mLinearLayout4.setOnClickListener(clickListener);
		setEveryMenuStatus();
	}
	
	/**
	 * 
	 * 1 在每个menu对应的Activity中设置其Title
	 * 2 在此判断当前显示是哪一个Activity.使得
	 *   当前Activity对应的Menu不可再次点击.
	 */
	private void setEveryMenuStatus(){
		mCurrentActivityTitle=(String) ((Activity)mContext).getTitle();
		if (mCurrentActivityTitle.equals(ACTIVITY_NAME_1)) {
			mLinearLayout1.setClickable(false);
		}else if (mCurrentActivityTitle.equals(ACTIVITY_NAME_2)) {
			mLinearLayout2.setClickable(false);
		}else if (mCurrentActivityTitle.equals(ACTIVITY_NAME_3)) {
			mLinearLayout3.setClickable(false);
		}else if (mCurrentActivityTitle.equals(ACTIVITY_NAME_4)) {
			mLinearLayout4.setClickable(false);
		}
	}
	
	private class BottomMenuOnClickListener implements OnClickListener{
		public void onClick(View v) {
			switch (v.getId()) {
			case R.id.menu_LinearLayout1:
				Intent intent1=new Intent(mContext, Activity1.class);
				mContext.startActivity(intent1);
				break;
			case R.id.menu_LinearLayout2:
				Intent intent2=new Intent(mContext, Activity2.class);
				mContext.startActivity(intent2);
				break;
			case R.id.menu_LinearLayout3:
				Intent intent3=new Intent(mContext, Activity3.class);
				mContext.startActivity(intent3);
				break;
			case R.id.menu_LinearLayout4:
				Intent intent4=new Intent(mContext, Activity4.class);
				mContext.startActivity(intent4);
				break;
			default:
				break;
			}
			
		}
		
	}

}


 

在车辆工程中,悬架系统的性能评估和优化直是研究的热点。悬架不仅关乎车辆的乘坐舒适性,还直接影响到车辆的操控性和稳定性。为了深入理解悬架的动态行为,研究人员经常使用“二自由度悬架模型”来简化分析,并运用“传递函数”这数学工具来描述悬架系统的动态特性。 二自由度悬架模型将复杂的车辆系统简化为两个独立的部分:车轮和车身。这种简化模型能够较准确地模拟出车辆在垂直方向上的运动行为,同时忽略了侧向和纵向的动态影响,这使得工程师能够更加专注于分析与优化与垂直动态相关的性能指标。 传递函数作为控制系统理论中的种工具,能够描述系统输入和输出之间的关系。在悬架系统中,传递函数特别重要,因为它能够反映出路面不平度如何被悬架系统转化为车内乘员感受到的振动。通过传递函数,我们可以得到个频率域上的表达式,从中分析出悬架系统的关键动态特性,如系统的振幅衰减特性和共振频率等。 在实际应用中,工程师通过使用MATLAB这类数学软件,建立双质量悬架的数学模型。模型中的参数包括车轮质量、车身质量、弹簧刚度以及阻尼系数等。通过编程求解,工程师可以得到悬架系统的传递函数,并据此绘制出传递函数曲线。这为评估悬架性能提供了个直观的工具,使工程师能够了解悬架在不同频率激励下的响应情况。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

谷哥的小弟

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值