Android仿Win8界面开发

本文将要模仿Win8界面的一个设计,一个一个的方块。方法很简单。这里自己把图片改改就可以成为自己想要的界面了。

1、首先来看看自定义的MyImageView:

package com.example.win8test; import android.annotation.SuppressLint; import android.content.Context; import android.graphics.Camera; import android.graphics.Canvas; import android.graphics.Matrix; import android.graphics.Paint; import android.graphics.PaintFlagsDrawFilter; import android.graphics.drawable.BitmapDrawable; import android.graphics.drawable.Drawable; import android.os.Handler; import android.os.Message; import android.util.AttributeSet; import android.view.MotionEvent; import android.widget.ImageView; @SuppressLint("HandlerLeak") public class MyImageView extends ImageView { public static final int Rotate_Handler_Message_Start = 1; public static final int Rotate_Handler_Message_Turning = 2; public static final int Rotate_Handler_Message_Turned = 3; public static final int Rotate_Handler_Message_Reverse = 6; public static final int Scale_Handler_Message_Start = 1; public static final int Scale_Handler_Message_Turning = 2; public static final int Scale_Handler_Message_Turned = 3; public static final int Scale_Handler_Message_Reverse = 6; private boolean isAntiAlias = true; private boolean scaleOnly = false; private boolean isSizeChanged = false; private boolean isShowAnimation = true; private int rotateDegree = 10; private boolean isFirst = true; private float minScale = 0.95f; private int vWidth; private int vHeight; private boolean isAnimationFinish = true, isActionMove = false, isScale = false; private Camera camera; boolean XbigY = false; float RolateX = 0; float RolateY = 0; OnViewClick onclick = null; public MyImageView(Context context) { super(context); camera = new Camera(); } public MyImageView(Context context, AttributeSet attrs) { super(context, attrs); camera = new Camera(); } public void SetAnimationOnOff(boolean oo) { isShowAnimation = oo; } public void setOnClickIntent(OnViewClick onclick) { this.onclick = onclick; } @SuppressLint("DrawAllocation") @Override protected void onDraw(Canvas canvas) { super.onDraw(canvas); if (isFirst) { isFirst = false; init(); } canvas.setDrawFilter(new PaintFlagsDrawFilter(0, Paint.ANTI_ALIAS_FLAG | Paint.FILTER_BITMAP_FLAG)); } public void init() { vWidth = getWidth() - getPaddingLeft() - getPaddingRight(); vHeight = getHeight() - getPaddingTop() - getPaddingBottom(); Drawable drawable = getDrawable(); BitmapDrawable bd = (BitmapDrawable) drawable; bd.setAntiAlias(isAntiAlias); } @Override public boolean onTouchEvent(MotionEvent event) { super.onTouchEvent(event); if (!isShowAnimation) return true; switch (event.getAction() & MotionEvent.ACTION_MASK) { case MotionEvent.ACTION_DOWN: float X = event.getX(); float Y = event.getY(); RolateX = vWidth / 2 - X; RolateY = vHeight / 2 - Y; XbigY = Math.abs(RolateX) > Math.abs(RolateY) ? true : false; isScale = X > vWidth / 3 && X < vWidth * 2 / 3 && Y > vHeight / 3 && Y < vHeight * 2 / 3; isActionMove = false; if (isScale) { if (isAnimationFinish && !isSizeChanged) { isSizeChanged = true; scale_handler.sendEmptyMessage(Scale_Handler_Message_Start); } } else { if (scaleOnly) { scale_handler.sendEmptyMessage(Scale_Handler_Message_Start); } else { rotate_Handler .sendEmptyMessage(Rotate_Handler_Message_Start); } } break; case MotionEvent.ACTION_MOVE: float x = event.getX(); float y = event.getY(); if (x > vWidth || y > vHeight || x < 0 || y < 0) { isActionMove = true; } else { isActionMove = false; } break; case MotionEvent.ACTION_UP: if (isScale) { if (isSizeChanged) scale_handler .sendEmptyMessage(Scale_Handler_Message_Reverse); } else { rotate_Handler.sendEmptyMessage(Rotate_Handler_Message_Reverse); } break; } return true; } public interface OnViewClick { public void onClick(); } @SuppressLint("HandlerLeak") private Handler rotate_Handler = new Handler() { private Matrix matrix = new Matrix(); private float count = 0; // private boolean clickGuolv = false; @Override public void handleMessage(Message msg) { super.handleMessage(msg); matrix.set(getImageMatrix()); switch (msg.what) { case Rotate_Handler_Message_Start: count = 0; beginRotate(matrix, (XbigY ? count : 0), (XbigY ? 0 : count)); rotate_Handler.sendEmptyMessage(Rotate_Handler_Message_Turning); break; case Rotate_Handler_Message_Turning: beginRotate(matrix, (XbigY ? count : 0), (XbigY ? 0 : count)); count++; if (count < getDegree()) { rotate_Handler .sendEmptyMessage(Rotate_Handler_Message_Turning); } else { isAnimationFinish = true; } break; case Rotate_Handler_Message_Turned: beginRotate(matrix, (XbigY ? count : 0), (XbigY ? 0 : count)); if (count > 0) { rotate_Handler .sendEmptyMessage(Rotate_Handler_Message_Turned); } else { isAnimationFinish = true; if (!isActionMove && onclick != null) { onclick.onClick(); } } count--; count--; break; case Rotate_Handler_Message_Reverse: count = getDegree(); beginRotate(matrix, (XbigY ? count : 0), (XbigY ? 0 : count)); rotate_Handler.sendEmptyMessage(Rotate_Handler_Message_Turned); break; } } }; private synchronized void beginRotate(Matrix matrix, float rotateX, float rotateY) { // Bitmap bm = getImageBitmap(); int scaleX = (int) (vWidth * 0.5f); int scaleY = (int) (vHeight * 0.5f); camera.save(); camera.rotateX(RolateY > 0 ? rotateY : -rotateY); camera.rotateY(RolateX < 0 ? rotateX : -rotateX); camera.getMatrix(matrix); camera.restore(); // 控制中心点 if (RolateX > 0 && rotateX != 0) { matrix.preTranslate(-vWidth, -scaleY); matrix.postTranslate(vWidth, scaleY); } else if (RolateY > 0 && rotateY != 0) { matrix.preTranslate(-scaleX, -vHeight); matrix.postTranslate(scaleX, vHeight); } else if (RolateX < 0 && rotateX != 0) { matrix.preTranslate(-0, -scaleY); matrix.postTranslate(0, scaleY); } else if (RolateY < 0 && rotateY != 0) { matrix.preTranslate(-scaleX, -0); matrix.postTranslate(scaleX, 0); } setImageMatrix(matrix); } private Handler scale_handler = new Handler() { private Matrix matrix = new Matrix(); private float s; int count = 0; @Override public void handleMessage(Message msg) { super.handleMessage(msg); matrix.set(getImageMatrix()); switch (msg.what) { case Scale_Handler_Message_Start: if (!isAnimationFinish) { return; } else { isAnimationFinish = false; isSizeChanged = true; count = 0; s = (float) Math.sqrt(Math.sqrt(minScale)); beginScale(matrix, s); scale_handler .sendEmptyMessage(Scale_Handler_Message_Turning); } break; case Scale_Handler_Message_Turning: beginScale(matrix, s); if (count < 4) { scale_handler .sendEmptyMessage(Scale_Handler_Message_Turning); } else { isAnimationFinish = true; if (!isSizeChanged && !isActionMove && onclick != null) { onclick.onClick(); } } count++; break; case Scale_Handler_Message_Reverse: if (!isAnimationFinish) { scale_handler .sendEmptyMessage(Scale_Handler_Message_Reverse); } else { isAnimationFinish = false; count = 0; s = (float) Math.sqrt(Math.sqrt(1.0f / minScale)); beginScale(matrix, s); scale_handler .sendEmptyMessage(Scale_Handler_Message_Turning); isSizeChanged = false; } break; } } }; private synchronized void beginScale(Matrix matrix, float scale) { int scaleX = (int) (vWidth * 0.5f); int scaleY = (int) (vHeight * 0.5f); matrix.postScale(scale, scale, scaleX, scaleY); setImageMatrix(matrix); } public int getDegree() { return rotateDegree; } public void setDegree(int degree) { rotateDegree = degree; } public float getScale() { return minScale; } public void setScale(float scale) { minScale = scale; } }

2、下来,来看看布局

<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns:tools="http://schemas.android.com/tools" android:layout_width="match_parent" android:layout_height="match_parent" android:background="@drawable/d" android:orientation="vertical" tools:context=".MainActivity" > <LinearLayout android:layout_width="wrap_content" android:layout_height="wrap_content" android:orientation="horizontal" > <com.example.win8test.MyImageView android:id="@+id/MyImageView01" android:layout_width="108dp" android:layout_height="108dp" android:layout_margin="16dp" android:scaleType="matrix" android:src="@drawable/fen" /> <com.example.win8test.MyImageView android:id="@+id/MyImageView02" android:layout_width="108dp" android:layout_height="108dp" android:layout_margin="16dp" android:scaleType="matrix" android:src="@drawable/fen" /> </LinearLayout> <LinearLayout android:layout_width="wrap_content" android:layout_height="wrap_content" android:orientation="horizontal" > <com.example.win8test.MyImageView android:id="@+id/MyImageView03" android:layout_width="108dp" android:layout_height="108dp" android:layout_margin="16dp" android:scaleType="matrix" android:src="@drawable/fen" /> <com.example.win8test.MyImageView android:id="@+id/MyImageView04" android:layout_width="108dp" android:layout_height="108dp" android:layout_margin="16dp" android:scaleType="matrix" android:src="@drawable/fen" /> </LinearLayout> <LinearLayout android:layout_width="wrap_content" android:layout_height="wrap_content" android:orientation="horizontal" > <com.example.win8test.MyImageView android:id="@+id/MyImageView05" android:layout_width="108dp" android:layout_height="108dp" android:layout_margin="16dp" android:scaleType="matrix" android:src="@drawable/fen" /> <com.example.win8test.MyImageView android:id="@+id/MyImageView06" android:layout_width="108dp" android:layout_height="108dp" android:layout_margin="16dp" android:scaleType="matrix" android:src="@drawable/fen" /> </LinearLayout> </LinearLayout>

3、上面的图片按钮的用法,这里只给一张图片按钮添加了事件:

MyImageView image_3D_1 = (MyImageView)findViewById(R.id.MyImageView01); image_3D_1.setOnClickIntent(new MyImageView.OnViewClick() { @Override public void onClick() { Toast.makeText(MainActivity.this, "clicked", 100) .show(); } });

4、效果
手指按在中间是缩小,手指按在边上是有角度的卷动

手指一直按着的时候,被按下的那个图像变小,并且手指一直按着移动,此时其它图片按钮不响应

希望本文所述对大家学习Android软件编程有所帮助。

时间: 2024-07-29 16:05:51

Android仿Win8界面开发的相关文章

Android仿Win8界面开发_Android

本文将要模仿Win8界面的一个设计,一个一个的方块.方法很简单.这里自己把图片改改就可以成为自己想要的界面了. 1.首先来看看自定义的MyImageView: package com.example.win8test; import android.annotation.SuppressLint; import android.content.Context; import android.graphics.Camera; import android.graphics.Canvas; impo

Android WebView 应用界面开发教程_Android

WebView组件本身就是一个浏览器实现,Android5.0增强的WebView基于Chromium M37,直接支持WebRTC.WebAudio.WebGL.开发者可以直接在WebView中使用聚合(Polymer)和Material设计. 一.WebView浏览网页(加载线上URL) WebView提供了很多方法执行浏览器操作,常用方法如下: void goBack():后退 void goForward():前进. void goBackOrForward(int step):step

Android WebView 应用界面开发教程

WebView组件本身就是一个浏览器实现,Android5.0增强的WebView基于Chromium M37,直接支持WebRTC.WebAudio.WebGL.开发者可以直接在WebView中使用聚合(Polymer)和Material设计. 一.WebView浏览网页(加载线上URL) WebView提供了很多方法执行浏览器操作,常用方法如下: void goBack():后退 void goForward():前进. void goBackOrForward(int step):step

Android仿Win8的metro的UI界面(上)_Android

手机下载了一些APP,发现现在仿win8的主界面越来越多,在大家见惯了类GridView或者类Tab后,给人一种耳目一新的感觉.今天在eoe上偶然发现已经有人实现了这个功能的源码(地址:http://www.eoeandroid.com/forum.php?mod=viewthread&tid=327557),马上下载跑了一下,效果很炫,但是有些bug,比如点击速度特别快时图像会被放大,以及点击时会触发两次点击事件. 本例子基于eoe中这位大神的实现,做了一些简化,和bug的修复. 效果: 首先

Android仿Win8的metro的UI界面(上)

手机下载了一些APP,发现现在仿win8的主界面越来越多,在大家见惯了类GridView或者类Tab后,给人一种耳目一新的感觉.今天在eoe上偶然发现已经有人实现了这个功能的源码(地址:http://www.eoeandroid.com/forum.php?mod=viewthread&tid=327557),马上下载跑了一下,效果很炫,但是有些bug,比如点击速度特别快时图像会被放大,以及点击时会触发两次点击事件. 本例子基于eoe中这位大神的实现,做了一些简化,和bug的修复. 效果: 首先

Android miniTwitter登录界面开发实例

本文要演示的Android开发实例是如何完成一个Android中的miniTwitter登录界面,下面将分步骤讲解怎样实现图中的界面效果,让大家都能轻松的做出美观的登录界面. 先贴上最终要完成的效果图: miniTwitter登录界面的布局分析 首先由界面图分析布局,基本可以分为三个部分,下面分别讲解每个部分. 第一部分是一个带渐变色背景的LinearLayout布局,关于背景渐变色就不再贴代码了,效果如下图所示: 第二部分,红色线区域内,包括1,2,3,4 如图所示: 红色的1表示的是一个带圆

wp8开发仿win8磁贴界面以及功能源码实例

最近看见有人放win8的界面效果,搜了两款,一款是只是仿界面没有特效,另一款是自定义组件能够实现反转效果,今天分析一下这两类界面. 仿win8界面 win8磁贴类似九宫格效果,实现这种效果基本上有三种方式实现:LinearLayout,使用其属性layout_weight实现等分:TableLayout,做过计算器的人可能会用到过这个,也可以实现,还有一种就是GridView,自己实现适配器,我找到的仿win8界面使用LinearLayout来实现的,LinearLayout层层嵌套,这种方式不

Android仿微信主界面设计_Android

先来一张效果图 一.ActionBar的设计 首先是main.xml,先定义这些菜单,界面稍后在调整 <menu xmlns:android="http://schemas.android.com/apk/res/android" tools:context=".MainActivity"> <item android:id="@+id/action_search" android:actionViewClass="a

Android 仿Windows Metro 界面UI

布局采用LinearLayout来实现(比较喜欢这个布局,在UI之前要有全局考虑的思想,操作起来比较简单),每一个菜单都是一个Linear块,内部是一个ImageView和一个TextView:一共做了两个界面点击互相切换,下面是效果截图:            由于每个Linear块的属性配置都差不多很相似,所以提取出来做成了统一的style,在XML文件中引用则更方便一些   下面是UI设计的布局文件代码片段: <?xml version="1.0" encoding=&qu