#android #android-fragments
#Android #android-фрагменты
Вопрос:
Я использую этот код / концепцию :
Чего я хочу добиться, так это того, что при выбранном элементе (как показано ниже) я хочу отправить элемент на сервер, обработать его на этой стороне (что я могу сделать) и получить String
отправленный обратно и использовать эту строку для обновления подробной части списка / сведенийфрагмент. Есть ли кто-нибудь, кто поможет мне достичь этого с помощью какого-либо кода?
Мой код пока выглядит следующим образом:
public class MainActivity extends FragmentActivity implements HeadlinesFragment.OnHeadlineSelectedListener
{
XMLCreator x = new XMLCreator();
/** Called when the activity is first created. */
public void onCreate(Bundle savedInstanceState)
{
super.onCreate(savedInstanceState);
setContentView(R.layout.news_articles);
// Check whether the activity is using the layout version with
// the fragment_container FrameLayout. If so, we must add the first fragment
if (findViewById(R.id.fragment_container) != null)
{
// However, if we're being restored from a previous state,
// then we don't need to do anything and should return or else
// we could end up with overlapping fragments.
if (savedInstanceState != null)
{
return;
}
// Create an instance of ExampleFragment
HeadlinesFragment firstFragment = new HeadlinesFragment();
// In case this activity was started with special instructions from an Intent,
// pass the Intent's extras to the fragment as arguments
firstFragment.setArguments(getIntent().getExtras());
// Add the fragment to the 'fragment_container' FrameLayout
getSupportFragmentManager().beginTransaction()
.add(R.id.fragment_container, firstFragment).commit();
}
postToServer();
}
public void postToServer()
{
new Connection().execute();
}
public void onArticleSelected(int position)
{
// The user selected the headline of an article from the HeadlinesFragment
// Capture the article fragment from the activity layout
ArticleFragment articleFrag = (ArticleFragment)getSupportFragmentManager().findFragmentById(R.id.article_fragment);
if (articleFrag != null)
{
// If article frag is available, we're in two-pane layout...
// Call a method in the ArticleFragment to update its content
String Day = "";
Day = Ipsum.Headlines[position];
Document doc;
try
{
doc = x.createDoc();
Element tutor = doc.createElement("Query");
tutor.appendChild(x.createDay(doc, Day, "GetSessionByDay"));
doc.appendChild(tutor);
String s = x.getStringFromDocument(doc);
//connection.sendData(s);
//Want to send and receive strings here
}
catch (Exception e)
{
e.printStackTrace();
}
articleFrag.updateArticleView(position);
}
else
{
// If the frag is not available, we're in the one-pane layout and must swap frags...
// Create fragment and give it an argument for the selected article
ArticleFragment newFragment = new ArticleFragment();
Bundle args = new Bundle();
args.putInt(ArticleFragment.ARG_POSITION, position);
newFragment.setArguments(args);
FragmentTransaction transaction = getSupportFragmentManager().beginTransaction();
// Replace whatever is in the fragment_container view with this fragment,
// and add the transaction to the back stack so the user can navigate back
transaction.replace(R.id.fragment_container, newFragment);
transaction.addToBackStack(null);
// Commit the transaction
transaction.commit();
}
}
public class Connection extends AsyncTask<Void, Void, String>
{
// the I/O streams that will be receiving/sending data from/to the
// server
private ObjectOutputStream output;
private ObjectInputStream input;
private String message = "";
private Socket client;
@Override
protected void onPreExecute()
{
// IMPORTANT: this method is synched with UI thread, so can access UI
super.onPreExecute();
}
@Override
protected String doInBackground(Void... params)
{
try
{
client = new Socket("10.111.1.1", 5001);
} catch (UnknownHostException e1) {
// TODO Auto-generated catch block
e1.printStackTrace();
} catch (IOException e1) {
// TODO Auto-generated catch block
e1.printStackTrace();
}
try {
output = new ObjectOutputStream(client.getOutputStream());
output.flush();
input = new ObjectInputStream(client.getInputStream());
} catch (IOException e1) {
// TODO Auto-generated catch block
e1.printStackTrace();
}
do
{
try
{
message = (String) input.readObject();
}
catch (ClassNotFoundException classNotFoundException)
{
} catch (OptionalDataException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (Exception e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
while (!message.equals("SERVER>>> TERMINATE"));
try
{
output.writeObject(message);
output.flush();
} catch (IOException ioException)
{
}
// sleep a bit, so this task isn't over before it starts
try
{
Thread.sleep(500);
} catch (InterruptedException e)
{
Log.e("TASK", "Error sleeping in CalculateTask");
}
// return value to be passed to onPostExecute of task initiator
return message;
}
@Override
protected void onProgressUpdate(Void... progress)
{
// IMPORTANT: this method is synched with UI thread, so can access UI
}
@Override
protected void onPostExecute(String result)
{
// IMPORTANT: this method is synched with UI thread, so can access UI
super.onPostExecute(result);
// update UI
}
}
}
Ответ №1:
Просто вызовите сервер из своего фрагмента, например, метод getData()
, внутри которого, я думаю, вам нужно реализовать AsynkTask
. Когда вы получите ответ на этот запрос DoInBackground()
, просто передайте его onPostExecute()
и используйте этот ответ и обновите свой пользовательский интерфейс, как захотите.
Комментарии:
1. Итак, что-то вроде: @Override public void onListItemClick(ListView l, View v, int position, длинный идентификатор) { showDetails(позиция); строка s = getData(); } общедоступная строка getData() { Строка s = новое соединение ().execute().get(); } Затемв dobackground я возвращаю строку? Это сработает?
2. Да, это будет работать, но передайте ваши данные из метода onPostExecute() после завершения вашего запроса, ответа.
Ответ №2:
Создайте метод postToServer()
в MainActivity
для выполнения AsyncTask
. Вызовите этот метод OnItemClickListner
внутри фрагмента
((MainActivity)getActivity).postToServer();
В Fragment
, создайте метод updateUI(String response)
, который обрабатывает обновление пользовательского интерфейса, и вызовите этот метод у своего родителя Activity
, когда AsyncTask
он будет завершен. Вызовите этот метод в OnPostExecute()
AsyncTask
;
Комментарии:
1. Итак, я вызываю updateUI (строковый ответ) в моем методе onListItemClick? и это затем обновит пользовательский интерфейс во фрагменте, с которым он связан?
2. я изменил ответ, пожалуйста, проверьте
3. Когда я добавляю метод updateUI (строковый ответ), я сталкиваюсь с проблемой. Мой фрагмент статичен, поэтому я не могу ссылаться на него в своей основной деятельности. В противном случае я уверен, что предоставленный вами ответ решит мою проблему.
4. почему вы делаете его статичным, по какой-либо конкретной причине? Лучше всего сохранить фрагмент в другом файле Java.
5. Я изменил свой код, чтобы каждый фрагмент содержался в каждом отдельном файле Java. Есть ли способ, которым я мог бы передать его вам, чтобы вы посмотрели? Вероятно, я не вижу своей проблемы из-за того, насколько я расстроен.