как установить результат BackgroundWorker для TextView

Я очень плохо знаком с Android и не могу получить результат из базы данных в TextView на экране. На данный момент мое приложение возвращает сообщение после нажатия на кнопку. У меня два TextView элементы на экране txtViewBegin а также txtViewEind, От mySql (с помощью php) я получаю строку, как это 22-02-2014 24-05-2017, который я разделил с массивом Strings (.split(" ")),

Могу ли я использовать setTextView из фонового рабочего (onPostExecute?)

или я должен сделать это в моем MainActivity? Все еще новичок в этом. Сожалею.

Вот мой BackgroundWorker:

public class BackgroundWorker extends AsyncTask<String,Void,String> {
Context context;
AlertDialog alertDialog;
BackgroundWorker(Context ctx){
context = ctx;
}@Override
protected String doInBackground(String... params) {
String type = params[0];
String login_url= "http://*************/****.php";
if(type.equals("Draai")){
try {
URL url = new URL(login_url);
HttpURLConnection httpURLConnection = (HttpURLConnection) url.openConnection();
httpURLConnection.setRequestMethod("POST");
httpURLConnection.setDoOutput(false);
httpURLConnection.setDoInput(true);
//OutputStream outputStream = httpURLConnection.getOutputStream();
//BufferedWriter bufferedWriter = new BufferedWriter(new OutputStreamWriter(outputStream,"UTF-8"));
//String post_data = URLEncoder.encode("user_name""UTF-8")// HIER KUN JE VARIABELEN INGEVEN DIE WORDEN GEIMPLEMENTEERD IN HET PHP DOCUMENT
//bufferedWriter.write();
//bufferedWriter.flush();
// bufferedWriter.close();
//outputStream.close();
InputStream inputStream = httpURLConnection.getInputStream();
BufferedReader bufferedReader = new BufferedReader(new InputStreamReader(inputStream, "iso-8859-1"));
String result ="";
String line="";
while ((line=bufferedReader.readLine()) != null){
result += line;
}
String[] separated = result.split(" ");
bufferedReader.close();
inputStream.close();
httpURLConnection.disconnect();
return result;

} catch (MalformedURLException e) {
e.printStackTrace();
} catch (IOException e) {
e.printStackTrace();
} catch (Exception e){
e.printStackTrace();
}
}
return null;
}

@Override
protected void onPreExecute() {
alertDialog = new AlertDialog.Builder(context).create();
alertDialog.setTitle("TijdsDuur");
}

@Override
protected void onPostExecute(String result) {
alertDialog.setMessage(result);
alertDialog.show();
}

@Override
protected void onProgressUpdate(Void... values) {
super.onProgressUpdate(values);
}
}

и мой MainActivity:

public class MainActivity extends AppCompatActivity {
TextView ViewBegin, ViewEind;

@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
ViewBegin = (TextView) findViewById(R.id.txtViewBegin);
ViewEind = (TextView) findViewById(R.id.txtViewEind);
}

public void onDraai(View view){
String type = "Draai";

BackgroundWorker backgroundWorker = new BackgroundWorker(this);
backgroundWorker.execute(type);

}
}

1

Решение

1.) создать interface для обратного вызова в вашем BackgroundWorker

public interface DataCallBack{
void onDataReceived(String s);
}

2.) Реализуйте этот интерфейс обратного вызова в вашем Activity

public class MainActivity extends AppCompatActivity implements BackgroundWorker.DataCallBack {

3.) Когда задание выполнено, оповестите свою активность данными для отображения.

Ваш MainActivity будет выглядеть

public class MainActivity extends AppCompatActivity implements BackgroundWorker.DataCallBack {
TextView ViewBegin, ViewEind;

// .....code

@Override
void onDataReceived(String s){
if(s!=null){
String[] separated = result.split(" ");
ViewBegin.setText(separated[0]);
ViewEind.setText(separated[1]);
}
}

// .....code

}

Ваш BackgroundWorker класс будет выглядеть

public class BackgroundWorker extends AsyncTask<String,Void,String> {
Context context;
AlertDialog alertDialog;
DataCallBack callback;

BackgroundWorker(Context ctx){
context = ctx;

// initialize the callback reference
callback = (DataCallBack) cxt;
}

public interface DataCallBack{
void onDataReceived(String s);
}

// .....code

@Override
protected void onPostExecute(String result) {
callback.onDataReceived(result);
// ^^^ send data to Activity

alertDialog.setMessage(result);
alertDialog.show();
}

// .....code

}
2

Другие решения

Других решений пока нет …

По вопросам рекламы [email protected]