1

У меня есть небольшая проблема на данный момент: Я пытаюсь сделать видимыми 2 кнопки на моем фрагменте после завершения asynktask, который я вызвал. Для этого я использовал это:?.Выполнить функцию в конце asynctask

while (!recordi.getterminé){ 

    } 
    terminé(); 

Но это не является оптимальным и мое приложение не отвечает :( Так есть какие-либо решения для вызова функции Termine() в функции onPostExecute Благодаря

Вот мой код:

фрагмент:

public class FragmentEnregistrer extends Fragment { 

    String path,nomfinal, ip="http://MYIP/php"; 
    ImageButton mrecord,mupload,mlire; 
    TextView Nomm; 
    ProgressBar progressbar; 
    int i=2; 
    EnregistrerSon recordi; 
    String id; 


    @Override 
    public View onCreateView(LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState) { 
     View myView= inflater.inflate(R.layout.enregistrer, container, false); 

     mrecord= (ImageButton) myView.findViewById(record); 
     mupload= (ImageButton) myView.findViewById(upload); 
     mlire= (ImageButton) myView.findViewById(lire); 
     Nomm = (TextView) myView.findViewById(NomWhizz); 
     progressbar = (ProgressBar) myView.findViewById(progressBar); 
     progressbar.setVisibility(View.INVISIBLE); 

     id=((MainActivity)getActivity()).getIdentifiant(); 

     mrecord.setOnClickListener(new View.OnClickListener() { 
      @RequiresApi(api = Build.VERSION_CODES.N) 
      @Override 
      public void onClick(View v) { 
       Toast.makeText(getActivity().getApplicationContext(), "Enregistrement en cours", Toast.LENGTH_SHORT).show(); 
       String nomm = Nomm.getText().toString(); 
       nomm=nomm.replace(" ", "_"); 
       nomm=nomm.replace("&", ""); 

       final String finalNomm = nomm; 
       recordi = new EnregistrerSon(); 
       recordi.execute(finalNomm); 
       terminé(); 






      } 
     }); 

     mupload.setOnClickListener(new View.OnClickListener() { 
      @RequiresApi(api = Build.VERSION_CODES.N) 
      @Override 
      public void onClick(View v) { 
       UploadOnServer upload = new UploadOnServer(); 
       progressbar.setVisibility(View.VISIBLE); 
       upload.execute(path,nomfinal); 
       progressbar.setVisibility(View.INVISIBLE); 

       HttpGetRequest request = new HttpGetRequest(); 
       request.execute(ip+"/son/creation_son.php?nom_whiz="+nomfinal+"&id_createur="+id); 

      } 
     }); 

     mlire.setOnClickListener(new View.OnClickListener() { 
      @RequiresApi(api = Build.VERSION_CODES.N) 
      @Override 
      public void onClick(View v) { 
       LireSonLocal local = new LireSonLocal(); 
       Uri myUri = Uri.parse("file://"+recordi.getAccess()); 
       local.execute(myUri); 

      } 
     }); 

     return myView; 
    } 

    @RequiresApi(api = Build.VERSION_CODES.N) 
    public void terminé(){ 
     Log.i("Enregistrement","terminé"); 
     Toast.makeText(getActivity().getApplicationContext(), "Enregistrement terminé", Toast.LENGTH_LONG).show(); 
     path = recordi.getAccess(); 
     nomfinal = recordi.getNomSansExtenssions(); 
     Log.i("nomfinale",nomfinal); 
     mlire.setVisibility(View.VISIBLE); 
     mupload.setVisibility(View.VISIBLE); 
     Log.i("test",""); 
} 

} 

И asynktask:

class EnregistrerSon extends AsyncTask<String,Void,String> { 
    private Boolean isRecording = false; 
    private Boolean termine = false; 
    private String Nom, NOM; 



    @RequiresApi(api = Build.VERSION_CODES.N) 
    @Override 
    protected String doInBackground(String... params) { 
     NOM = params[0]; 
     if(!isRecording){ 
      //configuration 
      Looper.prepare(); 
      MediaRecorder mr = new MediaRecorder(); 
      mr.setAudioSource(MediaRecorder.AudioSource.DEFAULT); 
      mr.setOutputFormat(MediaRecorder.OutputFormat.MPEG_4); 
      mr.setAudioEncoder(MediaRecorder.AudioEncoder.AAC); 
      mr.setAudioChannels(1); 
      mr.setAudioEncodingBitRate(1280000); 
      mr.setAudioSamplingRate(9500000); 
      mr.setOutputFile(getAccess()); 
      try {mr.prepare();} 
      catch (IOException e) {e.printStackTrace();} 

      //Demarage du record 
      long start_time = System.currentTimeMillis(); //pendant 15 secondes 
      long wait_time = 15000; 
      long end_time = start_time + wait_time; 
      mr.start(); 
      while (System.currentTimeMillis() < end_time){ 
       Long temps = end_time - System.currentTimeMillis(); 

       isRecording = true; 
       //pendant 15 secondes 
      } 
      mr.stop(); 
      mr.reset(); 
      mr.release(); 
      isRecording = false; 
      termine = true; 
      //fin de l'enregistrement 
     } 
     return "lol"; 
    } 


    @RequiresApi(api = Build.VERSION_CODES.N) 
    protected void onPostExecute(String s) { 
     super.onPostExecute(s); 


    } 

    @TargetApi(Build.VERSION_CODES.N) 
    @RequiresApi(api = Build.VERSION_CODES.N) 
    String getAccess(){ 
     MainActivity main = new MainActivity(); 
     if(Objects.equals(NOM, "Nom") || Objects.equals(NOM, "") || NOM == null) { 
      Calendar now = Calendar.getInstance(); 
      Nom = now.get(Calendar.HOUR_OF_DAY) + "_" + now.get(Calendar.DAY_OF_MONTH) + "_" + now.get(Calendar.MONTH) + "_" + now.get(Calendar.YEAR); 
     } 
     else{ 
      Nom = NOM; 
     } 
     File directory = new File(Environment.getExternalStorageDirectory().getAbsolutePath() + "/Whizz/"); 
     directory.mkdirs(); 
     String filename = directory +"/"+Nom+".mp3"; 
     Log.i("filename",filename); 
     return filename; 
    } 

    Boolean getTerminé(){ 
     return termine; 
    } 

    String getNomSansExtenssions(){ 
     return Nom; 
    } 

} 

ответ

1

Чтобы выполнить свой метод terminé внутри класса AsyncTask. Я предлагаю, чтобы иметь следующее:

  1. Создание поля экземпляра FragmentEnregistrer внутри EnregistrerSon класса.

    private FragmentEnregistrer fragmentEnregistrer; 
    
  2. Создать конструктор в своем классе EnregistrerSon с ожидаемым аргументом FragmentEnregistrer класса и присвоить аргумент переменного поля.

    public EnregistrerSon(FragmentEnregistrer fe) { 
    this.fragmentEnregistrer = fe; 
    } 
    
  3. Вы можете вызвать метод terminé в методе onPostExecute следующим образом:

    protected void onPostExecute(String s) { 
        super.onPostExecute(s); 
        this.fragmentEnregistrer.terminé(); 
    } 
    
  4. Последний, передать экземпляр FragmentEnregistrer объекта на EnregistrerSon конкретизации.

    recordi = new EnregistrerSon(FragmentEnregistrer.this); 
    recordi.execute(finalNomm); 
    
+0

отлично работает!Спасибо :) –

