ProgressDialog Android 표시


78

사용자와 searchButton에서 문자열을 가져 오는 EditText가 있습니다. searchButton을 클릭하면 XML 파일을 검색하여 ListView에 표시합니다.

사용자로부터 입력을 받아 XML 파일을 검색하고 ListView에도 usersearched 값을 표시 할 수 있습니다.

내가 원하는 것은 ProgressDialogsearchButton을 "PLEASE WAIT ... RETRIEVING DATA ..."또는 이와 유사한 것과 같이 클릭 한 후 표시 하고 데이터가 표시 될 때 닫는 것입니다.

public class Tab1Activity extends ListActivity {
private Button okButton;
private Button searchButton;
Toast toast;
String xml;

private TextView searchText;
private String searchTextString;
HashMap<String, String> o;
ArrayList<HashMap<String, String>> mylist = new ArrayList<HashMap<String, String>>();

@Override
public void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.tab1);

    searchButton = (Button) findViewById(R.id.search_button);
    searchButton.setOnClickListener(new View.OnClickListener() {

        public void onClick(View v) {
            // TODO Auto-generated method stub
            System.out.print("hello");

            searchText = (TextView) findViewById(R.id.search_text);
            searchTextString = searchText.getText().toString();
            readXml(searchTextString);

        }
    });

}

private void readXml(String searchTextString1) {
    ArrayList<HashMap<String, String>> mylist = new ArrayList<HashMap<String, String>>();

    String xml = XMLfunctions.getXML();
            //Here XMLfunctions is class name which parse xml
    Document doc = XMLfunctions.XMLfromString(xml);

    int numResults = XMLfunctions.numResults(doc);

    if ((numResults <= 0)) {
        Toast.makeText(Tab1Activity.this, "Testing xmlparser",
                Toast.LENGTH_LONG).show();
        finish();
    }

    NodeList nodes = doc.getElementsByTagName("result");

    for (int i = 0; i < nodes.getLength(); i++) {
        HashMap<String, String> map = new HashMap<String, String>();

        Element e = (Element) nodes.item(i);
        String nameMapString = XMLfunctions.getValue(e, "name");



         if ( nameMapString.toLowerCase().indexOf(searchTextString1.toLowerCase()) != -1 )   // != -1 means string is present in the search string
            {
                map.put("id", XMLfunctions.getValue(e, "id"));
                map.put("name",  XMLfunctions.getValue(e, "name"));
                map.put("Score",  XMLfunctions.getValue(e, "score"));
                mylist.add(map);
            }
    }

    ListAdapter adapter = new SimpleAdapter(this, mylist,
            R.layout.parsexml, new String[] { "name", "Score" }, new int[] {
                    R.id.item_title, R.id.item_subtitle });

    setListAdapter(adapter);

    final ListView lv = getListView();
    lv.setTextFilterEnabled(true);
    lv.setOnItemClickListener(new OnItemClickListener() {
        public void onItemClick(AdapterView<?> parent, View view,
                int position, long id) {
            @SuppressWarnings("unchecked")
            HashMap<String, String> o = (HashMap<String, String>) lv
                    .getItemAtPosition(position);


                Toast.makeText(Tab1Activity.this,
                         "Name "+o.get("name")+"  Clicked", Toast.LENGTH_LONG)
                        .show();                

        }
    });
}


2
"이 모달 대화 상자를 사용하는 대신 활동 내에서 ProgressBar 인라인과 같은 진행률 표시기를 사용하십시오."라고 표시됩니다. 단순히 어떻게 하는지를 보여주지 않는 이유는 무엇입니까? :)
Wolf359

답변:


265

진행률 대화 상자를 선언하십시오.

ProgressDialog progress;

진행률 대화 상자를 시작할 준비가되면 :

progress = ProgressDialog.show(this, "dialog title",
    "dialog message", true);

완료되면 사라지게하려면 :

progress.dismiss();

다음은 작은 스레드 예입니다.

// Note: declare ProgressDialog progress as a field in your class.

progress = ProgressDialog.show(this, "dialog title",
  "dialog message", true);

new Thread(new Runnable() {
  @Override
  public void run()
  {
    // do the thing that takes a long time

    runOnUiThread(new Runnable() {
      @Override
      public void run()
      {
        progress.dismiss();
      }
    });
  }
}).start();

아래 코드를 작성했지만 작동하지 않습니다. 'searchButton.setOnClickListener (new View.OnClickListener () {public void onClick (View v) {// TODO 자동 생성 메서드 stub System.out.print ( "hello"); searchText = (TextView) findViewById (R.id.search_text); searchTextString = searchText.getText (). toString (); progress.show (Tab1Activity.this, "Dialog Title", "Please wait ... loading"); readXml (searchTextString ); progress.dismiss ();}}); '
captaindroid

nup, 위에서 볼 수 있듯이 readXML 메소드도 작성했습니다.
captaindroid

readXML이 너무 빨리 실행되어 진행률 대화 상자가 표시되지 않는지 궁금합니다. 네트워크를 통해 실제로 몇 초가 걸리는 작업을 수행하는 경우-먼저 별도의 스레드에서 수행하지만 진행 대화 상자의 전체 효과를 볼 수 있습니다. 당신이 스레드를 추가 끝내는 경우 확인 showdismissUI 스레드에서 진행 대화 상자가.
dldnh 2012 년

하지만 진행 상황을 보여줄 시간이 충분하다고 생각합니다. searchButton을 클릭하면 약 2-3 초가 걸립니다.
captaindroid

