Использование String / Resource вместо статического / неизменяемого текста
Я пытаюсь написать сообщение NDef со строкой, которую я обычно использую в своем приложении вместо текста.
Пример:
@Override
public NdefMessage createNdefMessage(NfcEvent event) {
Time time = new Time();
time.setToNow();
String text = ("Beam me up!\n\n" +
"Beam Time: " + time.format("%H:%M:%S"));
NdefMessage msg = new NdefMessage(NdefRecord.createMime(
"application/com.nfc.linkingmanager.beam", text.getBytes())
/**
Я хочу написать значение для:
android:id="@+id/timeEdit
вместо:
Beam me up!\n\n" +
"Beam Time: " + time.format("%H:%M:%S"
VIEWCOUNTRY.JAVA (еще один класс Java, который может ссылаться на искомое значение: timeEdit)
public class ViewCountry extends Activity {
private long rowID;
private TextView nameTv;
private TextView capTv;
private TextView codeTv;
private TextView timeTv;
@Override
public void onCreate(Bundle savedInstanceState)
{
super.onCreate(savedInstanceState);
setContentView(R.layout.view_country);
setUpViews();
Bundle extras = getIntent().getExtras();
rowID = extras.getLong(CountryList.ROW_ID);
}
private void setUpViews() {
nameTv = (TextView) findViewById(R.id.nameText);
capTv = (TextView) findViewById(R.id.capText);
timeTv = (TextView) findViewById(R.id.timeEdit);
codeTv = (TextView) findViewById(R.id.codeText);
}
@Override
protected void onResume()
{
super.onResume();
new LoadContacts().execute(rowID);
}
private class LoadContacts extends AsyncTask<Long, Object, Cursor>
{
DatabaseConnector dbConnector = new DatabaseConnector(ViewCountry.this);
@Override
protected Cursor doInBackground(Long... params)
{
dbConnector.open();
return dbConnector.getOneContact(params[0]);
}
@Override
protected void onPostExecute(Cursor result)
{
super.onPostExecute(result);
result.moveToFirst();
// get the column index for each data item
int nameIndex = result.getColumnIndex("name");
int capIndex = result.getColumnIndex("cap");
int codeIndex = result.getColumnIndex("code");
int timeIndex = result.getColumnIndex("time");
nameTv.setText(result.getString(nameIndex));
capTv.setText(result.getString(capIndex));
// timeTv.setText(result.getInt(timeIndex)); // <--- HERE WAS AN ERROR
timeTv.setText(result.getString(timeIndex)); // time was stored as Sting all the time
codeTv.setText(result.getString(codeIndex));
result.close();
dbConnector.close();
}
}
@Override
public boolean onCreateOptionsMenu(Menu menu)
{
super.onCreateOptionsMenu(menu);
MenuInflater inflater = getMenuInflater();
inflater.inflate(R.menu.view_country_menu, menu);
return true;
}
@Override
public boolean onOptionsItemSelected(MenuItem item)
{
switch (item.getItemId())
{
case R.id.editItem:
Intent addEditContact =
new Intent(this, AddEditDevice.class);
addEditContact.putExtra(CountryList.ROW_ID, rowID);
addEditContact.putExtra("name", nameTv.getText());
addEditContact.putExtra("cap", capTv.getText());
addEditContact.putExtra("code", codeTv.getText());
startActivity(addEditContact);
return true;
case R.id.deleteItem:
deleteContact();
return true;
default:
return super.onOptionsItemSelected(item);
}
}
private void deleteContact()
{
AlertDialog.Builder alert = new AlertDialog.Builder(ViewCountry.this);
alert.setTitle(R.string.confirmTitle);
alert.setMessage(R.string.confirmMessage);
alert.setPositiveButton(R.string.delete_btn,
new DialogInterface.OnClickListener()
{
public void onClick(DialogInterface dialog, int button)
{
final DatabaseConnector dbConnector =
new DatabaseConnector(ViewCountry.this);
AsyncTask<Long, Object, Object> deleteTask =
new AsyncTask<Long, Object, Object>()
{
@Override
protected Object doInBackground(Long... params)
{
dbConnector.deleteContact(params[0]);
return null;
}
@Override
protected void onPostExecute(Object result)
{
finish();
}
};
deleteTask.execute(new Long[] { rowID });
}
}
);
alert.setNegativeButton(R.string.cancel_btn, null).show();
}
}
1 ответ
Вы не показываете, где в вашем коде вы используете этот метод, поэтому он может быть немного сложнее, но в целом:
public MyActivity extends Activity{
...
private final TextView tvTimeStamp; // <--- declare it, it's class level so is available to all methods of this class
...
@Override
public void onCreate(Bundle savedInstance){
super.onCreate(savedInstance);
...
setContentView(R.layout.my_activity_layout);
tvTimeStamp = (TextView)findViewById(R.id.timeEdit); // <---- get a reference to it
...
}
@Override
public NdefMessage createNdefMessage(NfcEvent event) {
Time time = new Time();
time.setToNow();
String text = ("Beam me up!\n\n" +
"Beam Time: " + time.format("%H:%M:%S"));
NdefMessage msg = new NdefMessage(NdefRecord.createMime(
tvTimeStamp.getText(), text.getBytes()) // <----- use it here!
}
}
Чтобы получить значение TextView в другом классе, вы можете использовать эту технику:
Первый: передать значение TextView классу, в котором вы создаете сообщение NFC, добавляя конструктор, например
public class MyNfcClass{
private String timeStamp;
public void MyNfcClass(String timeStamp){
this.timeStamp = timeStamp;
}
}
Недостатком этого является то, что если TextView изменится, ваш класс NFC не будет знать.
Два: Определить интерфейс. Смотрите этот учебник http://www.tutorialspoint.com/java/java_interfaces.htm
Три: Если и только если класс NFC имеет время жизни, равное или меньшее времени жизни действия, то передайте ссылку на TextView классу. Только сделайте это, если вы действительно понимаете время жизни, и вы можете гарантировать, что не потеряете ссылку. Если ты этого не понимаешь, то считай это словесным;)
Четвертое: если класс Nfc создается в другом действии, начатом с этого (или где-то в цепочке действий, то передайте значение в дополнительных функциях Intent, используемых для запуска действия. Это имеет тот же недостаток, что и вариант 1.
Таким образом, вариант 2 является предпочтительным. Это Java и Android "путь".
Удачи.