1

Во-первых, линия while (!recordi.getterminé){} terminé(); не имеет смысла, она равна:

while (!recordi.getterminé){ 

} 
terminé(); 

Что касается onPostExecute, да, просто напишите вызов функции в ней:

protected void onPostExecute(String s) { 

    // Anything here will be executed at the end, when doInBackground finishes 
    terminé(); 
} 
+0

Это не возможно: у меня есть эта ошибка: невозможно решить метод terminé() .. Спасибо за вашу помощь –

+0

Правильно, это потому, что они принадлежат к разным классам. Ознакомьтесь с [ответом ниже] (http://stackoverflow.com/a/42319105/7373404), чтобы исправить это. – JonZarate

1

использование модель Broadcast/приемник, onhandleintent() будет работать на UI потоке, в котором вы можете сделать ваши кнопки видимыми.
1. Запустите задачу async. 2. Определите BroadcastReceiver, создайте экземпляр в своей деятельности и зарегистрируйте/отмените регистрацию. 3. В onpostexecute() задачи async просто вызывается sendBroadcast. Возможно, вам придется передать параметр контекста при создании экземпляра AsyncTask. Метод onHandleIntent широковещательного приемника вашего приложения (тот, который вы создали на шаге 2) будет запускаться в потоке пользовательского интерфейса, делая все эти обновления пользовательского интерфейса безопасными.

+0

tis был тем, что я пытался использовать перед публикацией в stackoverflow, и он не работал (приложение продолжает сбой) для меня, но спасибо за вашу помощь. –

+0

Вы использовали широковещательный приемник? Если это так, пожалуйста, укажите в вопросе. Это полезно для нас, чтобы предложить вам ответ. –