当前位置: 首页 > 知识库问答 >
问题:

当数据在一个片段中更改时,如何刷新另一个片段中的RecyclerView

薛涛
2023-03-14

如何在成功提交数据时将数据从本地数据库刷新到RecyclerView?我使用应用程序上的选项卡。2nd-tab函数提交数据,如果成功,数据将存储在localdb中。

关于localdb的数据将在3rd-tab中显示。但是发生的情况是,我必须滑动1st-tab,然后滑动到2nd-tab,然后滑动到我的LocalDB上成功显示的新的3rd-tab数据。

主要活动:

import android.os.Bundle;
import android.support.design.widget.TabLayout;
import android.support.v4.app.Fragment;
import android.support.v4.app.FragmentManager;
import android.support.v4.app.FragmentPagerAdapter;
import android.support.v4.view.ViewPager;
import android.support.v7.app.AppCompatActivity;
import android.support.v7.widget.Toolbar;

import com.bertho.gmyl.fragments.EngagedFragment;
import com.bertho.gmyl.fragments.RequestFragment;
import com.bertho.gmyl.fragments.SigninFragment;

import java.util.ArrayList;
import java.util.List;

public class MainActivity extends AppCompatActivity {

    private static final String TAG = MainActivity.class.getSimpleName();

    private Toolbar toolbar;
    private TabLayout tabLayout;
    private ViewPager viewPager;

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

        toolbar = (Toolbar) findViewById(R.id.toolbar);
        setSupportActionBar(toolbar);
        //getSupportActionBar().setDisplayHomeAsUpEnabled(true);

        viewPager = (ViewPager) findViewById(R.id.viewpager);
        setupViewPager(viewPager);

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

    private void setupViewPager(ViewPager viewPager) {
        ViewPagerAdapter adapter = new ViewPagerAdapter(getSupportFragmentManager());
        adapter.addFrag(new SigninFragment(), "SIGN-IN");
        adapter.addFrag(new EngagedFragment(), "ENGAGED ID");
        adapter.addFrag(new RequestFragment(), "LOCATION");
        viewPager.setAdapter(adapter);
    }

    class ViewPagerAdapter extends FragmentPagerAdapter {
        private final List<Fragment> mFragmentList = new ArrayList<>();
        private final List<String> mFragmentTitleList = new ArrayList<>();

        public ViewPagerAdapter(FragmentManager manager) {
            super(manager);
        }

        @Override
        public Fragment getItem(int position) {
            return mFragmentList.get(position);
        }

        @Override
        public int getCount() {
            return mFragmentList.size();
        }

        public void addFrag(Fragment fragment, String title) {
            mFragmentList.add(fragment);
            mFragmentTitleList.add(title);
        }

        @Override
        public CharSequence getPageTitle(int position) {
            return mFragmentTitleList.get(position);
        }
    }

}
import android.os.Bundle;
import android.support.design.widget.Snackbar;
import android.support.v4.app.Fragment;
import android.support.v7.app.AppCompatActivity;
import android.util.Log;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.Button;
import android.widget.EditText;
import android.widget.RelativeLayout;
import android.widget.TextView;

import com.bertho.gmyl.R;
import com.bertho.gmyl.model.Engaged;
import com.google.firebase.database.DataSnapshot;
import com.google.firebase.database.DatabaseError;
import com.google.firebase.database.DatabaseReference;
import com.google.firebase.database.FirebaseDatabase;
import com.google.firebase.database.ValueEventListener;
import com.bertho.gmyl.realm.RealmHelper;

public class EngagedFragment extends Fragment implements View.OnClickListener {

    private static final String TAG = EngagedFragment.class.getSimpleName();

    private EditText nama, email, nohp;
    private Button btnSaveConnection;
    private DatabaseReference mFirebaseDatabase;
    private FirebaseDatabase mFirebaseInstance;
    private RelativeLayout mRoot;
    private View rootView;
    private String userId;
    private TextView lblNama, lblEmail, lblNohp;
    private RelativeLayout relativeLayout;

    private RealmHelper realmHelper;


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

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

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

        rootView = inflater.inflate(R.layout.fragment_engaged, container, false);

        realmHelper = new RealmHelper(getActivity());

