当前位置:  编程技术>移动开发
本页文章导读:
    ▪Flex搬动开发第一次分享        Flex移动开发第一次分享 ppt主要内容:       •Spark Skin •Mobile Skin •Container Layout •Performance ......
    ▪ Matrix学习——怎么使用Matrix        Matrix学习——如何使用Matrix 以前在线性代数中学习了矩阵,对矩阵的基本运算有一些了解,前段时间在使用GDI+的时候再次学习如何使用矩阵来变化图像,看了之后在这里总结说明。 首先大.........
    ▪ 手机运用瘦身方案       手机应用瘦身方案 1.把系统用的声音文件统一改.ogg音乐格式(特点:此格式压缩比高,是有损压缩中较好的,android 也支持) 2.符合下列条件图片,改用 xml bitmap   a.整个图片都是重复的小块   .........

[1]Flex搬动开发第一次分享
    来源: 互联网  发布时间: 2014-02-18
Flex移动开发第一次分享

ppt主要内容:

 

 

 

•Spark Skin
•Mobile Skin
•Container Layout
•Performance

    
[2] Matrix学习——怎么使用Matrix
    来源: 互联网  发布时间: 2014-02-18
Matrix学习——如何使用Matrix

以前在线性代数中学习了矩阵,对矩阵的基本运算有一些了解,前段时间在使用GDI+的时候再次学习如何使用矩阵来变化图像,看了之后在这里总结说明。

首先大家看看下面这个3 x 3的矩阵,这个矩阵被分割成4部分。为什么分割成4部分,在后面详细说明。

首先给大家举个简单的例子:现设点P0(x0, y0)进行平移后,移到P(x,y),其中x方向的平移量为△x,y方向的平移量为△y,那么,点P(x,y)的坐标为:

x = x0  + △x
y = y0  + △y

采用矩阵表达上述如下:

上述也类似与图像的平移,通过上述矩阵我们发现,只需要修改矩阵右上角的2个元素就可以了。

我们回头看上述矩阵的划分:

为了验证上面的功能划分,我们举个具体的例子:现设点P0(x0 ,y0)进行平移后,移到P(x,y),其中x放大a倍,y放大b倍,

矩阵就是:,按照类似前面“平移”的方法就验证。

图像的旋转稍微复杂:现设点P0(x0, y0)旋转θ角后的对有点为P(x, y)。通过使用向量,我们得到如下:

x0 = r  cosα
y0 = r  sinα

x = r cos(α-θ) = x0 cosθ+ y0 sinθ
y = r sia(α-θ) = -x0 sinθ+y0 cosθ

于是我们得到矩阵:

如果图像围绕着某个点(a ,b)旋转呢?则先要将坐标平移到该点,再进行旋转,然后将旋转后的图像平移回到原来的坐标原点,在后面的篇幅中我们将详细介绍。

Matrix学习——如何使用Matrix

上一篇幅  Matrix学习——基础知识,从高等数学方面给大家介绍了Matrix,本篇幅我们就结合Android 中的android.graphics.Matrix来具体说明,还记得我们前面说的图像旋转的矩阵:

从最简单的旋转90度的是:

在android.graphics.Matrix中有对应旋转的函数:
Matrix matrix = new Matrix();
matrix.setRotate(90);
Test.Log(MAXTRIX_TAG,”setRotate(90):%s” , matrix.toString());

查看运行后的矩阵的值(通过Log输出):

与上面的公式基本完全一样(android.graphics.Matrix采用的是浮点数,而我们采用的整数)。

有了上面的例子,相信大家就可以亲自尝试了。通过上面的例子我们也发现,我们也可以直接来初始化矩阵,比如说要旋转30度:

前面给大家介绍了这么多,下面我们开始介绍图像的镜像,分为2种:水平镜像、垂直镜像。先介绍如何实现垂直镜像,什么是垂直镜像就不详细说明。图像的垂直镜像变化也可以用矩阵变化的表示,设点P0(x0 ,y0 )进行镜像后的对应点为P(x ,y ),图像的高度为fHeight,宽度为fWidth,原图像中的P0(x0 ,y0 )经过垂直镜像后的坐标变为(x0 ,fHeight- y0);
x = x0
y = fHeight – y0
推导出相应的矩阵是:

final float f[] = {1.0F,0.0F,0.0F,0.0F,-1.0F,120.0F,0.0F,0.0F,1.0F};
Matrix matrix = new Matrix();
matrix.setValues(f);

按照上述方法运行后的结果:

至于水平镜像采用类似的方法,大家可以自己去试试吧。

实际上,使用下面的方式也可以实现垂直镜像:
Matrix matrix = new Matrix();
matrix.setScale (1.0,-1.0);
matrix.postTraslate(0, fHeight);

Matrix学习——对称变换(反射)

什么是对称变换?具体的理论就不详细说明了,图像的镜像就是对称变换中的一种。

利用上面的总结做个具体的例子,产生与直线y= – x对称的反射图形,代码片段如下:

当前矩阵输出是:

图像变换的效果如下:

Matrix学习——错切变换

什么是图像的错切变换(Shear transformation)?我们还是直接看图片错切变换后是的效果:

对图像的错切变换做个总结:

x = x0 + b*y0;

y = d*x0 + y0;

这里再次给大家介绍一个需要注意的地方:

通过以上,我们发现Matrix的setXXXX()函数,在调用时调用了一次reset(),这个在复合变换时需要注意。

Matrix学习——图像的复合变化

Matrix学习——基础知识篇幅中,我们留下一个话题:如果图像围绕着某个点P(a,b)旋转,则先要将坐标系平移到该点,再进行旋转,然后将旋转后的图像平移回到原来的坐标原点。

我们需要3步:

  • 平移——将坐标系平移到点P(a,b);
  • 旋转——以原点为中心旋转图像;
  • 平移——将旋转后的图像平移回到原来的坐标原点;
  • 相比较前面说的图像的几何变化(基本的图像几何变化),这里需要平移——旋转——平移,这种需要多种图像的几何变化就叫做图像的复合变化。

    设对给定的图像依次进行了基本变化F1、F2、F3…..、Fn,它们的变化矩阵分别为T1、T2、T3…..、Tn,图像复合变化的矩阵T可以表示为:T = TnTn-1…T1。

    按照上面的原则,围绕着某个点(a,b)旋转θ的变化矩阵序列是:

    按照上面的公式,我们列举一个简单的例子:围绕(100,100)旋转30度(sin 30 = 0.5 ,cos 30 = 0.866)
    float f[]= { 0.866F,  -0.5F, 63.4F,0.5F, 0.866F,-36.6F,0.0F,    0.0F,  1.0F };
    matrix = new Matrix();
    matrix.setValues(f);
    旋转后的图像如下:

    Android为我们提供了更加简单的方法,如下:
    Matrix matrix = new Matrix();
    matrix.setRotate(30,100,100);
    矩阵运行后的实际结果:

    与我们前面通过公式获取得到的矩阵完全一样。

    在这里我们提供另外一种方法,也可以达到同样的效果:
    float a = 100.0F,b = 100.0F;
    matrix = new Matrix();
    matrix.setTranslate(a,b);
    matrix.preRotate(30);
    matrix.preTranslate(-a,-b);
    将在后面的篇幅中为大家详细解析

    通过类似的方法,我们还可以得到:相对点P(a,b)的比例[sx,sy]变化矩阵

    来自:http://www.moandroid.com/?p=1781


        
    [3] 手机运用瘦身方案
        来源: 互联网  发布时间: 2014-02-18
    手机应用瘦身方案

    1.把系统用的声音文件统一改.ogg音乐格式(特点:此格式压缩比高,是有损压缩中较好的,android 也支持)

    2.符合下列条件图片,改用 xml bitmap
      a.整个图片都是重复的小块
      <?xml version="1.0" encoding="utf-8"?>

    <bitmap
            xmlns:android="http://schemas.android.com/apk/res/android"
            android:src="/blog_article/@drawable/x_bg/index.html"
            android:tileMode="repeat"
            android:dither="false"/>
    3.按钮背景相同,但文字不同,可以在切图时,只切背景,文字在代码填充,

    4.把一些不变状态的图片切图,合成在一张图片中(类似CSS中的技术),使用时,在代码中使用
           Bitmap resource = BitmapFactory.decodeResource(this.getResources(), R.drawable.num);  
             Bitmap zero = Bitmap.createBitmap(resource, 0, 0, 12, 12);
    5.使用无损压缩软件(PNGGauntlet)把最大的图片压缩下,效果视特定情况下使用。
    相关链接
    http://bbs.duba.net/thread-22664727-1-1.html


        
    最新技术文章:
    ▪Android开发之登录验证实例教程
    ▪Android开发之注册登录方法示例
    ▪Android获取手机SIM卡运营商信息的方法
    ▪Android实现将已发送的短信写入短信数据库的...
    ▪Android发送短信功能代码
    ▪Android根据电话号码获得联系人头像实例代码
    ▪Android中GPS定位的用法实例
    ▪Android实现退出时关闭所有Activity的方法
    ▪Android实现文件的分割和组装
    ▪Android录音应用实例教程
    ▪Android双击返回键退出程序的实现方法
    ▪Android实现侦听电池状态显示、电量及充电动...
    ▪Android获取当前已连接的wifi信号强度的方法
    ▪Android实现动态显示或隐藏密码输入框的内容
    ▪根据USER-AGENT判断手机类型并跳转到相应的app...
    WEB前端 iis7站长之家
    ▪Android中实现为TextView添加多个可点击的文本
    ▪Android程序设计之AIDL实例详解
    ▪Android显式启动与隐式启动Activity的区别介绍
    ▪Android按钮单击事件的四种常用写法总结
    ▪Android消息处理机制Looper和Handler详解
    ▪Android实现Back功能代码片段总结
    ▪Android实用的代码片段 常用代码总结
    ▪Android实现弹出键盘的方法
    ▪Android中通过view方式获取当前Activity的屏幕截...
    ▪Android提高之自定义Menu(TabMenu)实现方法
    ▪Android提高之多方向抽屉实现方法
    ▪Android提高之MediaPlayer播放网络音频的实现方法...
    ▪Android提高之MediaPlayer播放网络视频的实现方法...
    ▪Android提高之手游转电视游戏的模拟操控
     


    站内导航:


    特别声明:169IT网站部分信息来自互联网,如果侵犯您的权利,请及时告知,本站将立即删除!

    ©2012-2021,,E-mail:www_#163.com(请将#改为@)

    浙ICP备11055608号-3