diff --git a/core/java/com/android/internal/app/PlatLogoActivity.java b/core/java/com/android/internal/app/PlatLogoActivity.java index 9fbbb3d9c6551..a0e125a074948 100644 --- a/core/java/com/android/internal/app/PlatLogoActivity.java +++ b/core/java/com/android/internal/app/PlatLogoActivity.java @@ -17,32 +17,79 @@ package com.android.internal.app; import android.app.Activity; +import android.content.ActivityNotFoundException; +import android.content.Intent; import android.os.Bundle; +import android.os.Handler; +import android.os.Vibrator; import android.view.MotionEvent; +import android.view.View; +import android.view.ViewConfiguration; import android.widget.ImageView; import android.widget.Toast; public class PlatLogoActivity extends Activity { Toast mToast; + ImageView mContent; + Vibrator mZzz = new Vibrator(); + int mCount; + final Handler mHandler = new Handler(); + + Runnable mSuperLongPress = new Runnable() { + public void run() { + mCount++; + mZzz.vibrate(50 * mCount); + final float scale = 1f + 0.25f * mCount * mCount; + mContent.setScaleX(scale); + mContent.setScaleY(scale); + + if (mCount <= 3) { + mHandler.postDelayed(mSuperLongPress, ViewConfiguration.getLongPressTimeout()); + } else { + try { + startActivity(new Intent(Intent.ACTION_MAIN) + .setFlags(Intent.FLAG_ACTIVITY_NEW_TASK + | Intent.FLAG_ACTIVITY_CLEAR_TASK + | Intent.FLAG_ACTIVITY_EXCLUDE_FROM_RECENTS) + .setClassName("com.android.systemui","com.android.systemui.Nyandroid")); + } catch (ActivityNotFoundException ex) { + android.util.Log.e("PlatLogoActivity", "Couldn't find platlogo screensaver."); + } + finish(); + } + } + }; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); - mToast = Toast.makeText(this, "REZZZZZZZ...", Toast.LENGTH_SHORT); + mToast = Toast.makeText(this, "Android 4.0: Ice Cream Sandwich", Toast.LENGTH_SHORT); - ImageView content = new ImageView(this); - content.setImageResource(com.android.internal.R.drawable.platlogo); - content.setScaleType(ImageView.ScaleType.CENTER_INSIDE); + mContent = new ImageView(this); + mContent.setImageResource(com.android.internal.R.drawable.platlogo); + mContent.setScaleType(ImageView.ScaleType.CENTER_INSIDE); + + mContent.setOnTouchListener(new View.OnTouchListener() { + @Override + public boolean onTouch(View v, MotionEvent event) { + final int action = event.getAction(); + if (action == MotionEvent.ACTION_DOWN) { + mContent.setPressed(true); + mHandler.removeCallbacks(mSuperLongPress); + mCount = 0; + mHandler.postDelayed(mSuperLongPress, 2*ViewConfiguration.getLongPressTimeout()); + } else if (action == MotionEvent.ACTION_UP) { + if (mContent.isPressed()) { + mContent.setPressed(false); + mHandler.removeCallbacks(mSuperLongPress); + mToast.show(); + } + } + return true; + } + }); - setContentView(content); - } - - @Override - public boolean dispatchTouchEvent(MotionEvent ev) { - if (ev.getAction() == MotionEvent.ACTION_UP) { - mToast.show(); - } - return super.dispatchTouchEvent(ev); + setContentView(mContent); } } diff --git a/core/res/res/drawable-nodpi/platlogo.png b/core/res/res/drawable-nodpi/platlogo.png index e619ed59bf1e1..8aa3b9ef2ef70 100644 Binary files a/core/res/res/drawable-nodpi/platlogo.png and b/core/res/res/drawable-nodpi/platlogo.png differ diff --git a/packages/SystemUI/AndroidManifest.xml b/packages/SystemUI/AndroidManifest.xml index a2452c4916137..64c54d9e9cd9b 100644 --- a/packages/SystemUI/AndroidManifest.xml +++ b/packages/SystemUI/AndroidManifest.xml @@ -101,5 +101,21 @@ android:taskAffinity="com.android.systemui.net" android:excludeFromRecents="true" /> + + + + + + + + diff --git a/packages/SystemUI/res/drawable-nodpi/nyandroid00.png b/packages/SystemUI/res/drawable-nodpi/nyandroid00.png new file mode 100644 index 0000000000000..6cea87315f174 Binary files /dev/null and b/packages/SystemUI/res/drawable-nodpi/nyandroid00.png differ diff --git a/packages/SystemUI/res/drawable-nodpi/nyandroid01.png b/packages/SystemUI/res/drawable-nodpi/nyandroid01.png new file mode 100644 index 0000000000000..82b8a218c5edf Binary files /dev/null and b/packages/SystemUI/res/drawable-nodpi/nyandroid01.png differ diff --git a/packages/SystemUI/res/drawable-nodpi/nyandroid02.png b/packages/SystemUI/res/drawable-nodpi/nyandroid02.png new file mode 100644 index 0000000000000..fde0033d78d63 Binary files /dev/null and b/packages/SystemUI/res/drawable-nodpi/nyandroid02.png differ diff --git a/packages/SystemUI/res/drawable-nodpi/nyandroid03.png b/packages/SystemUI/res/drawable-nodpi/nyandroid03.png new file mode 100644 index 0000000000000..54c5f46381279 Binary files /dev/null and b/packages/SystemUI/res/drawable-nodpi/nyandroid03.png differ diff --git a/packages/SystemUI/res/drawable-nodpi/nyandroid04.png b/packages/SystemUI/res/drawable-nodpi/nyandroid04.png new file mode 100644 index 0000000000000..35e5ab5482654 Binary files /dev/null and b/packages/SystemUI/res/drawable-nodpi/nyandroid04.png differ diff --git a/packages/SystemUI/res/drawable-nodpi/nyandroid05.png b/packages/SystemUI/res/drawable-nodpi/nyandroid05.png new file mode 100644 index 0000000000000..d3eaace4c8c52 Binary files /dev/null and b/packages/SystemUI/res/drawable-nodpi/nyandroid05.png differ diff --git a/packages/SystemUI/res/drawable-nodpi/nyandroid06.png b/packages/SystemUI/res/drawable-nodpi/nyandroid06.png new file mode 100644 index 0000000000000..0e0d3b1da288b Binary files /dev/null and b/packages/SystemUI/res/drawable-nodpi/nyandroid06.png differ diff --git a/packages/SystemUI/res/drawable-nodpi/nyandroid07.png b/packages/SystemUI/res/drawable-nodpi/nyandroid07.png new file mode 100644 index 0000000000000..edb0b1731e61e Binary files /dev/null and b/packages/SystemUI/res/drawable-nodpi/nyandroid07.png differ diff --git a/packages/SystemUI/res/drawable-nodpi/nyandroid08.png b/packages/SystemUI/res/drawable-nodpi/nyandroid08.png new file mode 100644 index 0000000000000..10fc4f62d0e17 Binary files /dev/null and b/packages/SystemUI/res/drawable-nodpi/nyandroid08.png differ diff --git a/packages/SystemUI/res/drawable-nodpi/nyandroid09.png b/packages/SystemUI/res/drawable-nodpi/nyandroid09.png new file mode 100644 index 0000000000000..57ade54d7227c Binary files /dev/null and b/packages/SystemUI/res/drawable-nodpi/nyandroid09.png differ diff --git a/packages/SystemUI/res/drawable-nodpi/nyandroid10.png b/packages/SystemUI/res/drawable-nodpi/nyandroid10.png new file mode 100644 index 0000000000000..36feb2fa6ff37 Binary files /dev/null and b/packages/SystemUI/res/drawable-nodpi/nyandroid10.png differ diff --git a/packages/SystemUI/res/drawable-nodpi/nyandroid11.png b/packages/SystemUI/res/drawable-nodpi/nyandroid11.png new file mode 100644 index 0000000000000..125935ba9dddc Binary files /dev/null and b/packages/SystemUI/res/drawable-nodpi/nyandroid11.png differ diff --git a/packages/SystemUI/res/drawable-nodpi/star0.png b/packages/SystemUI/res/drawable-nodpi/star0.png new file mode 100644 index 0000000000000..f2ca960871ed6 Binary files /dev/null and b/packages/SystemUI/res/drawable-nodpi/star0.png differ diff --git a/packages/SystemUI/res/drawable-nodpi/star1.png b/packages/SystemUI/res/drawable-nodpi/star1.png new file mode 100644 index 0000000000000..69ef4da7eb29e Binary files /dev/null and b/packages/SystemUI/res/drawable-nodpi/star1.png differ diff --git a/packages/SystemUI/res/drawable-nodpi/star2.png b/packages/SystemUI/res/drawable-nodpi/star2.png new file mode 100644 index 0000000000000..b95968acaecd7 Binary files /dev/null and b/packages/SystemUI/res/drawable-nodpi/star2.png differ diff --git a/packages/SystemUI/res/drawable-nodpi/star3.png b/packages/SystemUI/res/drawable-nodpi/star3.png new file mode 100644 index 0000000000000..ad0f5896e6da4 Binary files /dev/null and b/packages/SystemUI/res/drawable-nodpi/star3.png differ diff --git a/packages/SystemUI/res/drawable-nodpi/star4.png b/packages/SystemUI/res/drawable-nodpi/star4.png new file mode 100644 index 0000000000000..934c45b4c5de2 Binary files /dev/null and b/packages/SystemUI/res/drawable-nodpi/star4.png differ diff --git a/packages/SystemUI/res/drawable-nodpi/star5.png b/packages/SystemUI/res/drawable-nodpi/star5.png new file mode 100644 index 0000000000000..46a4435162cfc Binary files /dev/null and b/packages/SystemUI/res/drawable-nodpi/star5.png differ diff --git a/packages/SystemUI/res/drawable/nyandroid_anim.xml b/packages/SystemUI/res/drawable/nyandroid_anim.xml new file mode 100644 index 0000000000000..855a0c2e981ee --- /dev/null +++ b/packages/SystemUI/res/drawable/nyandroid_anim.xml @@ -0,0 +1,32 @@ + + + + + + + + + + + + + + + + + diff --git a/packages/SystemUI/res/drawable/star_anim.xml b/packages/SystemUI/res/drawable/star_anim.xml new file mode 100644 index 0000000000000..d7f2d8f3804de --- /dev/null +++ b/packages/SystemUI/res/drawable/star_anim.xml @@ -0,0 +1,26 @@ + + + + + + + + + + + diff --git a/packages/SystemUI/src/com/android/systemui/Nyandroid.java b/packages/SystemUI/src/com/android/systemui/Nyandroid.java new file mode 100644 index 0000000000000..6f168ba190d4c --- /dev/null +++ b/packages/SystemUI/src/com/android/systemui/Nyandroid.java @@ -0,0 +1,253 @@ +/*); + * 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.systemui; + +import android.animation.AnimatorSet; +import android.animation.PropertyValuesHolder; +import android.animation.ObjectAnimator; +import android.animation.TimeAnimator; +import android.app.Activity; +import android.content.ComponentName; +import android.content.Context; +import android.content.Intent; +import android.graphics.drawable.AnimationDrawable; +import android.graphics.Bitmap; +import android.graphics.Canvas; +import android.graphics.Color; +import android.graphics.Matrix; +import android.graphics.Paint; +import android.graphics.Point; +import android.graphics.Rect; +import android.graphics.RectF; +import android.os.Handler; +import android.util.AttributeSet; +import android.util.DisplayMetrics; +import android.util.Pair; +import android.view.Gravity; +import android.view.MotionEvent; +import android.view.View; +import android.view.ViewGroup; +import android.view.WindowManager; +import android.widget.FrameLayout; +import android.widget.ImageView; +import java.util.HashMap; +import java.util.Random; + +public class Nyandroid extends Activity { + final static boolean DEBUG = false; + + public static class Board extends FrameLayout + { + public static final boolean FIXED_STARS = true; + public static final int NUM_CATS = 20; + + static Random sRNG = new Random(); + + static float lerp(float a, float b, float f) { + return (b-a)*f + a; + } + + static float randfrange(float a, float b) { + return lerp(a, b, sRNG.nextFloat()); + } + + static int randsign() { + return sRNG.nextBoolean() ? 1 : -1; + } + + static E pick(E[] array) { + if (array.length == 0) return null; + return array[sRNG.nextInt(array.length)]; + } + + public class FlyingCat extends ImageView { + public static final float VMAX = 1000.0f; + public static final float VMIN = 100.0f; + + public float v, vr; + + public float dist; + public float z; + + public ComponentName component; + + public FlyingCat(Context context, AttributeSet as) { + super(context, as); + setImageResource(R.drawable.nyandroid_anim); // @@@ + + if (DEBUG) setBackgroundColor(0x80FF0000); + } + + public String toString() { + return String.format("", + getX(), getY(), getWidth(), getHeight()); + } + + public void reset() { + final float scale = lerp(0.1f,2f,z); + setScaleX(scale); setScaleY(scale); + + setX(-scale*getWidth()+1); + setY(randfrange(0, Board.this.getHeight()-scale*getHeight())); + v = lerp(VMIN, VMAX, z); + + dist = 0; + +// android.util.Log.d("Nyandroid", "reset cat: " + this); + } + + public void update(float dt) { + dist += v * dt; + setX(getX() + v * dt); + } + } + + TimeAnimator mAnim; + + public Board(Context context, AttributeSet as) { + super(context, as); + + setLayerType(View.LAYER_TYPE_HARDWARE, null); + setSystemUiVisibility(View.SYSTEM_UI_FLAG_LOW_PROFILE | View.SYSTEM_UI_FLAG_HIDE_NAVIGATION); + setBackgroundColor(0xFF003366); + } + + private void reset() { +// android.util.Log.d("Nyandroid", "board reset"); + removeAllViews(); + + final ViewGroup.LayoutParams wrap = new ViewGroup.LayoutParams( + ViewGroup.LayoutParams.WRAP_CONTENT, + ViewGroup.LayoutParams.WRAP_CONTENT); + + if (FIXED_STARS) { + for(int i=0; i<20; i++) { + ImageView fixedStar = new ImageView(getContext(), null); + if (DEBUG) fixedStar.setBackgroundColor(0x8000FF80); + fixedStar.setImageResource(R.drawable.star_anim); // @@@ + addView(fixedStar, wrap); + final float scale = randfrange(0.1f, 1f); + fixedStar.setScaleX(scale); fixedStar.setScaleY(scale); + fixedStar.setX(randfrange(0, getWidth())); + fixedStar.setY(randfrange(0, getHeight())); + final AnimationDrawable anim = (AnimationDrawable) fixedStar.getDrawable(); + postDelayed(new Runnable() { + public void run() { + anim.start(); + }}, (int) randfrange(0, 1000)); + } + } + + for(int i=0; i