Android: Looping through a string array - help needed on logic for intent method
Solution 1
classname
is being overwritten every time you iterate in the foreach loop inside setTeamNames()
. Thus, only the last classname remains at the end.
If teams
and teamnames
have the same number of entries (which they should), you can use the following code and get rid of setTeamNames()
completely.
final String prefix = "ttj.android.ft.teams.";
for (int i = 0; i < teams.length; i++) {
tv = (TextView) findViewById(teams[i]);
tv.setOnClickListener(new View.OnClickListener() {
public void onClick(View v) {
try {
Class class = Class.forName(prefix + teamnames[i]);
Intent open = new Intent(Transfers.this, class);
startActivity(open);
} catch (ClassNotFoundException e) {
e.printStackTrace();
}
});
}
;
Solution 2
Assuming the activities you are trying to start have similar (or the same) layout and functionality but display different data specific to each team, try the following.
Change your onClick(View v)
method as follows...
tv.setOnClickListener(new View.OnClickListener() {
public void onClick(View v) {
Intent open = new Intent(Transfers.this, TeamActivity.class);
open.putExtra("team", ((TextView)v).getText());
startActivity(open);
}
});
Then create a 'generic' Activity
...
public class TeamActivity extends Activity {
String teamName = "";
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
// Set the layout here
// Get the Intent and team name with the following...
teamName = getIntent().getStringExtra("team");
// Do something with teamName
}
}
Just register the TeamActivity
in your manifest and you should be good to go.
Comments
-
tiptopjat almost 4 years
I'm a java novice and I've using the code below to display a list of clickable TextViews that call a specific class when they are clicked.
It is a list of football team names.
Eg.
Arsenal Manchester United Chelsea
Clicking on TextView Arsenal (TextView id = ars) will call ars.class Clicking on TextView Chelsea (TextView id = che)will call che.class
I have over 20 football team names.
I have an array of textview ids, which I loop through and assign them a clickable action. This works fine.
I have an string array of teamnames, the code loops through the string array and assigns each teamname to a Class object, which is used in the Intent() method.
When I run this code, the list is produced but when I click on a team name it always opens Wol.java, the last position in the string array.
I need some help with the logic, so that when I click on Arsenal it opens ars.class
Here is the code.
public final int[] teams = { R.id.ars, R.id.ast, R.id.bir, R.id.bla, R.id.blp, R.id.bol, R.id.che, R.id.eve, R.id.ful, R.id.hul, R.id.lee, R.id.liv, R.id.mid, R.id.mnc, R.id.mnu, R.id.nor, R.id.nwu, R.id.por, R.id.qpr, R.id.sto, R.id.sun, R.id.swa, R.id.tot, R.id.wes, R.id.wig, R.id.wol }; //String array of teamnames, named to correspond their class name. public final String[] teamnames = { "ars", "ast", "bir", "bla", "blp", "bol", "che", "eve", "ful", "hul", "lee", "liv", "mid", "mnc", "mnu", "nor", "nwu", "por", "qpr", "sto", "sun", "swa", "tot", "wes", "wig", "wol" }; TextView tv; Class classname; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.m_transfers); setTeamNames(); //Method sets up team names to a Class name. for (int i = 0; i < teams.length; i++) { tv = (TextView) findViewById(teams[i]); tv.setOnClickListener(new View.OnClickListener() { public void onClick(View v) { Intent open = new Intent(Transfers.this, classname); startActivity(open); } }); } ; } public void setTeamNames() { for (String s : teamnames) { String name = "ttj.android.ft.teams." + s; try { classname = Class.forName(name); } catch (ClassNotFoundException e) { e.printStackTrace(); } } ; }
-
tiptopjat almost 12 yearsDuh! Thanks Tushar! :-) Only problem I have with this is line 7. Class class = Class.forName(prefix + teamnames[i]); Eclipse says I can not refer to a non-final variable 'i' inside an inner class defined in a different method.
-
Tushar almost 12 yearsRight, I forgot. You'll either have to set your teamnames and prefix as final or declare them inside the OnClickListener() class.
-
tiptopjat almost 12 yearsThanks for replying back. 'teamnames' is already Public Final. I've tried declaring teamnames inside the OnClickListener() class. Still no joy.
-
Tushar almost 12 yearsDid you make String prefix final as well?
-
tiptopjat almost 12 yearsYes, inside the method Eclipse asked for it to be final. So I moved it outside the method as 'String prefix = "ttj.android.ft.teams.";' The problem still persists. If I made the int in the for loop final, the i++ increment throws an error.
-
Tushar almost 12 yearsOn the first line inside your for-loop, add
final int j = i;
and then replaceteamnames[i]
withteamnames[j]
. That may be the problem. -
tiptopjat almost 12 yearsAbsolutely fantastic! Thank you! It works. I've spent 6 hours trying to work this out, should have registered to this site sooner. Thanks again.
-
tiptopjat almost 12 yearsThank you for sharing this solution. I imagine the app will be more efficient using this approach? I've invested so much time in my approach I don't have the energy to start from scratch. Lol.