1 /* 2 * Copyright (C) 2014 The Android Open Source Project 3 * 4 * Licensed under the Apache License, Version 2.0 (the "License"); 5 * you may not use this file except in compliance with the License. 6 * You may obtain a copy of the License at 7 * 8 * http://www.apache.org/licenses/LICENSE-2.0 9 * 10 * Unless required by applicable law or agreed to in writing, software 11 * distributed under the License is distributed on an "AS IS" BASIS, 12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 13 * See the License for the specific language governing permissions and 14 * limitations under the License. 15 */ 16 17 package com.android.testingcamera2; 18 19 import java.util.Date; 20 import java.text.SimpleDateFormat; 21 22 import android.annotation.SuppressLint; 23 import android.content.Context; 24 import android.graphics.Color; 25 import android.os.Handler; 26 import android.os.Looper; 27 import android.text.Spannable; 28 import android.text.SpannableString; 29 import android.text.method.ScrollingMovementMethod; 30 import android.text.style.ForegroundColorSpan; 31 import android.util.AttributeSet; 32 import android.util.TypedValue; 33 import android.view.Gravity; 34 import android.view.View; 35 import android.view.MotionEvent; 36 import android.widget.LinearLayout; 37 import android.widget.TextView; 38 39 public class LogPane extends LinearLayout implements TLog.Logger { 40 41 private final TextView mLogTextView; 42 private final Handler mHandler; 43 44 @SuppressLint("SimpleDateFormat") 45 private SimpleDateFormat mDateFormatter = new SimpleDateFormat("HH:mm:ss.SSS : "); 46 47 public LogPane(Context context, AttributeSet attrs) { 48 super(context, attrs); 49 50 mHandler = new Handler(Looper.getMainLooper()); 51 52 this.setOrientation(VERTICAL); 53 54 TextView titleText = new TextView(context); 55 titleText.setText(R.string.log_pane_label); 56 titleText.setTextSize(TypedValue.COMPLEX_UNIT_PX, 57 context.getResources().getDimension(R.dimen.pane_title_text)); 58 LinearLayout.LayoutParams titleTextLayoutParams = 59 new LinearLayout.LayoutParams(LayoutParams.WRAP_CONTENT, LayoutParams.WRAP_CONTENT); 60 61 this.addView(titleText, titleTextLayoutParams); 62 63 mLogTextView = new TextView(context); 64 mLogTextView.setFreezesText(true); 65 LinearLayout.LayoutParams logTextLayoutParams = 66 new LinearLayout.LayoutParams(LayoutParams.MATCH_PARENT, LayoutParams.MATCH_PARENT); 67 logTextLayoutParams.leftMargin = 40; 68 mLogTextView.setLayoutParams(logTextLayoutParams); 69 mLogTextView.setLines(10); 70 mLogTextView.setMovementMethod(new ScrollingMovementMethod()); 71 mLogTextView.setOnTouchListener(new View.OnTouchListener() { 72 @Override 73 public boolean onTouch(View view, MotionEvent event) { 74 // Allow scrolling of text while inside a scroll view 75 view.getParent().requestDisallowInterceptTouchEvent(true); 76 return false; 77 } 78 }); 79 mLogTextView.setGravity(Gravity.BOTTOM); 80 81 this.addView(mLogTextView); 82 } 83 84 @Override 85 public void addToLog(final String text, boolean error) { 86 StringBuffer logEntry = new StringBuffer(32); 87 logEntry.append("\n").append(mDateFormatter.format(new Date())); 88 logEntry.append(text); 89 final Spannable logLine = new SpannableString(logEntry.toString()); 90 91 int lineColor = error ? Color.RED : Color.WHITE; 92 logLine.setSpan(new ForegroundColorSpan(lineColor), 0, logLine.length(), 93 Spannable.SPAN_EXCLUSIVE_EXCLUSIVE); 94 95 mHandler.post(new Runnable() { 96 public void run() { 97 mLogTextView.append(logLine); 98 } 99 }); 100 } 101 } 102