0

こんにちは、Android アプリケーションで xml 解析を使用して、[さらに読み込む] ボタンを備えたリストビューを開発する必要があります。

ここで私はいくつかの問題に直面しました。

my xml feed is empty は、最後のページの [さらに読み込む] ボタンを非表示にする方法を意味します。

ここでは以下のコードを使用しました。

public class CustomizedListView extends Activity {
// All static variables
private String URL = "http://dev.mmm.com/xctesting/xcart444pro/retrieve.php?page=1";
// XML node keys
static final String KEY_SONG = "Order"; 
    static final String KEY_TITLE = "orderid";
static final String KEY_DATE = "date";
static final String KEY_ARTIST = "payment_method";
    int current_page = 1;
ListView lv;
LazyAdapter adapter;
ProgressDialog pDialog; 

@Override
public void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.main);
    lv = (ListView) findViewById(R.id.list);

    ArrayList<HashMap<String, String>> songsList = new ArrayList<HashMap<String, String>>();

    XMLParser parser = new XMLParser();
    String xml = parser.getXmlFromUrl(URL); // getting XML from URL
    Document doc = parser.getDomElement(xml); // getting DOM element

    NodeList nl = doc.getElementsByTagName(KEY_SONG);
    // looping through all song nodes <song>
    for (int i = 0; i < nl.getLength(); i++) {
        // creating new HashMap
        HashMap<String, String> map = new HashMap<String, String>();
        Element e = (Element) nl.item(i);
        // adding each child node to HashMap key => value
        map.put(KEY_ID, parser.getValue(e, KEY_ID));
        map.put(KEY_TITLE, parser.getValue(e, KEY_TITLE));
        map.put(KEY_ARTIST, parser.getValue(e, KEY_ARTIST));
              songsList.add(map);
    }

    Button btnLoadMore = new Button(this);
    btnLoadMore.setText("Load More");

    btnLoadMore.setBackgroundResource(R.drawable.lgnbttn);
    // Adding Load More button to lisview at bottom
    lv.addFooterView(btnLoadMore);

    // Getting adapter
    adapter = new LazyAdapter(this, songsList);
    lv.setAdapter(adapter);
                btnLoadMore.setOnClickListener(new View.OnClickListener() {

        @Override
        public void onClick(View arg0) {
            // Starting a new async task
            new loadMoreListView().execute();
        }
    });
}
    private class loadMoreListView extends AsyncTask<Void, Void, Void> {

        @Override 
        protected void onPreExecute() {
            // Showing progress dialog before sending http request
            pDialog = new ProgressDialog(
                    CustomizedListView.this);
            pDialog.setMessage("Please wait..");
            //pDialog.setIndeterminateDrawable(getResources().getDrawable(R.drawable.my_progress_indeterminate));
            pDialog.setIndeterminate(true);
            pDialog.setCancelable(false);
            pDialog.show(); 

            pDialog.setContentView(R.layout.custom_dialog);


        }
        protected Void doInBackground(Void... unused) {

                    current_page += 1;

                    // Next page request
                    URL = "http://dev.mmm.com/xctesting/xcart444pro/retrieve.php?page=" + current_page;

                    ArrayList<HashMap<String, String>> songsList = new ArrayList<HashMap<String, String>>();

                    XMLParser parser = new XMLParser();
                    String xml = parser.getXmlFromUrl(URL); // getting XML from URL
                    Document doc = parser.getDomElement(xml); // getting DOM element

                    NodeList nl = doc.getElementsByTagName(KEY_SONG);


                    NodeList nl = doc.getElementsByTagName(KEY_SONG);
                    if (nl.getLength() == 0)
                      {
                          btnLoadMore.setVisibility(View.GONE);
                          pDialog.dismiss();

                      }
                      else

                    // looping through all item nodes <item>
                    for (int i = 0; i < nl.getLength(); i++) {
                        // creating new HashMap
                        HashMap<String, String> map = new HashMap<String, String>();
                        Element e = (Element) nl.item(i);

                        // adding each child node to HashMap key => value
                        map.put(KEY_ID, parser.getValue(e, KEY_ID));
                        map.put(KEY_TITLE, parser.getValue(e, KEY_TITLE));
                        map.put(KEY_ARTIST, parser.getValue(e, KEY_ARTIST));
                 songsList.add(map);
                    }

                    // get listview current position - used to maintain scroll position
                    int currentPosition = lv.getFirstVisiblePosition();

                    // Appending new data to menuItems ArrayList
                    adapter = new LazyAdapter(
                            CustomizedListView.this,
                            songsList);
                    lv.setAdapter(adapter);
             lv.setSelectionFromTop(currentPosition + 1, 0);


            }
            });

            return (null);
        }


        protected void onPostExecute(Void unused) {
            // closing progress dialog
            pDialog.dismiss();

        }
    }
}

