Asynctask используется несколькими фрагментами Java - PullRequest
0 голосов
/ 11 октября 2018

В настоящее время я работаю над проектом, в котором я получаю данные из дампа JSON на Android.До сих пор я настраивал Asynctask в каждом фрагменте, где мне нужно получать данные из дампа JSON.Что меня интересует, так это то, могу ли я иметь один общедоступный класс Java, который фрагменты могут просто «использовать» всякий раз, когда им нужно извлечь данные.

Это пример того, как я пытался это сделать.Сначала фрагмент, который вызывает Asynctask из общедоступного java-класса:

public class DataTabelFragment extends Fragment {

private TextView sensor1;
private Button jsonButton;

jsonAsynctask jsonasynctask = new jsonAsynctask();


public DataTabelFragment() {
    // Required empty public constructor
}


@Override
public View onCreateView(LayoutInflater inflater, ViewGroup container,
                         Bundle savedInstanceState) {
    // Inflate the layout for this fragment
    View view = inflater.inflate( R.layout.fragment_data_tabel, container, false );

    sensor1 = (TextView) view.findViewById( R.id.sensor1Box );
    //jsonButton = (Button) view.findViewById( R.id.buttonjson );

    new jsonAsynctask().execute();

    for (int i = 0; i < jsonasynctask.allId.size(); i++) {
        sensor1.append( jsonasynctask.allId.get( i ) + " | " + jsonasynctask.allDevice.get( i ) + " | " + jsonasynctask.allTemp.get( i ) + " | " + jsonasynctask.allHum.get( i ) + " | " + jsonasynctask.allBat.get( i ) + " | " + jsonasynctask.allMode.get( i ) + " | " + jsonasynctask.allLux.get( i ) + " | " + jsonasynctask.allDate_time.get( i ) + "\n\n" );

    }

    //new jsonConnection().execute();

    /*

    jsonButton.setOnClickListener( new View.OnClickListener() {
        @Override
        public void onClick(View v) {
            new jsonConnection().execute();
        }
    } );*/



    return view;

}


}

Вот java-класс с Asynctask:

public class jsonAsynctask extends MainActivity {

private TextView sensor1;
private Button jsonButton;

JSONObject deviceArray;
JSONObject tempArray;
JSONObject humArray;
JSONObject batArray;
JSONObject modeArray;
JSONObject date_timeArray;
JSONObject luxArray;

JSONArray json2;

List<String> allId = new ArrayList<String>();
List<String> allDevice = new ArrayList<String>();
List<String> allTemp = new ArrayList<String>();
List<String> allHum = new ArrayList<String>();
List<String> allBat = new ArrayList<String>();
List<String> allMode = new ArrayList<String>();
List<String> allDate_time = new ArrayList<String>();
List<String> allLux = new ArrayList<String>();

String basicAuth;
String line;
String json_string;
String json;
String cxwebURL;
String credentials;
String password;
String username;

Gson gson;
ProgressDialog pd;
String data = "";
HttpURLConnection connection;
BufferedReader bufferedReader;

String id = "";
JSONObject idArray;

URL url;

private static String encodeBase64URLSafeString(byte[] binaryData) {

    return android.util.Base64.encodeToString( binaryData, android.util.Base64.URL_SAFE );

}

public class jsonConnection extends AsyncTask<Void, Void, Void> {

    @Override
    protected Void doInBackground(Void... voids) {

        username = "xxx";

        password = "xxx";

        credentials = username + ":" + password;

        cxwebURL = "https://" + credentials + "@xxx.com/fetch.php?device=xxx";

        try {

            url = new URL( cxwebURL );

            connection = (HttpsURLConnection) url.openConnection();

            basicAuth = "Basic " + new String( encodeBase64URLSafeString( credentials.getBytes() ) );

            connection.setRequestProperty( "Authorization", basicAuth );
            connection.setRequestMethod( "GET" );
            connection.setRequestProperty( "Content-Type", "application/x-www-form-urlencoded" );
            connection.setRequestProperty( "Content-Language", "en-US" );
            connection.setUseCaches( false );
            connection.setDoInput( true );
            connection.setDoOutput( true );
            connection.connect();

            InputStream stream = connection.getInputStream();

            bufferedReader = new BufferedReader( new InputStreamReader( stream ) );

            line = "";

            while (line != null) {
                line = bufferedReader.readLine();
                data = data + line;
            }

            json2 = new JSONArray( data );

            for (int i = 0; i < json2.length(); i++) {
                idArray = json2.getJSONObject( i );
                deviceArray = json2.getJSONObject( i );
                tempArray = json2.getJSONObject( i );
                humArray = json2.getJSONObject( i );
                batArray = json2.getJSONObject( i );
                modeArray = json2.getJSONObject( i );
                date_timeArray = json2.getJSONObject( i );
                luxArray = json2.getJSONObject( i );
                id = idArray.getString( "id" );

                String temp = tempArray.getString( "temp" );
                String device = deviceArray.getString( "device" );

                String hum = humArray.getString( "hum" );

                String bat = batArray.getString( "bat" );

                String mode = modeArray.getString( "mode" );

                String date_time = date_timeArray.getString( "time" );

                String lux = luxArray.getString( "light" );

                allId.add( id );
                allDevice.add( device );
                allTemp.add( temp );
                allHum.add( hum );
                allBat.add( bat );
                allMode.add( mode );
                allDate_time.add( date_time );
                allLux.add( lux );


            }

        } catch (MalformedURLException e) {
            e.printStackTrace();
        } catch (IOException e) {
            e.printStackTrace();
        } catch (JSONException e) {
            e.printStackTrace();
        }
        return null;
    }

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

