Merge "Cleanup unused code"

This commit is contained in:
Adam Cohen
2013-05-08 18:00:52 +00:00
committed by Android (Google) Code Review
3 changed files with 0 additions and 280 deletions
@@ -1,138 +0,0 @@
/*
* Copyright (C) 2011 The Android Open Source Project
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package com.android.launcher2;
import android.content.Context;
import android.content.res.TypedArray;
import android.graphics.Bitmap;
import android.graphics.Canvas;
import android.graphics.Paint;
import android.graphics.PorterDuff;
import android.graphics.Rect;
import android.graphics.drawable.Drawable;
import android.util.AttributeSet;
import android.widget.TextView;
import com.android.launcher.R;
/**
* This class adds a stroke to the generic TextView allowing the text to stand out better against
* the background (ie. in the AllApps button).
*/
public class StrokedTextView extends TextView {
private final Canvas mCanvas = new Canvas();
private final Paint mPaint = new Paint();
private Bitmap mCache;
private boolean mUpdateCachedBitmap;
private int mStrokeColor;
private float mStrokeWidth;
private int mTextColor;
public StrokedTextView(Context context) {
super(context);
init(context, null, 0);
}
public StrokedTextView(Context context, AttributeSet attrs) {
super(context, attrs);
init(context, attrs, 0);
}
public StrokedTextView(Context context, AttributeSet attrs, int defStyle) {
super(context, attrs, defStyle);
init(context, attrs, defStyle);
}
private void init(Context context, AttributeSet attrs, int defStyle) {
TypedArray a = context.obtainStyledAttributes(attrs, R.styleable.StrokedTextView,
defStyle, 0);
mStrokeColor = a.getColor(R.styleable.StrokedTextView_strokeColor, 0xFF000000);
mStrokeWidth = a.getFloat(R.styleable.StrokedTextView_strokeWidth, 0.0f);
mTextColor = a.getColor(R.styleable.StrokedTextView_strokeTextColor, 0xFFFFFFFF);
a.recycle();
mUpdateCachedBitmap = true;
// Setup the text paint
mPaint.setAntiAlias(true);
mPaint.setStyle(Paint.Style.FILL_AND_STROKE);
}
protected void onTextChanged(CharSequence text, int start, int before, int after) {
super.onTextChanged(text, start, before, after);
mUpdateCachedBitmap = true;
}
protected void onSizeChanged(int w, int h, int oldw, int oldh) {
super.onSizeChanged(w, h, oldw, oldh);
if (w > 0 && h > 0) {
mUpdateCachedBitmap = true;
mCache = Bitmap.createBitmap(w, h, Bitmap.Config.ARGB_8888);
} else {
mCache = null;
}
}
protected void onDraw(Canvas canvas) {
if (mCache != null) {
if (mUpdateCachedBitmap) {
final int w = getMeasuredWidth();
final int h = getMeasuredHeight();
final String text = getText().toString();
final Rect textBounds = new Rect();
final Paint textPaint = getPaint();
final int textWidth = (int) textPaint.measureText(text);
textPaint.getTextBounds("x", 0, 1, textBounds);
// Clear the old cached image
mCanvas.setBitmap(mCache);
mCanvas.drawColor(0, PorterDuff.Mode.CLEAR);
// Draw the drawable
final int drawableLeft = getPaddingLeft();
final int drawableTop = getPaddingTop();
final Drawable[] drawables = getCompoundDrawables();
for (int i = 0; i < drawables.length; ++i) {
if (drawables[i] != null) {
drawables[i].setBounds(drawableLeft, drawableTop,
drawableLeft + drawables[i].getIntrinsicWidth(),
drawableTop + drawables[i].getIntrinsicHeight());
drawables[i].draw(mCanvas);
}
}
final int left = w - getPaddingRight() - textWidth;
final int bottom = (h + textBounds.height()) / 2;
// Draw the outline of the text
mPaint.setStrokeWidth(mStrokeWidth);
mPaint.setColor(mStrokeColor);
mPaint.setTextSize(getTextSize());
mCanvas.drawText(text, left, bottom, mPaint);
// Draw the text itself
mPaint.setStrokeWidth(0);
mPaint.setColor(mTextColor);
mCanvas.drawText(text, left, bottom, mPaint);
mUpdateCachedBitmap = false;
}
canvas.drawBitmap(mCache, 0, 0, mPaint);
} else {
super.onDraw(canvas);
}
}
}
@@ -1,118 +0,0 @@
/*
* Copyright (C) 2009 The Android Open Source Project
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package com.android.launcher2;
import android.os.Handler;
import android.os.SystemClock;
/**
* Provides an animation between 0.0f and 1.0f over a given duration.
*/
class SymmetricalLinearTween {
private static final int FPS = 30;
private static final int FRAME_TIME = 1000 / FPS;
Handler mHandler;
int mDuration;
TweenCallback mCallback;
boolean mRunning;
long mBase;
boolean mDirection;
float mValue;
/**
* @param duration milliseconds duration
* @param callback callbacks
*/
public SymmetricalLinearTween(boolean initial, int duration, TweenCallback callback) {
mValue = initial ? 1.0f : 0.0f;
mDirection = initial;
mDuration = duration;
mCallback = callback;
mHandler = new Handler();
}
/**
* Starts the tweening.
*
* @param direction If direction is true, the value goes towards 1.0f. If direction
* is false, the value goes towards 0.0f.
*/
public void start(boolean direction) {
start(direction, SystemClock.uptimeMillis());
}
/**
* Starts the tweening.
*
* @param direction If direction is true, the value goes towards 1.0f. If direction
* is false, the value goes towards 0.0f.
* @param baseTime The time to use as zero for this animation, in the
* {@link SystemClock.uptimeMillis} time base. This allows you to
* synchronize multiple animations.
*/
public void start(boolean direction, long baseTime) {
if (direction != mDirection) {
if (!mRunning) {
mBase = baseTime;
mRunning = true;
mCallback.onTweenStarted();
long next = SystemClock.uptimeMillis() + FRAME_TIME;
mHandler.postAtTime(mTick, next);
} else {
// reverse direction
long now = SystemClock.uptimeMillis();
long diff = now - mBase;
mBase = now + diff - mDuration;
}
mDirection = direction;
}
}
Runnable mTick = new Runnable() {
public void run() {
long base = mBase;
long now = SystemClock.uptimeMillis();
long diff = now-base;
int duration = mDuration;
float val = diff/(float)duration;
if (!mDirection) {
val = 1.0f - val;
}
if (val > 1.0f) {
val = 1.0f;
} else if (val < 0.0f) {
val = 0.0f;
}
float old = mValue;
mValue = val;
mCallback.onTweenValueChanged(val, old);
int frame = (int)(diff / FRAME_TIME);
long next = base + ((frame+1)*FRAME_TIME);
if (diff < duration) {
mHandler.postAtTime(this, next);
}
if (diff >= duration) {
mCallback.onTweenFinished();
mRunning = false;
}
}
};
}
@@ -1,24 +0,0 @@
/*
* Copyright (C) 2009 The Android Open Source Project
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package com.android.launcher2;
interface TweenCallback {
void onTweenValueChanged(float value, float oldValue);
void onTweenStarted();
void onTweenFinished();
}