Android 在屏幕上打印LOG

Android开发中需要迅速定位问题,在android 屏幕上打印LOG,是一个很好的通道

基本的思路:启动LogService读取指定log,使用WindowManager展示到屏幕上

直接上代码

public class LogService extends Service {

    private ListView listview;
    private LinkedList<LogLine> logList = new LinkedList<LogLine>();
    private LogAdapter mAdapter;
    private final int MAX_LINE = 500;
    private SimpleDateFormat LOGCAT_TIME_FORMAT = new SimpleDateFormat("HH:mm:ss.SSS");
    private Thread readLog;
    private boolean isAllowReadLog = false;

    @Override
    public IBinder onBind(Intent arg0) {
        return null;
    }

    @Override
    public int onStartCommand(Intent intent, int flags, int startId) {

//Utility.LOG_TAG 为自定义的logString,service会读取此log

        readLog = new Thread(new LogReaderThread(Utility.LOG_TAG));
        readLog.start();
        createSystemWindow();
        isAllowReadLog = true;
        return START_STICKY;
    }

    @Override
    public void onDestroy() {
        removeSystemWindow();
        isAllowReadLog = false;
        super.onDestroy();
    }

    private void createSystemWindow() {
        final WindowManager.LayoutParams lp = new WindowManager.LayoutParams(ViewGroup.LayoutParams.MATCH_PARENT, ViewGroup.LayoutParams.MATCH_PARENT, WindowManager.LayoutParams.TYPE_SYSTEM_OVERLAY, 0, PixelFormat.TRANSLUCENT);
        // lp.gravity=Gravity.LEFT|Gravity.TOP; //调整悬浮窗口至左上角
        // 以屏幕左上角为原点,设置x、y初始化
        // lp.x=0;
        // lp.y=0;
        final LayoutInflater inflator = (LayoutInflater) getSystemService(Context.LAYOUT_INFLATER_SERVICE);
        final WindowManager wm = (WindowManager) getSystemService(WINDOW_SERVICE);
        listview = (ListView) inflator.inflate(R.layout.log_window, null);
        logList = new LinkedList<LogLine>();
        mAdapter = new LogAdapter(this, logList);
        listview.setAdapter(mAdapter);
        if (isAllowReadLog) {
            wm.addView(listview, lp);
        }

    }

    private void removeSystemWindow() {
        if (listview != null && listview.getParent() != null) {
            final WindowManager wm = (WindowManager) getSystemService(WINDOW_SERVICE);
            wm.removeViewImmediate(listview);
        }
    }

    class LogAdapter extends ArrayAdapter<LogLine> {

        private LayoutInflater inflator = (LayoutInflater) getSystemService(Context.LAYOUT_INFLATER_SERVICE);

        public LogAdapter(Context context, List<LogLine> objects) {
            super(context, 0, objects);
        }

        public void add(LogLine line) {
            logList.add(line);
            notifyDataSetChanged();
        }

        @Override
        public LogLine getItem(int position) {
            return logList.get(position);
        }

        @Override
        public int getCount() {
            return logList.size();
        }

        @Override
        public View getView(int position, View convertView, ViewGroup parent) {
            LogLine line = getItem(position);
            ViewHolder holder;
            if (convertView == null) {
                holder = new ViewHolder();
                convertView = inflator.inflate(R.layout.log_line, parent, false);
                holder.time = (TextView) convertView.findViewById(R.id.log_time);
                holder.content = (TextView) convertView.findViewById(R.id.log_content);
                convertView.setTag(holder);
            } else {
                holder = (ViewHolder) convertView.getTag();
            }
            holder.time.setText(line.time);
            holder.content.setText(line.content);
            if (line.color != 0) {
                holder.content.setTextColor(line.color);
            } else {
                holder.content.setTextColor(getResources().getColor(android.R.color.white));
            }
            return convertView;
        }

    }

    class ViewHolder {
        public TextView time;
        public TextView content;
    }

    class LogReaderThread implements Runnable {

        private String filter;

        public LogReaderThread(String filter) {
            this.filter = filter;
        }

        @Override
        public void run() {
            Process mLogcatProc = null;
            BufferedReader reader = null;
            try {
                mLogcatProc = Runtime.getRuntime().exec(new String[] { "logcat", filter + " *:S" });
                reader = new BufferedReader(new InputStreamReader(mLogcatProc.getInputStream()));
                String line;

                while (isAllowReadLog) {
                    if ((line = reader.readLine()) != null) {
                        Message msg = new Message();
                        msg.obj = line;
                        handler.sendMessage(msg);
                    }
                }
            } catch (Exception e) {
                e.printStackTrace();
            }
        }
    }

    private void buildLogLine(String line) {
        LogLine log = new LogLine();
        log.time = LOGCAT_TIME_FORMAT.format(new Date()) + ": ";
        if (line.startsWith("I")) {
            log.color = Color.parseColor("#008f86");
        } else if (line.startsWith("V")) {
            log.color = Color.parseColor("#fd7c00");
        } else if (line.startsWith("D")) {
            log.color = Color.parseColor("#8f3aa3");
        } else if (line.startsWith("E")) {
            log.color = Color.parseColor("#fe2b00");
        }
        if (line.contains(")")) {
            line = line.substring(line.indexOf(")") + 1, line.length());
        }
        log.content = line;

        while (logList.size() > MAX_LINE) {
            logList.remove();
        }
        mAdapter.add(log);
    }

    private Handler handler = new Handler() {
        public void handleMessage(Message msg) {
            buildLogLine(msg.obj.toString());
        };
    };

}

//实体类

public class LogLine {
    
    public String time;
    public String content;
    public int color;
    
}

启动server,log将输出到屏幕上,Android共勉!

转自:http://blog.csdn.net/lushitianxia/article/details/51361057

Android开发中,我们可以使用Log类来在控制台或日志文件中进行打印输出,而不是直接在屏幕上显示。但是,我们可以通过Toast或Snackbar等方法间接地将日志信息显示在屏幕上。 最常用的方法是使用Toast类显示日志信息。Toast是一种在屏幕上显示简短消息的Android机制。我们可以使用Toast.makeText()方法创建一个Toast实例,并指定要显示的消息文本、显示时长等参数。然后,调用Toast.show()方法将Toast显示在屏幕上。 例如,我们可以使用以下代码将一条日志信息显示在屏幕上: ``` String message = "这是一条日志信息"; Toast.makeText(context, message, Toast.LENGTH_SHORT).show(); ``` 这样,当程序执行到这段代码时,屏幕上会弹出一个短暂显示消息的提示框,其中显示了我们指定的日志信息。 另一种方法是使用Snackbar类显示日志信息。Snackbar是一个替代Toast的控件,提供了更灵活和功能强大的消息显示方式。我们可以使用Snackbar.make()方法创建一个Snackbar实例,并指定要显示的消息文本、持续时长等参数。然后,调用Snackbar.show()方法将Snackbar显示在屏幕上。 例如,我们可以使用以下代码将一条日志信息显示在屏幕上: ``` String message = "这是一条日志信息"; Snackbar.make(view, message, Snackbar.LENGTH_SHORT).show(); ``` 这里的view参数表示Snackbar要显示在哪个视图上,可以是Activity的根视图或任何其他合适的视图。 总结来说,虽然AndroidLog类主要用于在控制台或日志文件中进行日志打印输出,但我们可以通过使用Toast或Snackbar等方法,将部分日志信息间接地显示在屏幕上,以增加用户体验或调试方便性。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值