Использование 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 "путь".

Удачи.

Другие вопросы по тегам