ไม่สามารถพันหัวของฉันกับชิ้นส่วน Android ได้

ฉันกำลังดิ้นรนที่จะพันหัวเรื่องเศษและกิจกรรมต่างๆ

ฉันกำลังเขียนแอปที่ใช้ ActionBar เพื่อนำทางผ่านรายการ "รายการเสียงเด่น" และรายการ "โปรแกรม" ซึ่งมีรายการ "รายการเสียง" ของตัวเอง ฉันใช้ ActionBarSherlock และแพ็คเกจความเข้ากันได้

เมื่อคุณคลิกที่แท็บ ActionBar ควรแสดงกิจกรรม/แฟรกเมนต์นั้น เมื่อคุณคลิกที่บางสิ่งในรายการ ควรเปิดส่วน/กิจกรรมใหม่ซึ่งจะแสดงรายการโปรแกรม/เสียงนั้น

ฉันได้ดูการสาธิต/ตัวอย่างต่างๆ แล้ว และเข้าใจว่ามีหลายวิธีในการดำเนินการนี้

คำถามของฉัน:

  • What's the structure of the programme?
    • e.g. An activity for every fragment? One activity with many fragments?
  • How do you navigate the fragments?
    • e.g. Intents?
  • ฉันจะมี ActionBar แบบถาวรในทุกกิจกรรมได้อย่างไร

ขอบคุณสำหรับความช่วยเหลือที่คุณสามารถให้ได้

แก้ไข - ตอบคำถามของฉันเอง:

ดังนั้นฉันจึงใช้แนวทางนี้:

  • กิจกรรมหลักซึ่งเริ่มต้น ActionBar จัดการการนำทางส่วนหลัก
  • แต่ละ Fragment หลักจะมี onClickListener
  • onClickListener จะแทนที่ Fragment ที่แสดงอยู่ในปัจจุบันด้วยอันใหม่ ซึ่งเตรียมใช้งานไว้เพื่อแสดงรายการที่ถูกต้อง

สิ่งนี้อิงจากการสาธิต ActionbarSherlock FragmentLayoutSupport ที่ฉันพูดถึงในความคิดเห็น

ตัวอย่างส่วนของรายการหลัก:

//public class ProgrammesFragment extends SherlockListFragment

@Override
public void onListItemClick(ListView l, View v, int position, long id) {
    showDetails(id);
}

/**
 * Helper function to show the details of a selected item, either by
 * displaying a fragment in-place in the current UI, or starting a
 * whole new activity in which it is displayed.
 */
void showDetails(long index) {
    // Check what fragment is currently shown, replace if needed.
    ProgrammeFragment details = (ProgrammeFragment) getFragmentManager().findFragmentByTag(ProgrammeFragment.TAG);
    if (details == null || details.getShownIndex() != index) {
        // Make new fragment to show this selection.
        details = ProgrammeFragment.newInstance(index);

        // Execute a transaction, replacing any existing fragment
        // with this one inside the frame.
        FragmentTransaction ft = getFragmentManager().beginTransaction();
        ft.remove(getFragmentManager().findFragmentByTag(ProgrammesFragment.TAG));
        ft.add(android.R.id.content, details, ProgrammeFragment.TAG);
        ft.addToBackStack(null);
        ft.commit();
    }
}

รายละเอียดข้อมูลโค้ดส่วนย่อย:

//public class ProgrammeFragment extends SherlockListFragment

/**
 * Create a new instance of ProgrammeFragment, initialized to
 * show the text at 'index'.
 */
public static ProgrammeFragment newInstance(long index) {
    ProgrammeFragment f = new ProgrammeFragment();

    // Supply index input as an argument.
    Bundle args = new Bundle();
    args.putLong("programme_id", index);
    f.setArguments(args);

    return f;
}

public long getShownIndex() {
    return getArguments().getLong("programme_id", 0);
}

ส่วนรายละเอียดกำลังใช้ LoaderManager ที่ด้านบนของ SQL ContentResolver และเรียก getShownIndex เพื่อสร้างเงื่อนไขสำหรับแบบสอบถามแบบใช้เลือกข้อมูล

