gpt4 book ai didi

android - 如何在 Android 的 TextView 中打印完整的 logcat 历史记录?

转载 作者:行者123 更新时间:2023-11-29 17:20:26 26 4
gpt4 key购买 nike

我正在使用 logcat 在我的 Android 应用程序中记录消息,我希望能够访问这些消息并在 DialogFragment 的 TextView 中显示它们。消息列表非常不一致,每次打开和关闭对话框时都会发生变化。它会显示一次完整的历史记录,然后在下次删除时显示,有时还会显示更多消息。每次打开对话框时,我可以做些什么来显示所有消息(用于运行)?我是不是在错误的时间运行了这个过程?或者缓冲区应该在其他地方处理吗?谢谢。

public boolean onOptionsItemSelected(MenuItem item) {
switch (item.getItemId()) {
case R.id.action_view_logs:
// View Logs MenuItem tapped
if (logsDialogFragment == null) {
logsDialogFragment = new LogsDialogFragment();
}
logsDialogFragment.show(getFragmentManager(), "dialog");
return true;
case R.id.action_exit:
// Exit MenuItem tapped
finish();
return true;
default:
return super.onOptionsItemSelected(item);
}
}

public class LogsDialogFragment extends DialogFragment {

@Override
public Dialog onCreateDialog(Bundle savedInstanceState) {
Log.i(WifiDirectHandler.LOG_TAG, "Viewing Logs");
AlertDialog.Builder dialogBuilder = new AlertDialog.Builder(getActivity())
.setTitle(getString(R.string.title_logs))
.setNegativeButton(getString(R.string.action_close),
new DialogInterface.OnClickListener() {
public void onClick(DialogInterface dialog, int whichButton) {
dialog.dismiss();
}
}
);

LayoutInflater i = getActivity().getLayoutInflater();
View rootView = i.inflate(R.layout.fragment_logs_dialog, null);

TextView logTextView = (TextView) rootView.findViewById(R.id.logTextView);
logTextView.setMovementMethod(new ScrollingMovementMethod());

try {
Process process = Runtime.getRuntime().exec("logcat -d");
BufferedReader bufferedReader = new BufferedReader(
new InputStreamReader(process.getInputStream()));

StringBuilder log = new StringBuilder();
String line;
while ((line = bufferedReader.readLine()) != null) {
if (line.contains(WifiDirectHandler.LOG_TAG)){
// Removes log tag and PID from the log line
log.append(line.substring(line.indexOf(": ") + 2)).append("\n");
}
}
logTextView.setText(log.toString());
} catch (IOException e) {
}

dialogBuilder.setView(rootView);
return dialogBuilder.create();
}
}

最佳答案

消息的 logcat 缓冲区不是很大,所以旧消息只是从 logcat 中删除,如果您需要完整的日志 - 将 logcat 消息保存到 sdcard 上的文件,然后从中读取信息。此方法会将所有当前消息保存到文件中:

public static void saveLogcatToFile(Context context) {
String fileName = "yourlogname.log";
File outputFile = new File(Environment.getExternalStorageDirectory().getAbsolutePath() +
"/YourAppName", fileName);
try {
@SuppressWarnings("unused")
Process process = Runtime.getRuntime().exec("logcat -f "+outputFile.getAbsolutePath());
} catch (IOException e) {
e.printStackTrace();
}
}

上面的代码只是一个时间点的日志快照。如果您想连续写入日志,请使用带有 FileLogger 的 Java 日志记录并写入。

关于android - 如何在 Android 的 TextView 中打印完整的 logcat 历史记录?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/36819066/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com