Android 修改Sherlock主细节流

Android 修改Sherlock主细节流,android,android-layout,android-fragments,master-detail,Android,Android Layout,Android Fragments,Master Detail,如果您使用过sherlock master细节流,请帮助我 我已经添加了选项卡,并删除了细节片段/活动中的数据,但当我尝试在选项卡中充气按钮时,它不起作用 你能帮我吗? 下面是我修改的列表活动,在双窗格模式下显示选项卡 package com.example.sample; import android.content.Intent; import android.os.Bundle; import android.support.v4.app.Fragment; import android

如果您使用过sherlock master细节流,请帮助我

我已经添加了选项卡,并删除了细节片段/活动中的数据,但当我尝试在选项卡中充气按钮时,它不起作用

你能帮我吗? 下面是我修改的列表活动,在双窗格模式下显示选项卡

package com.example.sample;

import android.content.Intent;
import android.os.Bundle;
import android.support.v4.app.Fragment;
import android.support.v4.app.FragmentTransaction;

import com.actionbarsherlock.app.ActionBar;
import com.actionbarsherlock.app.ActionBar.Tab;
import com.actionbarsherlock.app.SherlockFragmentActivity;

/**
 * An activity representing a list of Courses. This activity has different
 * presentations for handset and tablet-size devices. On handsets, the activity
 * presents a list of items, which when touched, lead to a
 * {@link CourseDetailActivity} representing item details. On tablets, the
 * activity presents the list of items and item details side-by-side using two
 * vertical panes.
 * <p>
 * The activity makes heavy use of fragments. The list of items is a
 * {@link CourseListFragment} and the item details (if present) is a
 * {@link CourseDetailFragment}.
 * <p>
 * This activity also implements the required
 * {@link CourseListFragment.Callbacks} interface to listen for item selections.
 */
public class CourseListActivity extends SherlockFragmentActivity implements
    CourseListFragment.Callbacks {

/**
 * Whether or not the activity is in two-pane mode, i.e. running on a tablet
 * device.
 */
private boolean mTwoPane;
private boolean once = true;

@Override
public void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_course_list);

    if (findViewById(R.id.course_detail_container) != null) {
        // The detail container view will be present only in the
        // large-screen layouts (res/values-large and
        // res/values-sw600dp). If this view is present, then the
        // activity should be in two-pane mode.
        mTwoPane = true;

        // In two-pane mode, list items should be given the
        // 'activated' state when touched.
        ((CourseListFragment) getSupportFragmentManager().findFragmentById(
                R.id.course_list)).setActivateOnItemClick(true);
    }

    // TODO: If exposing deep links into your app, handle intents here.
}

/**
 * Callback method from {@link CourseListFragment.Callbacks} indicating that
 * the item with the given ID was selected.
 */
@Override
public void onItemSelected(String id) {
    if (mTwoPane) {
        // In two-pane mode, show the detail view in this activity by
        // adding or replacing the detail fragment using a
        // fragment transaction.
        CourseDetailFragment fragment = new CourseDetailFragment();
        getSupportFragmentManager().beginTransaction()
                .replace(R.id.course_detail_container, fragment).commit();
        if (once) {
        ActionBar actionBar = getSupportActionBar();
        actionBar.setNavigationMode(ActionBar.NAVIGATION_MODE_TABS);
        // initiating both tabs and set text to it.
        ActionBar.Tab assignTab = actionBar.newTab().setText("Assignments");
        ActionBar.Tab schedTab = actionBar.newTab().setText("Schedule");
        ActionBar.Tab contactTab = actionBar.newTab().setText("Contact");

        // Create three fragments to display content
        Fragment assignFragment = new Assignments();
        Fragment schedFragment = new Schedule();
        Fragment contactFragment = new Contact();

        assignTab.setTabListener(new MyTabsListener(assignFragment));
        schedTab.setTabListener(new MyTabsListener(schedFragment));
        contactTab.setTabListener(new MyTabsListener(contactFragment));

        actionBar.addTab(assignTab);
        actionBar.addTab(schedTab);
        actionBar.addTab(contactTab);
        once = false;
        }
    } else {
        // In single-pane mode, simply start the detail activity
        // for the selected item ID.
        Intent detailIntent = new Intent(this, CourseDetailActivity.class);
        startActivity(detailIntent);
    }

}
class MyTabsListener implements ActionBar.TabListener {
    public Fragment fragment;

    public MyTabsListener(Fragment fragment) {
        this.fragment = fragment;
    }

    @Override
    public void onTabReselected(Tab tab, FragmentTransaction ft) {
    }

    @Override
    public void onTabSelected(Tab tab, FragmentTransaction ft) {
            ft.replace(R.id.twopanecontainer, fragment);
    }