ใช้งานได้ (ตอนนี้) ไม่แน่ใจเกี่ยวกับการใช้หน่วยความจำหรืออะไรทำนองนั้น แต่เราจะได้เห็นกัน!

ดูเหมือนว่า SO จะดีในการทำให้ความคิดชัดเจนขึ้นในใจของคุณ เพื่อให้คุณสามารถตอบคำถามของคุณเองได้ :P


person Nick Malcolm    schedule 03.04.2012    source แหล่งที่มา
comment
ตัวอย่างเช่น วิธีหนึ่งในการทำเช่นนี้จะแสดงในการสาธิต ตัวอย่าง ActionBarSherlock Fragments ชื่อ FragmentLayoutSupport ในนั้นแต่ละแฟรกเมนต์มีกิจกรรม และทั้งแฟรกเมนต์และกิจกรรมจะถูกนำไปใช้เป็นคลาสภายใน ดูเหมือนว่าจะขัดจุดประสงค์ของการมีชิ้นส่วนที่นำกลับมาใช้ใหม่ได้...   -  person Nick Malcolm    schedule 03.04.2012
comment
ฉันควรทราบด้วยว่าฉันไม่สนใจเลย์เอาท์ใดๆ ยกเว้นแนวตั้งบนสมาร์ทโฟน ไม่กังวลเรื่องเศษติดกัน ฯลฯ   -  person Nick Malcolm    schedule 03.04.2012


คำตอบ (1)


ใน onCreate กิจกรรมหลักของคุณ คุณสร้างและเพิ่มแท็บทั้งหมด (หนึ่งแท็บ = 1 คลาส SherlockFragment) ในกิจกรรมหลักของคุณ คุณต้องมีคลาสภายในที่เป็น TabAdapter ในตัวอย่างของฉันด้านล่าง TabAdapter ก็เป็น ViewPager เช่นกัน ดังนั้นคุณจึงสามารถปัดไปที่ใดก็ได้บนหน้าจอ ซ้าย-ขวา เพื่อสลับระหว่างแท็บต่างๆ นี่คือคลาสหลัก:

import java.util.ArrayList;
import library.DatabaseHandler;
import library.UserFunctions;

import org.json.JSONObject;
import com.actionbarsherlock.R;
import com.actionbarsherlock.app.ActionBar;
import com.actionbarsherlock.app.ActionBar.Tab;
import com.actionbarsherlock.app.SherlockFragment;
import com.actionbarsherlock.app.SherlockFragmentActivity;
import com.actionbarsherlock.view.Menu;
import com.actionbarsherlock.view.MenuInflater;
import com.actionbarsherlock.view.MenuItem;

import android.app.AlertDialog;
import android.app.Dialog;
import android.app.ProgressDialog;
import android.content.Context;
import android.content.DialogInterface;
import android.content.Intent;
import android.content.SharedPreferences;
import android.os.Bundle;
import android.util.Log;
import android.view.View.OnClickListener;
import android.view.View;
import android.widget.Button;
import android.widget.CheckBox;
import android.widget.EditText;
import android.widget.Switch;
import android.widget.TextView;
import android.widget.Toast;
import android.support.v4.app.Fragment;
import android.support.v4.app.FragmentActivity;
import android.support.v4.app.FragmentManager;
import android.support.v4.app.FragmentPagerAdapter;
import android.support.v4.app.FragmentTransaction;
import android.support.v4.view.ViewPager;
import android.support.v4.view.ViewPager.OnPageChangeListener;

public class Polling extends SherlockFragmentActivity {
    private ViewPager mViewPager;
    private TabsAdapter mTabsAdapter;
    ActionBar bar;

    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        mViewPager = new ViewPager(this);
        mViewPager.setId(R.id.pager);
        setContentView(mViewPager);
        bar = getSupportActionBar();
        bar.setNavigationMode(ActionBar.NAVIGATION_MODE_TABS);
        bar.setDisplayShowTitleEnabled(false);
        bar.setDisplayShowHomeEnabled(false);

