简体   繁体   English

API不起作用,progressBar持续旋转

[英]API doesnt work and progressBar keeps spinning

I am a beginner and i am trying to learn how to use APIs on android. 我是一个初学者,我正在尝试学习如何在android上使用API​​。 I am doing a bitcoin price app to learn APIs. 我正在做一个比特币价格应用程序来学习API。 But i have a few problems.I created a progressbar and a price TextView in mainactivity.xml . 但是我有一些问题。我在mainactivity.xml中创建了一个进度条和一个价格TextView。 I set progressbar visible and textview invisible by default.My thought is very simple, i created a new AsyncTask class and after background things are done , i will set the progressbar invisible and the textview visible in the onPostExecute() to show price. 我默认情况下将进度条设置为可见,将textview设置为不可见。我的想法很简单,我创建了一个新的AsyncTask类,并在完成背景操作后将onPostExecute()中的进度条设置为不可见和textview可见以显示价格。 But it didn't work. 但这没有用。 The progressbar keeps spinning, it doesn't show the price i dont understand why it doesn't work. 进度栏一直在旋转,没有显示价格,我不明白为什么它不起作用。

The API i am using 我正在使用的API

MainActivity 主要活动

import android.os.AsyncTask;

import android.os.Bundle;

import android.support.v7.app.AppCompatActivity;

import android.util.Log;

import android.view.View;
import android.widget.ProgressBar;
import android.widget.TextView;


import org.json.JSONObject;
import org.json.JSONTokener;

import java.net.URL;
import java.net.HttpURLConnection;
import java.io.InputStreamReader;
import java.io.BufferedReader;


public class MainActivity extends AppCompatActivity {


        public static String line;
        public static ProgressBar progressBar;

        static String API_URL="https://api.coindesk.com/v1/bpi/currentprice/try.json";

        static TextView priceTextView;
        static TextView timeTextView;

        static int priceInt;




            @Override
            protected void onCreate( Bundle savedInstanceState) {

                super.onCreate(savedInstanceState);


                setContentView(R.layout.activity_main);



                priceTextView=(TextView)findViewById(R.id.priceText);
                timeTextView=(TextView)findViewById(R.id.timeText);

                progressBar=(ProgressBar)findViewById(R.id.progressBar);


                retrievePriceTask retrievePriceTask=new retrievePriceTask();
                retrievePriceTask.execute();



            }




        }



   class retrievePriceTask extends AsyncTask <Void,Void,String>{




       @Override
       protected void onPreExecute() {
           MainActivity.progressBar.setVisibility(View.VISIBLE);
           MainActivity.priceTextView.setVisibility(View.INVISIBLE);


       }

       @Override
       protected String doInBackground(Void... urls) {

           try {
               URL url = new URL(MainActivity.API_URL);
               HttpURLConnection urlConnection = (HttpURLConnection) url.openConnection();
               try {
                   BufferedReader bufferedReader = new BufferedReader(new InputStreamReader(urlConnection.getInputStream()));
                   StringBuilder stringBuilder = new StringBuilder();

                   while ((MainActivity.line = bufferedReader.readLine()) != null) {
                       stringBuilder.append(MainActivity.line).append("\n");
                   }
                   bufferedReader.close();
                   return stringBuilder.toString();


               }
               finally{
                   urlConnection.disconnect();
               }
           }
           catch(Exception e) {
               Log.e("ERROR", e.getMessage(), e);
               return null;
           }
       }





       @Override
       protected void onPostExecute(String s) {



           MainActivity.priceTextView.setVisibility(View.VISIBLE);
           MainActivity.progressBar.setVisibility(View.INVISIBLE);


           try{
               JSONObject jsonObject=(JSONObject)new JSONTokener(MainActivity.line).nextValue();
                MainActivity.priceInt=jsonObject.getJSONObject("bpi").getJSONObject("TRY").getInt("rate");

               MainActivity.priceTextView.setText(MainActivity.priceInt);
           }
           catch (Exception e){
               e.printStackTrace();
           }


       }
   }

My Logcat 我的Logcat

