Android: взять данные в ListView

0

На самом деле в моем проекте я заблокирован. Итак, я впервые спрашиваю сообщество Stackoverflow. Я новичок в развитии.

Итак, у меня есть MySql с моими данными, и я не буду видеть в своем приложении элементы пользователей.

Для этого у меня это:

public class SuccessActivity extends AppCompatActivity {


    public static final int CONNECTION_TIMEOUT = 10000;
    public static final int READ_TIMEOUT = 15000;
    private ListView listView;

    protected String meubles[] = new String[100];

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_success);

        Intent intent = getIntent();
        String id = intent.getStringExtra("id");

        this.listView = (ListView) findViewById(R.id.liste);


        new SuccessActivity.Recup().execute(id);

    }



    //PRIVATE CLASSE POUR AFFICHER LES MEUBLES
    private class Recup extends AsyncTask<String, String, String> {
        HttpURLConnection conn;
        URL url = null;

        @Override
        protected String doInBackground(String... params) {
            try {

                //url d'ou reside mon fichier php
                url = new URL("http://opix-dev.fr/mytinyhomme/personne/afficher.meuble.php");

            } catch (MalformedURLException e) {
                // TODO Auto-generated catch block
                e.printStackTrace();
                return "exception";
            }
            try {
                // parametrage du  HttpURLConnection pour recevoir et envoyer des donner à mysql
                conn = (HttpURLConnection) url.openConnection();
                conn.setReadTimeout(READ_TIMEOUT);
                conn.setConnectTimeout(CONNECTION_TIMEOUT);
                conn.setRequestMethod("POST");

                // setDoInput and setDoOutput method depict handling of both send and receive
                conn.setDoInput(true);
                conn.setDoOutput(true);

                // Append parameters to URL
                Uri.Builder builder = new Uri.Builder()
                        .appendQueryParameter("id", params[0]);
                String query = builder.build().getEncodedQuery();


                // Open connection for sending data
                OutputStream os = conn.getOutputStream();
                BufferedWriter writer = new BufferedWriter(
                        new OutputStreamWriter(os, "UTF-8"));
                writer.write(query);
                writer.flush();
                writer.close();
                os.close();
                conn.connect();

            } catch (IOException e1) {
                // TODO Auto-generated catch block
                e1.printStackTrace();
                return "exception";
            }

            try {

                int response_code = conn.getResponseCode();

                // Check if successful connection made
                if (response_code == HttpURLConnection.HTTP_OK) {

                    // Read data sent from server
                    InputStream input = conn.getInputStream();
                    BufferedReader reader = new BufferedReader(new InputStreamReader(input));
                    StringBuilder result = new StringBuilder();
                    String line;

                    while ((line = reader.readLine()) != null) {
                        result.append(line);
                    }

                    // Pass data to onPostExecute method
                    return (result.toString());

                } else {

                    return ("unsuccessful");
                }

            } catch (IOException e) {
                e.printStackTrace();
                return "exception";
            } finally {
                conn.disconnect();
            }


        }

        @Override
        protected void onPostExecute(String resulta) {

            //this method will be running on UI thread
            if (resulta.equalsIgnoreCase("false")) {


            } else if (resulta.equalsIgnoreCase("exception") || resulta.equalsIgnoreCase("unsuccessful")) {


            } else {
                try {


                    JSONArray nom = new JSONArray(resulta);
                    System.out.println(nom);

                    String meubles[] = new String[100];

                    for (int i = 0; i < nom.length(); i++){
                        JSONObject jsonobject = nom.getJSONObject(i);

                        meubles[i]= jsonobject.getString("nom");
                        System.out.println(jsonobject);

                        System.out.println(meubles);
                        item.setText( meubles[i]);



                    }
                        System.out.println(meubles);


                } catch (JSONException e) {
                    e.printStackTrace();
                }


            }
        }

    }
}

file.php корректен, потому что JSONArray in System.print в порядке. Но я попытался с некоторыми TextView для отображения платы в конце, но мне это не удалось.

Как я могу использовать meuble[0], meuble[1], meuble[2](it board of String name of items) in a ListView?

Теги:
database

1 ответ

0
Лучший ответ

Вот что вам нужно сделать, чтобы показать свои данные в списке,

Модифицированный метод onPostExecute():

 @Override
        protected void onPostExecute(String resulta) {

            //this method will be running on UI thread
            if (resulta.equalsIgnoreCase("false")) {


            } else if (resulta.equalsIgnoreCase("exception") || resulta.equalsIgnoreCase("unsuccessful")) {


            } else {
                try {


                    JSONArray nom = new JSONArray(resulta);
                    System.out.println(nom);

                    String meubles[] = new String[100];

                    for (int i = 0; i < nom.length(); i++){
                        JSONObject jsonobject = nom.getJSONObject(i);

                        meubles[i]= jsonobject.getString("nom");
                        System.out.println(jsonobject);

                        System.out.println(meubles);

                    }

                    ArrayAdapter<String> listAdapter=new ArrayAdapter<>(this,android.R.layout.simple_list_item_1,meubles);

                    listView.setAdapter(listAdapter);



                        System.out.println(meubles);


                } catch (JSONException e) {
                    e.printStackTrace();
                }


            }
        }

Что добавил?

Вам нужен адаптер для отображения элементов в списке. Вы можете создать свой собственный класс адаптера, расширив массивный массив, или вы можете использовать arrayadapter без его настройки, как показано.

Добавлен код:

Создайте новый адаптер,

ArrayAdapter listAdapter = new ArrayAdapter <> (это, android.R.layout.simple_list_item_1, list);

Установите адаптер для своего списка,

listView.setAdapter(listAdapter);

  • 0
    Хорошо, спасибо за синтаксис И это работает сейчас! Спасибо dev '

Ещё вопросы

Сообщество Overcoder
Наверх
Меню