아시다시피 readXMLUI가 숨을 쉬지 못 하기 때문일 것입니다 . Win Myo Htet이 제안한 것처럼 간단한 new Thread(...)(내가 선호하는) 또는을 사용 하여 자체 스레드에 넣을 수 있습니다 AsyncTask.
dldnh 2012 년

7

인터넷에서 데이터를 다운로드하는 현재 프로젝트 중 하나에서 다음 코드를 사용하고 있습니다. 그것은 모두 내 활동 클래스 안에 있습니다.

// ---------------------------- START DownloadFileAsync // -----------------------//
class DownloadFileAsync extends AsyncTask<String, String, String> {

    @Override
    protected void onPreExecute() {
        super.onPreExecute();
        // DIALOG_DOWNLOAD_PROGRESS is defined as 0 at start of class
        showDialog(DIALOG_DOWNLOAD_PROGRESS);
    }

    @Override
    protected String doInBackground(String... urls) {
        try {
            String xmlUrl = urls[0];

            URL u = new URL(xmlUrl);
            HttpURLConnection c = (HttpURLConnection) u.openConnection();
            c.setRequestMethod("GET");
            c.setDoOutput(true);
            c.connect();

            int lengthOfFile = c.getContentLength();

            InputStream in = c.getInputStream();

            byte[] buffer = new byte[1024];
            int len1 = 0;
            long total = 0;

            while ((len1 = in.read(buffer)) > 0) {
                total += len1; // total = total + len1
                publishProgress("" + (int) ((total * 100) / lengthOfFile));
                xmlContent += buffer;
            }
        } catch (Exception e) {
            Log.d("Downloader", e.getMessage());
        }
        return null;
    }

    protected void onProgressUpdate(String... progress) {
        Log.d("ANDRO_ASYNC", progress[0]);
        mProgressDialog.setProgress(Integer.parseInt(progress[0]));
    }

    @Override
    protected void onPostExecute(String unused) {
        dismissDialog(DIALOG_DOWNLOAD_PROGRESS);
    }

}

@Override
protected Dialog onCreateDialog(int id) {
    switch (id) {
    case DIALOG_DOWNLOAD_PROGRESS:
        mProgressDialog = new ProgressDialog(this);
        mProgressDialog.setMessage("Retrieving latest announcements...");
        mProgressDialog.setIndeterminate(false);
        mProgressDialog.setMax(100);
        mProgressDialog.setProgressStyle(ProgressDialog.STYLE_HORIZONTAL);
        mProgressDialog.setCancelable(true);
        mProgressDialog.show();
        return mProgressDialog;
    default:
        return null;
    }

}

방향은 저에게 잘 바뀌 었습니다. 방금 2.3.3 AVD와 ICS 전화에서 테스트했습니다.
the_gesslar

6

진행률 표시 줄에 대한 개체를 만드는 동안 다음을 확인하십시오.

이것은 실패합니다.

dialog = new ProgressDialog(getApplicationContext());

활동 컨텍스트를 추가하는 동안 작동합니다 ..

dialog = new ProgressDialog(MainActivity.this);


1

인터넷에서 데이터를 다운로드하는 현재 프로젝트 중 하나에서 다음 코드를 사용하고 있습니다. 그것은 모두 내 활동 클래스 안에 있습니다.

private class GetData extends AsyncTask<String, Void, JSONObject> {

        @Override
        protected void onPreExecute() {
            super.onPreExecute();

            progressDialog = ProgressDialog.show(Calendar.this,
                    "", "");

        }

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

            String response;

            try {

                HttpClient httpclient = new DefaultHttpClient();

                HttpPost httppost = new HttpPost(url);

                HttpResponse responce = httpclient.execute(httppost);

                HttpEntity httpEntity = responce.getEntity();

                response = EntityUtils.toString(httpEntity);

                Log.d("response is", response);

                return new JSONObject(response);

            } catch (Exception ex) {

                ex.printStackTrace();

            }

            return null;
        }

        @Override
        protected void onPostExecute(JSONObject result) 
        {
            super.onPostExecute(result);

            progressDialog.dismiss();

            if(result != null)
            {
                try
                {
                    JSONObject jobj = result.getJSONObject("result");

                    String status = jobj.getString("status");

                    if(status.equals("true"))
                    {
                        JSONArray array = jobj.getJSONArray("data");

                        for(int x = 0; x < array.length(); x++)
                        {
                            HashMap<String, String> map = new HashMap<String, String>();

                            map.put("name", array.getJSONObject(x).getString("name"));

                            map.put("date", array.getJSONObject(x).getString("date"));

                            map.put("description", array.getJSONObject(x).getString("description"));

                            list.add(map);
                        }

                        CalendarAdapter adapter = new CalendarAdapter(Calendar.this, list);

                        list_of_calendar.setAdapter(adapter);
                    }
                }
                catch (Exception e) 
                {
                    e.printStackTrace();
                }
            }
            else
            {
                Toast.makeText(Calendar.this, "Network Problem", Toast.LENGTH_LONG).show();
            }
        }

    }

OnCreate Method에서 다음과 같이 실행합니다. new GetData().execute();

여기서 Calendar는 내 calendarActivity이며 이러한 값을 목록보기로 설정하는 CalendarAdapter도 만들었습니다.

당사 사이트를 사용함과 동시에 당사의 쿠키 정책개인정보 보호정책을 읽고 이해하였음을 인정하는 것으로 간주합니다.
Licensed under cc by-sa 3.0 with attribution required.