11

在我的项目中,我有两个选项卡和一个按钮。对于两个选项卡,我有两个活动和调用不同活动的按钮。问题是我在第一个选项卡上显示按钮的结果。即 tab0 在 tab0Event 和按钮单击事件上也是活动的。并且能够使用 tabHost.setOnTabChangedListener 更改选项卡事件,但现在我更想要的是,假设我点击按钮,所以现在按钮视图正在显示(tab0 处于活动状态)但是如果我再次点击 tab0,tab0 活动应该是显示。

我尝试了许多单击选项卡的解决方案,一个是

getTabWidget().getChildAt(getTabHost().getCurrentTab()).setOnClickListener
      (new View.OnClickListener() {

      @Override public void onClick(View v) {
      System.out.println(getTabHost().getCurrentTab());

      } });

但是当我将此代码与 tabChnageListner 一起使用时,选项卡更改不起作用,我得到了非常意想不到的结果。请您为我的问题提出解决方案。

谢谢。

适用于标签更改的代码如下:(适用于标签更改,需要在其中添加 Tab Onclick)

public class TabLayoutUsingTabChangeEventActivity extends TabActivity {

        @Override
        public void onCreate(Bundle savedInstanceState) {

            super.onCreate(savedInstanceState);
            setContentView(R.layout.main);                
            final TabHost tabHost = (TabHost)findViewById(android.R.id.tabhost);
            final TabHost.TabSpec sp1 = tabHost.newTabSpec("TAB1");
            TabHost.TabSpec sp2 = tabHost.newTabSpec("TAB2");

            //Creating First Tab
            Intent intent1 = new Intent(this, Tab1Activity.class);
            sp1.setIndicator("TAB1").setContent(intent1);
            tabHost.addTab(sp1);

            //Creating Second Tab 
            Intent intent2 = new Intent(this, Tab2Activity.class);
            sp2.setIndicator("TAB2").setContent(intent2);
            tabHost.addTab(sp2);               

            //Tab Changed Event
            tabHost.setOnTabChangedListener(new OnTabChangeListener(){
                 @Override
                 public void onTabChanged(String tabId) {
                     Log.i("TabId :", tabId);
                     if(tabId.equals("TAB2")){
                     Log.i("TAB1", "TAB1 Changed");
                     Intent intent1 = new Intent().setClass(getApplicationContext(), Tab1Activity.class);
                     sp1.setIndicator("TAB1").setContent(intent1);
                     tabHost.setCurrentTab(0);
                     }
                  }
            });

            Button addNewButton = (Button)findViewById(R.id.add_new_ticket_btn);
            addNewButton.setOnClickListener(new OnClickListener(){
                  @Override
                  public void onClick(View v) {
                     Intent in = new Intent().setClass(getApplicationContext(), AddNewTicketActivity.class);
                     sp1.setContent(in);
                     tabHost.setCurrentTab(0);
                     //startActivity(in);
                 }
            });               
      }
}
4

3 回答 3

7

你可以实现这个监听器:

    host.setOnTabChangedListener(new OnTabChangeListener()
    {
        @Override
        public void onTabChanged(String tabId)
        {
            if (getTabHost().getCurrentTabTag().equals("tab0"))
            {
                host.getCurrentTabView().setOnTouchListener(
                        new OnTouchListener()
                        {
                            @Override
                            public boolean onTouch(View v, MotionEvent event)
                            {
                                if (event.getAction() == MotionEvent.ACTION_DOWN)
                                {
                                    if (getTabHost().getCurrentTabTag().equals("tab0")
                                    {
                                        getTabHost().setCurrentTabByTag("tab1");
                                        getTabHost().setCurrentTabByTag("tab0");
                                    }
                                    return false;
                                }
                                return false;
                            }
                        });
            }
        }
    });

此外,当您为每个选项卡添加选项卡集标记时:

host.addTab(host.newTabSpec("tab0"));
host.addTab(host.newTabSpec("tab1"));
于 2013-01-09T20:19:04.397 回答
2

您可以使用 Fragment 进行布局

于 2013-01-10T03:25:40.617 回答
1

你不能。TabWidget 中的视图已经有 onClickListener,它是正常工作流程所必需的。如果您删除它,您将破坏 TabWidget 的逻辑。

当你设置你的 onClickListener 时,你会删除 previuos onClickListener 并破坏 TabWidget 逻辑。

通常在这种情况下会创建复合点击监听器(一个处理点击事件并调用另一个点击监听器的点击监听器)。但不是您的情况,因为 View 没有 getOnClickListener 方法,因此无法获取旧的单击侦听器。

这是 TabWidget 源代码。所有相关的值都是私有的......所以我们无法从这方面解决任何问题。

实现目标的唯一方法是使用反射,因为它们允许读取私有变量。因此,在设置 View 的新 onlick 侦听器之前,您应该获取旧的(使用反射),然后创建复合 onClickListener,它将执行您的事件处理代码,然后调用旧的 onClickListener。将复合单击侦听器设置为视图。

于 2013-01-08T21:16:56.957 回答