編集:

ここでアプリを実行する必要があるのは、リストビューがページごとに 4 つの項目に表示されることを意味します。最後のページには 1 つの項目が表示されます。このスクリーンショットを参照してください : lastpage空のページのボタン..このスクリーンショットを参照してください:空のページ - ボタンを非表示にします

空のページの状態を確認する必要があります:

    if (nl.getLength() == 0)
                    {
                        btnLoadMore.setVisibility(View.GONE);
                        pDialog.dismiss();

                    }

最後のページの状態をどのように書けばよいでしょうか?????助けてください

ここで、最後のページのボタンを隠すo / pが必要です

助けてください。状態を確認するにはどうすればよいですか。プログラムでコードを教えてください。

4

2 に答える 2

1

この方法を使用して、より多くの読み込みを達成しました。フッタービューは使用しません

public boolean mHasLoadMore = false;

    class MyAdapter extends ArrayAdapter implements OnItemClickListener{

        public MyAdapter(Context context, int textViewResourceId) {
            super(context, textViewResourceId);
            // TODO Auto-generated constructor stub
        }

        public int getTotal(){
            return super.getCount();
        }
        @Override
        public int getCount() {

            if(super.getCount()>0)
                return super.getCount()+1;
            else
                return 0;

        }

        @Override
        public View getView(int position, View convertView, ViewGroup parent) {

            if( getTotal() == (position+1) && mHasLoadMore ){

                TextView loadMoreView = new TextView(getContext());
                loadMoreView.setText("Load More");
                return loadMoreView;
            }              
            else {
                View theView = new View(getContext());
                // inflate & add what you need for item view here you can modify it to reuse convertView also
                return theView;
            }   

        }

        @Override
        public void onItemClick(AdapterView<?> arg0, View arg1, int position,
                long id) {

            if( getTotal() == (position+1) && mHasLoadMore ){

                // load more button clicked do handling for load more launch async 
                //task to do load more after that if found 0 result change mHasLoadMore to false 
                //& call notifydatadetchanged               
            }
            else
            {
                // handle item click here  
            }

        }



    } 

リストビューにこのようなアダプターを使用し、データのロード中に初めて mHasLoadMore の値を設定し、notifydatasetchanged を呼び出します

于 2012-10-30T06:48:10.563 に答える
1

まず、なぜ AsyncTaks 内で runOnUiThread を使用しているのですか? これは必要ありません。doInBackground メソッドで、バックグラウンドで実行する必要があるコードで十分です。

さらに、AsyncTask の 3 番目のパラメータ タイプを使用して、doInBackground から onPostExecute に結果を返すことができます。次に、結果に応じて、ボタンの可視性を変更できます。

これを行うには、ボタンへの参照 (この場合は btnLoadMore) をインスタンス変数にする必要があるため、onCreate メソッドではなくクラスで定義する必要があります。そうしないと、このメソッドの外部からアクセスできなくなります。

フィードが空の場合、ノードリストは空になると思いますか? 次に、次のようになります。

public class CustomizedListView extends Activity {

    private Button btnLoadMore;

    public void onCreate(){
        btnLoadMore = new Button(this);
        <do stuff>
        btnLoadMore.setOnClickListener(new View.OnClickListener() {

           @Override
           public void onClick(View arg0) {
               // Starting a new async task
               new LoadMoreListView().execute();
           }
        });

        new LoadMoreListView().execute();// execute the AsyncTask once in the onCreate, so you don't have to duplicate the code here to load the listview.

    }

    private class LoadMoreListView extends AsyncTask<Void, Void, Boolean> {

        @Override 
        protected void onPreExecute() {
            < Show dialog>;
        }

        @Override
        protected Void doInBackground(Void... unused) {
           Boolean listIsEmpty;

           < Page request>;
           < Retrieve element list>;
           < If element list size == 0, listIsEmpty = true; return listIsEmpty>;

           < Process elements, fill list etc.>;
           < End of doInBackground, listIsEmpty = false; return listIsEmpty>;

        }

        @Override
        protected void onPostExecute(Boolean listIsEmpty) {
            < If listIsEmpty == true -> btnLoadMore.setVisibility(View.GONE);>
            < Close dialog>
        }
    }
}
}
于 2012-10-30T06:49:45.593 に答える