        String appName = getResources().getString(R.string.app_name);

        loadLocalDB();

        nama = (EditText) rootView.findViewById(R.id.txtName);
        email = (EditText) rootView.findViewById(R.id.txtEmail);
        nohp = (EditText) rootView.findViewById(R.id.txtNoHp);

        lblNama = (TextView) rootView.findViewById(R.id.lblNameval);
        lblEmail = (TextView) rootView.findViewById(R.id.lblEmailval);
        lblNohp = (TextView) rootView.findViewById(R.id.lblNohpval);
        relativeLayout = (RelativeLayout) rootView.findViewById(R.id.panelLabelDetail);
        btnSaveConnection = (Button) rootView.findViewById(R.id.btnEngaged);


        mFirebaseInstance = FirebaseDatabase.getInstance();

        mFirebaseDatabase = mFirebaseInstance.getReference("tbl_engaged");

        mFirebaseInstance.getReference("titleapp").setValue(appName);

        mFirebaseInstance.getReference("titleapp").addValueEventListener(new ValueEventListener() {
            @Override
            public void onDataChange(DataSnapshot dataSnapshot) {
                Log.e(TAG, "TITLE UPDATED FROM FIREBASE");
                String appTitle = dataSnapshot.getValue(String.class);
                ((AppCompatActivity)getActivity()).getSupportActionBar().setTitle(appTitle);
            }

            @Override
            public void onCancelled(DatabaseError error) {
                Log.e(TAG, "FAILED TO READ TITLE FROM FIREBASE.", error.toException());
            }
        });

        btnSaveConnection.setOnClickListener(this);

        return rootView;
    }

    private void showSnack(String notify) {
        mRoot = (RelativeLayout) rootView.findViewById(R.id.frag_engaged);
        Snackbar snackbar = Snackbar.make(mRoot, notify, Snackbar.LENGTH_LONG);
        snackbar.show();
    }

    public void onClick(View v) {

        if(v.getId() == R.id.btnEngaged) {

            String txtName = nama.getText().toString();
            String txtEmail = email.getText().toString();
            String txtNo = nohp.getText().toString();

            if(txtName.equals("") || txtName.isEmpty()) {
                showSnack("Name must filled");
                nama.requestFocus();
            } else if (txtEmail.equals("") || txtEmail.isEmpty()) {
                showSnack("Email must filled");
                email.requestFocus();
            } else if (txtNo.equals("") || txtNo.isEmpty()) {
                showSnack("No.HP must filled");
                nohp.requestFocus();
            } else {
                createUser(txtName, txtEmail, txtNo);
                saveToLocalDB(txtName, txtEmail, txtNo);
            }
        }
    }

    private void saveToLocalDB(String txtName, String txtEmail, String txtNo) {
        realmHelper.addEngaged(txtName, txtEmail, txtNo);
    }

    private void loadLocalDB() {
        realmHelper.getAllData();
    }

    private void createUser(String name, String email, String nohp) {
        userId = mFirebaseDatabase.push().getKey();
        Engaged user = new Engaged(name, email, nohp);
        mFirebaseDatabase.child(userId).setValue(user);
        addUserChangeListener();
    }

    private void addUserChangeListener() {

        mFirebaseDatabase.child(userId).addValueEventListener(new ValueEventListener() {
            @Override
            public void onDataChange(DataSnapshot dataSnapshot) {
                Engaged user = dataSnapshot.getValue(Engaged.class);

                if (user == null) {
                    Log.e(TAG, "ENGAGED DATA IS NULL");
                    return;
                }

                Log.e(TAG, "ENGAGED DATA IS CHANGED!" + user.name + ", " + user.email);

                lblNama.setText(user.name);
                lblEmail.setText(user.email);
                lblNohp.setText(user.nohp);

                //relativeLayout.setVisibility(View.VISIBLE);

                nama.setText("");
                email.setText("");
                nohp.setText("");
            }

            @Override
            public void onCancelled(DatabaseError error) {
                // Failed to read value
                Log.e(TAG, "FAILED TO READ USER", error.toException());
            }
        });
    }
}
import android.content.Intent;
import android.os.Bundle;
import android.support.v4.app.Fragment;
import android.support.v7.widget.LinearLayoutManager;
import android.support.v7.widget.RecyclerView;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.Toast;