    @Override
    public void onTabUnselected(Tab tab, FragmentTransaction ft) {
        ft.remove(fragment);
}
}
}
package com.example.sample;
导入android.content.Intent;
导入android.os.Bundle;
导入android.support.v4.app.Fragment;
导入android.support.v4.app.FragmentTransaction;
导入com.actionbarsherlock.app.ActionBar;
导入com.actionbarsherlock.app.ActionBar.Tab;
导入com.actionbarsherlock.app.SherlockFragmentActivity;
/**
*表示课程列表的活动。这项活动有不同的特点
*手机和平板电脑大小设备的演示文稿。在手机上,活动
*显示一个项目列表,当触摸该列表时,将导致
*{@link CourseDetailActivity}表示项目详细信息。在平板电脑上
*活动使用两种方式并排显示项目列表和项目详细信息
*垂直窗格。
*
*该活动大量使用片段。项目列表是一个
*{@link CourseListFragment}并且项目详细信息(如果存在)是
*{@link CourseDetailFragment}。
*
*此活动还实现了所需的
*{@link CourseListFragment.Callbacks}接口侦听项选择。
*/
公共类CourseListativity扩展了SherlockFragmentActivity实现
CourseListFragment.回调{
/**
*活动是否处于双窗格模式,即在平板电脑上运行
*装置。
*/
私有布尔值窗格;
private boolean once=true;
@凌驾
创建时的公共void(Bundle savedInstanceState){
super.onCreate(savedInstanceState);
setContentView(R.layout.activity\u course\u list);
if(findViewById(R.id.course\u detail\u container)!=null){
//详图容器视图将仅显示在
//大屏幕布局(分辨率/大小和
//res/values-sw600dp)。如果存在此视图,则
//活动应处于双窗格模式。
mTwoPane=true;
//在双窗格模式下,列表项应具有
//触摸时处于“激活”状态。
((CourseListFragment)getSupportFragmentManager().findFragmentById(
R.id.course_list)).setActivateOnItemClick(true);
}
//TODO:如果在应用程序中公开深层链接,请在此处处理意图。
}
/**
*来自{@link CourseListFragment.Callbacks}的回调方法,指示
*已选择具有给定ID的项目。
*/
@凌驾
已选择公共id(字符串id){
如果(mTwoPane){
//在双窗格模式下,按显示此活动中的详细信息视图
//使用
//片段事务。
CourseDetailFragment=新的CourseDetailFragment();
getSupportFragmentManager().beginTransaction()
.replace(R.id.course\u detail\u容器,片段).commit();
如果(一次){
ActionBar ActionBar=getSupportActionBar();
actionBar.setNavigationMode(actionBar.NAVIGATION\u MODE\u选项卡);
//启动两个选项卡并设置文本。
ActionBar.Tab assignTab=ActionBar.newTab().setText(“赋值”);
ActionBar.Tab schedTab=ActionBar.newTab().setText(“时间表”);
ActionBar.Tab contactTab=ActionBar.newTab().setText(“联系人”);
//创建三个片段以显示内容
Fragment assignFragment=新赋值();
片段schedFragment=新计划();
Fragment contactFragment=新联系人();
assignTab.setTabListener(新的MyTabsListener(assignFragment));
schedTab.setTabListener(新的MyTabsListener(schedFragment));
contactTab.setTabListener(新的MyTabsListener(contactFragment));
actionBar.addTab(assignTab);
actionBar.addTab(schedTab);
actionBar.addTab(contactTab);
一次=假;
}
}否则{
//在单窗格模式下,只需启动详细信息活动
//对于所选项目ID。
Intent detailIntent=新的Intent(这个,CourseDetailActivity.class);
星触觉(意向);
}
}
类MyTabsListener实现ActionBar.TablListener{
公共碎片;
公共MyTabsListener(片段){
this.fragment=片段;
}
@凌驾
已重新选择公共无效页签(页签,碎片事务){
}
@凌驾
已选择的公共事务(选项卡,碎片事务ft){
ft.更换(R.id.twopanecontainer,碎片);
}
@凌驾
已选择公共空页(选项卡,碎片事务ft){
ft.去除(碎片);
}
}
}
下面是默认情况下保存文本视图的片段课程详细布局

<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    android:id="@+id/twopanecontainer"
    android:layout_width="match_parent"
    android:layout_height="match_parent" >

    <TextView
        android:id="@+id/course_detail"
        style="?android:attr/textAppearanceLarge"
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:padding="16dp"
        tools:context=".CourseDetailFragment" />

</LinearLayout>

我应该修改什么,以便为每个选项卡膨胀不同的视图


谢谢

在您的活动布局中设置一个ViewPager,然后实施FragmentPagerAdapter