使用Firebase数据库中的键填充Spinner,然后根据第一个选择填充另一个Spinner

时间:2019-04-19 16:59:26

标签: android firebase-realtime-database android-spinner

我想在单个Spinner中获得所有“组号”键,然后在第二个Spinner中获得所选“组号”的所有“学校号”键。 / p>

这是我的数据库:

enter image description here

这是我的Java代码:

public class Collection extends AppCompatActivity {

    TextView ttl, tgat, tsch;
    Button btnshw, btngt;
    Spinner sping;
    DatabaseReference d2ref;

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

        tgat = (TextView) findViewById(R.id.texigat);
        tsch = (TextView) findViewById(R.id.texisch);
        //tcls = (TextView) findViewById(R.id.texiclass);
        ttl = (TextView) findViewById(R.id.texirs);
        btnshw = (Button) findViewById(R.id.bshow);
        btngt = (Button) findViewById(R.id.bgat);
        sping = (Spinner) findViewById(R.id.spingat);

        btnshw.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View v) {
                d2ref = FirebaseDatabase.getInstance().getReference().child("2018-19").child("Group No 14")
                        .child("School no 109").child("Standard 2nd");
                d2ref.addValueEventListener(new ValueEventListener() {
                    @Override
                    public void onDataChange(@NonNull DataSnapshot dataSnapshot) {
                        String rs = dataSnapshot.child("Rupees").getValue().toString();
                        ttl.setText(rs);
                    }

                    @Override
                    public void onCancelled(@NonNull DatabaseError databaseError) {

                    }
                });
            }
        });

        btngt.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View v) {
        d2ref = FirebaseDatabase.getInstance().getReference().child("2018-19");
        ValueEventListener eventListener = new ValueEventListener() {
            @Override
            public void onDataChange(@NonNull DataSnapshot dataSnapshot) {
                final List<String> grpno = new ArrayList<String>();

                for (DataSnapshot dsnap : dataSnapshot.child("Group No 14").getChildren()) {
                    String grp = dsnap.getKey();
                    grpno.add(grp);
                }
                ArrayAdapter<String> adapter = new ArrayAdapter<String>(Collection.this, android.R.layout.simple_spinner_item);
                adapter.setDropDownViewResource(android.R.layout.simple_spinner_dropdown_item);
                sping.setAdapter(adapter);

                /*I wasn't able to get the value in 1st spinner so I didn't
                 wrote program for second spinner*/
            }

            @Override
            public void onCancelled(@NonNull DatabaseError databaseError) {

            }
        };
        d2ref.addListenerForSingleValueEvent(eventListener);
            }
        });
    }
}

我试图在TextView中获取它,并用Button来增加值,但是TextView却只获得了“第2组”。

2 个答案:

答案 0 :(得分:2)

将密钥放入Spinner就像将值放入Spinner一样简单。您要做的就是从child()循环中删除for

代替这样做:

for (DataSnapshot dsnap : dataSnapshot.child("Group No 14").getChildren()) {
    String grp = dsnap.getKey();
    grpno.add(grp);
}

您必须这样做:

for (DataSnapshot dsnap : dataSnapshot.getChildren()) {
    String grp = dsnap.getKey();
    grpno.add(grp);
}

希望这会有所帮助。

答案 1 :(得分:0)

事实证明,将密钥放入Spinner就像将值放入Spinner一样简单。我要做的就是从child()循环中删除for

代替这样做:

for (DataSnapshot dsnap : dataSnapshot.child("Group No 14").getChildren()) {
    String grp = dsnap.getKey();
    grpno.add(grp);
}

我必须这样做:

for (DataSnapshot dsnap : dataSnapshot.getChildren()) {
    String grp = dsnap.getKey();
    grpno.add(grp);
}