通过单击另一个活动

时间:2017-06-26 16:56:32

标签: java android listview android-fragments android-activity

首先,如果已经提出并回答了类似的问题,我道歉,但我已经查看了大量的帖子而没有任何运气。其次,我是一个绝对的初学者(已经编写了6周),所以如果我错过了一些概念或者有更好的方法可以做,请随时赐教。

现在,我的问题是: 在我的MainActivity上,我有一个具有 ListView 的EventsFragment。 MainActivity上还有一个FloatingActionBar,点击它时会加载另一个名为CreateEventActivity的Activity。 CreateEventActivity有一个EditText字段和一个Create Button。我想要做的是当用户在EditText字段中输入一些文本并单击创建按钮时,它应该从EditText字段中获取字符串,并在 ListView 上创建一个项目,其中包含String作为其名称。此外,只要单击“创建”按钮,它就应该返回到MainActivity中的EventsFragment。

我按照建议使用了startActivityForResults(),似乎我能够将一个ArrayList作为意图从CreateEventActivity传递回MainActivity,这就是我能够得到的。我认为我将列表发送到EventsFragment的方式是错误的,因为listView没有更新。

MainActivity -

    public class MainActivity extends AppCompatActivity {

        /**
         * The {@link android.support.v4.view.PagerAdapter} that will provide
         * fragments for each of the sections. We use a
         * {@link FragmentPagerAdapter} derivative, which will keep every
         * loaded fragment in memory. If this becomes too memory intensive, it
         * may be best to switch to a
         * {@link android.support.v4.app.FragmentStatePagerAdapter}.
         */
        private SectionsPagerAdapter mSectionsPagerAdapter;

        /**
         * The {@link ViewPager} that will host the section contents.
         */
        private ViewPager mViewPager;

        @Override
        protected void onCreate(Bundle savedInstanceState) {
            super.onCreate(savedInstanceState);
            setContentView(R.layout.activity_main);

            Toolbar toolbar = (Toolbar) findViewById(R.id.toolbar);
            setSupportActionBar(toolbar);
            // Create the adapter that will return a fragment for each of the three
            // primary sections of the activity.
            mSectionsPagerAdapter = new SectionsPagerAdapter(getSupportFragmentManager(), MainActivity.this);

            // Set up the ViewPager with the sections adapter.
            mViewPager = (ViewPager) findViewById(R.id.container);
            mViewPager.setAdapter(mSectionsPagerAdapter);

            TabLayout tabLayout = (TabLayout) findViewById(R.id.tabs);
            tabLayout.setupWithViewPager(mViewPager);

            //Iterate over all TabLayouts to set the custom View
            for (int i = 0; i < tabLayout.getTabCount(); i++){
                TabLayout.Tab tab = tabLayout.getTabAt(i);
                tab.setCustomView(mSectionsPagerAdapter.getTabView(i));
            }

            FloatingActionButton fab = (FloatingActionButton) findViewById(R.id.fab);
            fab.setOnClickListener(new View.OnClickListener() {
                @Override
                public void onClick(View view) {
                    loadCreateEventActivity();
    //                Snackbar.make(view, "Here the create a New Event Screen will be displayed", Snackbar.LENGTH_LONG)
    //                        .setAction("Action", null).show();
                }
            });

        }


        private void loadCreateEventActivity(){

            Intent intent = new Intent(MainActivity.this, CreateEventActivity.class);
            startActivityForResult(intent, 2);
        }

        public ArrayList<String>list = new ArrayList<>();

        @Override
        protected void onActivityResult(int requestCode, int resultCode, Intent data) {
            super.onActivityResult(requestCode, resultCode, data);
            if (requestCode == 2){
                if (resultCode == RESULT_OK) {

                    list = data.getStringArrayListExtra("LIST_ITEMS");
                }
            }
        }

        public ArrayList<String> getList() {
            return list;
        }

CreatEventsActivity -

public class CreateEventActivity extends AppCompatActivity {

    EditText createEventName;
    Button createButton;
    ArrayList<String> listItems;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_create_event);

        createEventName = (EditText) findViewById(R.id.createEventName);
        createButton = (Button) findViewById(R.id.createButton);
        listItems = new ArrayList<String>();
        listItems.add("First Item - added on Activity Create");

        createButton.setOnClickListener(new View.OnClickListener() {

            public void onClick(View v) {
                listItems.add(createEventName.getText().toString());
                Intent intent = new Intent();
                intent.putStringArrayListExtra("LIST_ITEMS", listItems);
                setResult(RESULT_OK, intent);
                createEventName.setText("");
                finish();
            }
        });
    }
}

EventsFragment -

public class EventsFragment extends Fragment {


    public EventsFragment() {
        // Required empty public constructor
    }

    @Override
    public void onCreate(@Nullable Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
    }

    @Override
    public View onCreateView(LayoutInflater inflater, ViewGroup container,
                             Bundle savedInstanceState) {
        View view = inflater.inflate(R.layout.fragment_events, container, false);

        MainActivity mainActivity = (MainActivity) getActivity();
        ArrayList<String>list = mainActivity.getList();

        ListView listView = (ListView)view.findViewById(R.id.list_view);

        ArrayAdapter<String> adapter = new ArrayAdapter<String>(getActivity().getApplicationContext(),android.R.layout.simple_list_item_1, list);
        listView.setAdapter(adapter);
        adapter.notifyDataSetChanged();

        return view;
    }
}

感谢您提前提供任何帮助:)

1 个答案:

答案 0 :(得分:0)

解决方案1: 您需要拥有一个数据集,这对两个活动都是通用的。 每次单击时,都会向该数据集添加一个项目。 使用该相同的数据集填充列表视图。 由于它们都处于不同的活动中,因此您需要保留该数据集。

您可以在json中使用table(database)[shared preference][1]字符串存储,将其保存在本地。

保留数据集的另一个捷径是将您的数据设置为Application类中的属性,这样您就可以从应用程序中的任何activity添加和访问数据集,如application类在应用程序的整个生命周期中都处于活动状态。 我不推荐这个。这很简单并且有效,但这并不是一种好的做法,会导致严重的代码质量,但如果您只是想快速实现它,那么就可以做到。

解决方案2:在您的主要活动中,使用startActivityForResult()开始第二项活动。这将让你做的是让第二个活动回到第一个活动。所以当它回过头来时,你可以在第一个中知道在第二个中添加了多少项,并相应地更新你的第一个活动的listView。