07-16 10:20:08.884 2269-2269/zaaa.trinki E/AndroidRuntime: FATAL EXCEPTION: main
                                                           Process: zaaa.trinki, PID: 2269
                                                           java.lang.RuntimeException: Unable to start activity ComponentInfo{zaaa.trinki/zaaa.trinki.MainActivity}: java.lang.NullPointerException: Attempt to invoke virtual method 'void android.widget.ProgressBar.setVisibility(int)' on a null object reference
                                                               at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2298)
                                                               at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2360)
                                                               at android.app.ActivityThread.access$800(ActivityThread.java:144)
                                                               at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1278)
                                                               at android.os.Handler.dispatchMessage(Handler.java:102)
                                                               at android.os.Looper.loop(Looper.java:135)
                                                               at android.app.ActivityThread.main(ActivityThread.java:5221)
                                                               at java.lang.reflect.Method.invoke(Native Method)
                                                               at java.lang.reflect.Method.invoke(Method.java:372)
                                                               at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:899)
                                                               at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:694)
                                                            Caused by: java.lang.NullPointerException: Attempt to invoke virtual method 'void android.widget.ProgressBar.setVisibility(int)' on a null object reference
                                                               at zaaa.trinki.retrievePriceTask.onPreExecute(MainActivity.java:94)
                                                               at android.os.AsyncTask.executeOnExecutor(AsyncTask.java:587)
                                                               at android.os.AsyncTask.execute(AsyncTask.java:535)
                                                               at zaaa.trinki.MainActivity.onCreate(MainActivity.java:55)
                                                               at android.app.Activity.performCreate(Activity.java:5933)
                                                               at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1105)
                                                               at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2251)
                                                               at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2360) 
                                                               at android.app.ActivityThread.access$800(ActivityThread.java:144) 
                                                               at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1278) 
                                                               at android.os.Handler.dispatchMessage(Handler.java:102) 
                                                               at android.os.Looper.loop(Looper.java:135) 
                                                               at android.app.ActivityThread.main(ActivityThread.java:5221) 
                                                               at java.lang.reflect.Method.invoke(Native Method) 
                                                               at java.lang.reflect.Method.invoke(Method.java:372) 
                                                               at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:899) 
                                                               at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:694) 
07-16 10:37:42.062 16262-16262/zaaa.trinki E/AndroidRuntime: FATAL EXCEPTION: main
                                                             Process: zaaa.trinki, PID: 16262
                                                             java.lang.RuntimeException: Unable to start activity ComponentInfo{zaaa.trinki/zaaa.trinki.MainActivity}: android.content.res.Resources$NotFoundException: String resource ID #0x0
                                                                 at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2298)
                                                                 at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2360)
                                                                 at android.app.ActivityThread.access$800(ActivityThread.java:144)
                                                                 at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1278)
                                                                 at android.os.Handler.dispatchMessage(Handler.java:102)
                                                                 at android.os.Looper.loop(Looper.java:135)
                                                                 at android.app.ActivityThread.main(ActivityThread.java:5221)
                                                                 at java.lang.reflect.Method.invoke(Native Method)
                                                                 at java.lang.reflect.Method.invoke(Method.java:372)
                                                                 at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:899)
                                                                 at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:694)
                                                              Caused by: android.content.res.Resources$NotFoundException: String resource ID #0x0
                                                                 at android.content.res.Resources.getText(Resources.java:274)
                                                                 at android.support.v7.widget.ResourcesWrapper.getText(ResourcesWrapper.java:52)
                                                                 at android.widget.TextView.setText(TextView.java:4122)
                                                                 at zaaa.trinki.MainActivity.onCreate(MainActivity.java:63)
                                                                 at android.app.Activity.performCreate(Activity.java:5933)
                                                                 at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1105)
                                                                 at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2251)
                                                                 at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2360) 
                                                                 at android.app.ActivityThread.access$800(ActivityThread.java:144) 
                                                                 at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1278) 
                                                                 at android.os.Handler.dispatchMessage(Handler.java:102) 
                                                                 at android.os.Looper.loop(Looper.java:135) 
                                                                 at android.app.ActivityThread.main(ActivityThread.java:5221) 
                                                                 at java.lang.reflect.Method.invoke(Native Method) 
                                                                 at java.lang.reflect.Method.invoke(Method.java:372) 
                                                                 at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:899) 
                                                                 at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:694) 

Use a ProgressDialog instead of a ProgressBar: 使用ProgressDialog而不是ProgressBar:

ProgressDialog myProgressDialog = ProgressDialog.show(Context CONTEXT, String TITLE, String MESSAGE, boolean INDETERMINATE, boolean CANCELABLE);

myProgressDialog.setProgressStyle(ProgressDialog.STYLE_SPINNER);

and in your onPostExecute() just put myProgressDialog.dismiss() 并在您的onPostExecute()中放入myProgressDialog.dismiss()

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM