Salut,
Je souhaite réaliser une application qui lit en permanence les activités log. Pour cela, j'ai réaliser une petite application qui récupére le résultat de la commande "logcat -v time". Mais l'application "freeze" au bout de quelques secondes.
Est-ce que il y a un moyen de réaliser ce travail ?
Merci.

Voici le code:
Manifest:
Code : Sélectionner tout - Visualiser dans une fenêtre à part
1
2
3
4
 
....
<uses-permission android:name="android.permission.READ_LOGS" />
....
source java:
Code : Sélectionner tout - Visualiser dans une fenêtre à part
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
 
package logcloud.logsintotextfield;
 
import android.os.AsyncTask;
import android.os.Looper;
import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.view.View;
import android.widget.EditText;
import android.widget.ScrollView;
 
import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
import java.util.regex.Matcher;
import java.util.regex.Pattern;
 
public class logsIntoTextfieldMainActivity extends AppCompatActivity {
    public EditText logsTextfieldId;
    public ScrollView logContainer;
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.main_activity_logs_into_textfield);
 
        logsTextfieldId = (EditText) findViewById(R.id.logsTextfieldId);
        logContainer = (ScrollView)findViewById(R.id.logContainer);
 
        getLogs();
 
    }
 
    protected void getLogs() {
        GetLogs getLogs = new GetLogs(this);
        getLogs.execute();
    }
 
}
 
class GetLogs extends AsyncTask<Void, String, Void> {
    protected logsIntoTextfieldMainActivity context;
 
    public GetLogs(logsIntoTextfieldMainActivity _context){
        context = _context;
    }
 
    @Override
    protected Void doInBackground(Void... voids) {
        try {
            Process process = Runtime.getRuntime().exec("logcat -v time");
            BufferedReader bufferedReader = new BufferedReader(
                    new InputStreamReader(process.getInputStream()));
 
            String line = "";
            while ((line = bufferedReader.readLine()) != null) {
                publishProgress(line);
            }
        }
        catch (IOException e) {
        }
        return null;
    }
 
    @Override
    protected void onProgressUpdate(String... values) {
        super.onProgressUpdate(values);
        context.logsTextfieldId.append(values[0] + "\n");
        context.logContainer.post(new Runnable() {
            @Override
            public void run() {
                context.logContainer.fullScroll(View.FOCUS_DOWN);
            }
        });
    }
}