        mTabsAdapter = new TabsAdapter(this, mViewPager);
        mTabsAdapter.addTab(bar.newTab().setText(R.string.login),
                LoginFragment.class, null);
        mTabsAdapter.addTab(bar.newTab().setText(R.string.economics),
                EconFragment.class, null);
        mTabsAdapter.addTab(bar.newTab().setText(R.string.elections),
                ElectionsFragment.class, null);
        mTabsAdapter.addTab(bar.newTab().setText(R.string.politics),
                PoliticsFragment.class, null);
        mTabsAdapter.addTab(bar.newTab().setText(R.string.science),
                ScienceFragment.class, null);
        mTabsAdapter.addTab(bar.newTab().setText(R.string.finance),
                FinanceFragment.class, null);
        mTabsAdapter.addTab(bar.newTab().setText(R.string.religion),
                ReligionFragment.class, null);
        mTabsAdapter.addTab(bar.newTab().setText(R.string.military),
                MilitaryFragment.class, null);
        mTabsAdapter.addTab(bar.newTab().setText(R.string.international),
                InternationalFragment.class, null); 
    }


    public static class TabsAdapter extends FragmentPagerAdapter
    implements ActionBar.TabListener, ViewPager.OnPageChangeListener {
        private final Context mContext;
        private final ActionBar mActionBar;
        private final ViewPager mViewPager;
        private final ArrayList<TabInfo> mTabs = new ArrayList<TabInfo>();

        static final class TabInfo {
            private final Class<?> clss;
            private final Bundle args;

            TabInfo(Class<?> _class, Bundle _args) {
                clss = _class;
                args = _args;
            }
        }

        public TabsAdapter(SherlockFragmentActivity activity, ViewPager pager) {
            super(activity.getSupportFragmentManager());
            mContext = activity;
            mActionBar = activity.getSupportActionBar();
            mViewPager = pager;
            mViewPager.setAdapter(this);
            mViewPager.setOnPageChangeListener(this);
        }

        public void addTab(ActionBar.Tab tab, Class<?> clss, Bundle args) {
            TabInfo info = new TabInfo(clss, args);
            tab.setTag(info);
            tab.setTabListener(this);
            mTabs.add(info);
            mActionBar.addTab(tab);
            notifyDataSetChanged();
        }

        public int getCount() {
            return mTabs.size();
        }

        public SherlockFragment getItem(int position) {
            TabInfo info = mTabs.get(position);
            return (SherlockFragment)Fragment.instantiate(mContext, info.clss.getName(), info.args);
        }

        public void onPageSelected(int position) {
            mActionBar.setSelectedNavigationItem(position);
        }
        public void onPageScrollStateChanged(int state) {}
        public void onPageScrolled(int position, float positionOffset, int positionOffsetPixels) {}

        public void onTabSelected(Tab tab, FragmentTransaction ft) {
            mViewPager.setCurrentItem(tab.getPosition());
            //Log.v(TAG, "clicked");
            Object tag = tab.getTag();
            for (int i=0; i<mTabs.size(); i++) {
                if (mTabs.get(i) == tag) {
                    mViewPager.setCurrentItem(i);
                }
            }
        }
        public void onTabUnselected(Tab tab, FragmentTransaction ft) {}
        public void onTabReselected(Tab tab, FragmentTransaction ft) {}
        public void onTabReselected(Tab tab, android.app.FragmentTransaction ft) {}
        public void onTabUnselected(Tab tab, android.app.FragmentTransaction ft) {}
    }
}

นี่คือส่วนที่ไม่มี UI ที่สำคัญ (เพียงไฟล์ xml ที่มี TextView อยู่ในนั้น):

import com.actionbarsherlock.R;
import com.actionbarsherlock.app.SherlockFragment;

import android.support.v4.app.Fragment;
import android.os.Bundle;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;

public class FinanceFragment extends SherlockFragment {

@Override
public View onCreateView(LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState) {

        return inflater.inflate(R.layout.financefragment, container, false);
    }
}

ส่วนอื่นที่มี UI ชั่วคราวใน onResume/onCreateView:

import com.actionbarsherlock.R;
import com.actionbarsherlock.app.SherlockFragment;
import android.app.Activity;
import android.app.AlertDialog;
import android.content.Context;
import android.content.Intent;
import android.os.Bundle;
import android.util.Log;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.view.View.OnClickListener;
import android.view.ViewGroup.LayoutParams;
import android.view.inputmethod.InputMethodManager;
import android.widget.Button;
import android.widget.LinearLayout;
import android.widget.RelativeLayout;
import android.widget.ScrollView;
import android.widget.TableLayout;
import android.widget.TableRow;
import android.widget.TextView;