        pd = new ProgressDialog( new MainActivity() );
        pd.setMessage( "Være sød at vente" );
        //pd.setCancelable( false );
        pd.show();
    }

    @Override
    public void onPostExecute(Void result) {
        super.onPostExecute( result );
        if (pd.isShowing()) {
            pd.dismiss();
        }

        System.out.println( data );

        gson = new Gson();

        json = gson.toJson( data );

        System.out.println( "String json: " + json );

        json_string = data;

        System.out.println( "json_string: " + json_string );

//            System.out.println( "DET HER ER ID!!: " + allId.get( 1 ) );

        //textView2.setMovementMethod( new ScrollingMovementMethod() );


        System.out.println("Size of Array: " + allId.size());



    }
        }


}

Могу ли я сделать это так, илия должен продолжать иметь Asynctask в каждом фрагменте?Кстати, "новый jsonAsynctask (). Execute ();"во фрагменте не работает, и я получаю эту ошибку:

ошибка: не удается найти класс символов выполнить

* Обновление *

Вот обновление класса Java, где Asynctask.

public class jsonAsynctask extends AsyncTask<Void, Void, Void> {

private TextView sensor1;
private Button jsonButton;

JSONObject deviceArray;
JSONObject tempArray;
JSONObject humArray;
JSONObject batArray;
JSONObject modeArray;
JSONObject date_timeArray;
JSONObject luxArray;

JSONArray json2;

List<String> allId = new ArrayList<String>();
List<String> allDevice = new ArrayList<String>();
List<String> allTemp = new ArrayList<String>();
List<String> allHum = new ArrayList<String>();
List<String> allBat = new ArrayList<String>();
List<String> allMode = new ArrayList<String>();
List<String> allDate_time = new ArrayList<String>();
List<String> allLux = new ArrayList<String>();

String basicAuth;
String line;
String json_string;
String json;
String cxwebURL;
String credentials;
String password;
String username;

Gson gson;
ProgressDialog pd;
String data = "";
HttpURLConnection connection;
BufferedReader bufferedReader;

String id = "";
JSONObject idArray;

URL url;

private static String encodeBase64URLSafeString(byte[] binaryData) {

    return android.util.Base64.encodeToString( binaryData, android.util.Base64.URL_SAFE );

}

    @Override
    protected Void doInBackground(Void... voids) {

        username = "xxx";

        password = "xxx";

        credentials = username + ":" + password;

        cxwebURL = "https://" + credentials + "@xxx.com/fetch.php?device=xxx";


        try {

            url = new URL( cxwebURL );

            connection = (HttpsURLConnection) url.openConnection();

            basicAuth = "Basic " + new String( encodeBase64URLSafeString( credentials.getBytes() ) );

            connection.setRequestProperty( "Authorization", basicAuth );
            connection.setRequestMethod( "GET" );
            connection.setRequestProperty( "Content-Type", "application/x-www-form-urlencoded" );
            connection.setRequestProperty( "Content-Language", "en-US" );
            connection.setUseCaches( false );
            connection.setDoInput( true );
            connection.setDoOutput( true );
            connection.connect();

            InputStream stream = connection.getInputStream();

            bufferedReader = new BufferedReader( new InputStreamReader( stream ) );

            line = "";

            while (line != null) {
                line = bufferedReader.readLine();
                data = data + line;
            }

            json2 = new JSONArray( data );


            for (int i = 0; i < json2.length(); i++) {
                idArray = json2.getJSONObject( i );
                deviceArray = json2.getJSONObject( i );
                tempArray = json2.getJSONObject( i );
                humArray = json2.getJSONObject( i );
                batArray = json2.getJSONObject( i );
                modeArray = json2.getJSONObject( i );
                date_timeArray = json2.getJSONObject( i );
                luxArray = json2.getJSONObject( i );
                id = idArray.getString( "id" );

                String temp = tempArray.getString( "temp" );

                String device = deviceArray.getString( "device" );


                String hum = humArray.getString( "hum" );

                String bat = batArray.getString( "bat" );

                String mode = modeArray.getString( "mode" );

                String date_time = date_timeArray.getString( "time" );

                String lux = luxArray.getString( "light" );

                allId.add( id );
                allDevice.add( device );
                allTemp.add( temp );
                allHum.add( hum );
                allBat.add( bat );
                allMode.add( mode );
                allDate_time.add( date_time );
                allLux.add( lux );


            }


        } catch (MalformedURLException e) {
            e.printStackTrace();
        } catch (IOException e) {
            e.printStackTrace();
        } catch (JSONException e) {
            e.printStackTrace();
        }
        return null;
    }

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

        pd = new ProgressDialog( new MainActivity() );
        pd.setMessage( "Være sød at vente" );
        pd.show();
    }

    @Override
    public void onPostExecute(Void result) {
        super.onPostExecute( result );
        if (pd.isShowing()) {
            pd.dismiss();
        }

        gson = new Gson();

        json = gson.toJson( data );

        json_string = data;


      }
        }

}

Полученная ошибка:

ошибка: ожидается ожидаемый класс, интерфейс или перечисление

Я ценю помощь!Заранее спасибо.

1 Ответ

0 голосов
/ 11 октября 2018

Лучше создать отдельный класс для AsynctTask, чем создавать AsyncTask в каждом фрагменте.Вы получаете ошибку, потому что в новом jsonAsynctask (). Execute () // jsonAsyncTask расширяется от MainActivity, поэтому это не AsyncTask

Замените вышеуказанную строку новой jsonConnection .execute ()

...