import com.bertho.gmyl.R;
import com.bertho.gmyl.adapter.AdapterEngaged;
import com.bertho.gmyl.model.ModelEngaged;
import com.bertho.gmyl.realm.RealmHelper;

import java.util.ArrayList;

public class RequestFragment extends Fragment {

    private static final String TAG = "RequestFragment";
    private RecyclerView recyclerView;
    private View rootView;
    private ArrayList<ModelEngaged> data;
    private RealmHelper helper;

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

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

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

        rootView =  inflater.inflate(R.layout.fragment_request, container, false);

        data = new ArrayList<>();
        helper = new RealmHelper(getActivity());

        recyclerView = (RecyclerView) rootView.findViewById(R.id.rvArticle);
        recyclerView.setLayoutManager(new LinearLayoutManager(getContext()));

        setRecyclerView();

        return rootView;
    }

    public void setRecyclerView() {
        try {
            data = helper.findAllArticle();
        } catch (Exception e) {
            e.printStackTrace();
        }
        AdapterEngaged adapter = new AdapterEngaged(data, new AdapterEngaged.OnItemClickListener() {
            @Override
            public void onClick(ModelEngaged item) {
                Toast.makeText(getContext(), "LIST CLICKED", Toast.LENGTH_LONG).show();
            }
        });
        recyclerView.setAdapter(adapter);
    }

    @Override
    public void onResume() {
        super.onResume();
        try {
            data = helper.findAllArticle();
        } catch (Exception e) {
            e.printStackTrace();
        }
        setRecyclerView();
    }


}

一切都很顺利,只是希望表单提交的时候数据能显示出来,可以直接在第3页签上查看

共有1个答案

帅彦
2023-03-14

试试这个,

在EngagedFragment中创建接口,

public interface SubmitListener {

    void onSubmit();
}

private SubmitListener onSubmitListener;

public void setSubmitListener(SubmitListener onSubmitListener){
        this.onSubmitListener = onSubmitListener;
}

public SubmitListener getOnSubmitListener(){
        return onSubmitListener;
}

在saveToLocalDB(...)中方法

onSubmitListener.onSubmit();
public class MainActivity extends AppCompatActivity implements EngagedFragment.SubmitListener
EngagedFragment engagedFrag = new EngagedFragment();
adapter.addFrag(engagedFrag, "ENGAGED ID");

...
viewPager.setAdapter(adapter);
engagedFrag.setSubmitListener(this);
if(viewPager != null){

    if(adapter != null){
        Fragment fragment = adapter.getItem(2);
        if(fragment != null){
            RequestFragment requestFragment = (RequestFragment) fragment;
            requestFragment.setRecyclerView();
        }
    }
}
 类似资料:
  • 我试图使用另一个片段中的数据填充我的Listview。 我可以从另一个片段获取数据,但当我尝试创建listview对象时,它返回null。 结果,该应用程序正在崩溃。 我从一个片段中获取用户的数据,然后从另一个片段中调用一个方法来传递数据。我正在第二个方法的poplist()方法中创建listview对象和数组适配器。但是,由于空指针异常,应用程序正在崩溃。请帮忙。 我尝试了以下方法,但不起作用

  • 我知道的一种方法是通过活动。我们可以将数据从一个片段发送到另一个活动,再从一个活动发送到另一个片段。还有其他方法吗?

  • 先生/女士,我想使用android JAVA将一个片段回调到另一个片段。我试图找到问题,但没有找到解决方案。若我使用接口,它会向活动发送回调响应,这是我不想要的。非常感谢。

  • 我试着从一个片段到主要片段。编译器不喜欢我的代码,但我不确定是什么问题。转换片段的最佳实践是什么? //这是我要导航到的主片段的xml 2019-07-12 17:49:45.091 959 4-9594/com.example.cribb E/AndroidRuntime:致命异常:主进程:com.example.cribb,PID:9594 Android.content.res.resour

  • 这里是链接的代码,我正在做同样的事情链接

  • 在FragmentOne.class扩展android.support.v4.app.