public class EconFragment extends SherlockFragment {

    private TableLayout questionContainer;
    int pos = 0;
    private String[] titles = {"The first title ", "hallo1","hallo2", "hallo3",
            "hallo4", "hallo5","hallo6", "hallo7","hallo8", "hallo9"};

    public View onCreateView(LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState) {
        Log.v("Econ", "onCreateView");
        View v = inflater.inflate(R.layout.econfragment, container, false);
        questionContainer = (TableLayout) v.findViewById(R.id.questionContainer);
        //bs
        int leftMargin=5;
        int topMargin=5;
        int rightMargin=5;
        int bottomMargin=5;
        while (pos < 10) {
        View question = inflater.inflate(R.layout.question, null);
        question.setId(pos);
        TextView title = (TextView) question.findViewById(R.id.questionTextView);
        title.setText(titles[pos]);
        Button charts = (Button) question.findViewById(R.id.chartsButton);
        charts.setId(pos);
        charts.setOnClickListener(chartsListener);
        TableRow tr = (TableRow) question;
        TableLayout.LayoutParams trParams = new TableLayout.LayoutParams(
                TableLayout.LayoutParams.MATCH_PARENT,
                TableLayout.LayoutParams.WRAP_CONTENT);
        trParams.setMargins(leftMargin, topMargin, rightMargin, bottomMargin);
        tr.setLayoutParams(trParams);
        Log.v("econ", "while loop");
        questionContainer.addView(tr);
        pos++;
        }
        pos = 0;
        return v;
    }

    public void onResume() {
        super.onResume();
        Log.v("Econ", "onResume");
    }

    public OnClickListener chartsListener = new OnClickListener() {

        @Override
        public void onClick(View v) {
            Intent chart = new Intent();
            chart.setClass(getActivity(), Chart.class);
            chart.putExtra("key", titles[v.getId()]);
            Log.v("TAG", Integer.toString(v.getId()));
            startActivity(chart);

        }

    };

    public void onAttach(Activity activity) {
        super.onAttach(activity);
        Log.d("Econ", "onAttach");
    }

    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        Log.d("Econ", "onCreate");
        //Log.v("ECON", savedInstanceState.toString());

    }

    public void onActivityCreated(Bundle savedInstanceState) {
        super.onActivityCreated(savedInstanceState);
        Log.d("Econ", "onActivityCreated");
    }

    public void onStart() {
        super.onStart();
        Log.d("Econ", "OnStart");
    }

    public void onPause() {
        super.onPause();    
        Log.d("Econ", "onpause");
    }

    public void onStop() {
        super.onStop();
        Log.d("Econ", "onstop");
    }

    public void onDestroyView() {
        super.onDestroyView();
        Log.d("Econ", "ondestroyview");
    }

    public void onDestroy() {
        super.onDestroy();
        Log.d("Econ", "ondestroy");

    }

    public void onDetach() {
        super.onDetach();
        Log.d("Econ", "ondetach");
    }
}

แก้ไข ~ ฉันยังไม่ได้บันทึกรหัสของฉัน - บางส่วนเป็นเพียงตัวอย่างที่ฉันพบทางออนไลน์ หากมีอุปสรรค์หรือสิ่งที่คุณไม่เข้าใจก็ถามได้เลย

person Davek804    schedule 03.04.2012
comment
ขอบคุณ. ฉันเข้าใจวิธีแสดงส่วนย่อยและเพิ่มแท็บใน ActionBar โดยทั่วไป สิ่งที่ฉันไม่เข้าใจคือจะนำทางระหว่างส่วนต่างๆ ได้อย่างไรเมื่อคุณคลิกที่รายการ ฉันไม่เห็นสิ่งนั้นในตัวอย่างของคุณ - person Nick Malcolm; 03.04.2012
comment
ฉันเพิ่งย้อนกลับไปดูในหนังสือที่สอนฉันเรื่องนี้มากมาย และตัวอย่างของ ListFragment ก็ค่อนข้างแย่ - person Davek804; 03.04.2012