当前位置:  编程技术>移动开发
本页文章导读:
    ▪【通译】(80)Renderscript之计算        【翻译】(80)Renderscript之计算 【翻译】(80)Renderscript之计算   see http://developer.android.com/guide/topics/renderscript/compute.html   原文见 http://developer.android.com/guide/topics/renderscript/compute.html   --------------.........
    ▪ unity3D打造skybox淡入淡出        unity3D制作skybox淡入淡出 首先建立个shader Shader "Custom/Skybox" { Properties { _Tint ("Tint Color", Color) = (.5, .5, .5, .5) _FrontTex ("Front (+Z)", 2D) = "white" {} _BackTex ("Back (-Z)", 2D) = "white" {} _LeftTex .........
    ▪ 反编译apk资料       反编译apk文件 Android拿来主义-反编译apk文件     前言   今天给大家分享一下Android中的拿来主义,我们时常会碰到自己觉得很有用的应用(apk),想同过此应用来学习,尝试用WinRAR等之类的工具.........

[1]【通译】(80)Renderscript之计算
    来源: 互联网  发布时间: 2014-02-18
【翻译】(80)Renderscript之计算

【翻译】(80)Renderscript之计算

 

see

http://developer.android.com/guide/topics/renderscript/compute.html

 

原文见

http://developer.android.com/guide/topics/renderscript/compute.html

 

-------------------------------

 

Compute

 

Renderscript之计算

 

-------------------------------

 

In this document

 

本文目录

 

* Creating a Compute Renderscript 创建一个计算Renderscript

* Creating the Renderscript file 创建Renderscript文件

* Calling the Renderscript code 调用Renderscript代码

 

Related Samples

 

相关示例

 

* Hello Compute 你好计算

* Balls 球

 

-------------------------------

 

Renderscript exposes a set of compute APIs that you can use to do intensive computational operations. You can use the compute APIs in the context of a graphics Renderscript such as calculating the positions of many objects in a scene. You can also create standalone compute Renderscripts such as one that does image processing for a photo editor application.

 

Renderscript暴露一组计算API,你可以使用它们来执行密集的计算型操作。你可以在一个图形Renderscript的上下文中使用计算API,诸如计算场景中许多对象的位置。你还可以创建独立的计算Renderscript,诸如用于相片编辑器应用程序的一个执行图片处理的Renderscript。

 

Compute Renderscripts scale to the amount of processing cores available on the device. This is enabled through a function named rsForEach() (or the forEach_root() method at the Android framework level). that automatically partitions work across available processing cores on the device. For now, compute Renderscripts can only take advantage of CPU cores, but in the future, they can potentially run on other types of processors such as GPUs and DSPs.

 

计算Renderscript伸缩至设备上可用的处理(注:这里的processing应该是指处理器,下同)核心个数。这通过一个名为rsForEach()的函数被使能(或者在Android框架层上的forEach_root()方法)。它自动地划分工作,跨越设备上的可用处理核心。目前,计算Renderscript只可以利用CPU核心,但在未来,它们可以隐式地运行在其它类型的处理器上,诸如GPU和DSP。

 

-------------------------------

 

Creating a Compute Renderscript

 

创建一个计算Renderscript

 

Implementing a compute Renderscript creating a .rs file that contains your Renderscript code and calling it at the Android framework level with the forEach_root() or at the Renderscript runtime level with the rsForEach() function. The following diagram describes how a typical compute Renderscript is set up:

 

实现一个计算Renderscript,通过创建一个包含你的Renderscript代码的.rs文件,并在Android框架层上用forEach_root()或在Renderscript运行时层上用rsForEach()函数调用它。以下图表描述一个典型的计算Renderscript是如何被配置的:

 

-------------------------------

 

(图略:

1. Android框架(左图)

 

(“Android框架”包含)活动

 

(“活动”包含)Renderscript上下文

 

--o

 

(“活动”包含)Renderscript对象

 

--o(连接至“计算Renderscript”)

 

2. Renderscript运行时(右图)

(“Renderscript运行时”包含)计算Renderscript(.rs)

 

-->

 

(“Renderscript运行时”包含)Renderscript计算引擎

 

Figure 1. Compute Renderscript overview

 

图1. 计算Renderscript概览

 

-------------------------------

 

The following sections describe how to create a simple compute Renderscript and use it in an Android application. This example uses the HelloCompute Renderscript sample that is provided in the SDK as a guide (some code has been modified from its original form for simplicity).

 

以下章节描述如何创建一个简单的计算Renderscript并在一个Android应用程序中使用它。这个示例使用SDK中的HelloCompute的Renderscript示例作为一个指引(简单起见,一些代码已经被修改自它原来的形式)。

 

Creating the Renderscript file

 

创建Renderscript文件

 

Your Renderscript code resides in .rs and .rsh files in the <project_root>/src/ directory. This code contains the compute logic and declares all necessary variables and pointers. Every compute .rs file generally contains the following items:

 

你的Renderscript代码寄居在<project_root>/src/目录下的.rs和.rsh文件中。这个代码包含计算逻辑并声明所有必需的变量和指针。每个计算.rs文件通常包含以下条目:

 

* A pragma declaration (#pragma rs java_package_name(package.name)) that declares the package name of the .java reflection of this Renderscript.

 

* 一个pragma声明(#pragma rs java_package_name(package.name)),它声明这个Renderscript的.java反射的包名。

 

* A pragma declaration (#pragma version(1)) that declares the version of Renderscript that you are using (1 is the only value for now).

 

* 一个pragma声明(#pragma version(1)),它声明你正在使用的Renderscript的版本(目前1是唯一的值)。

 

* A root() function that is the main worker function. The root function is called by the rsForEach function, which allows the Renderscript code to be called and executed on multiple cores if they are available. The root() function must return void and accept the following arguments:

 

* 一个root()函数,它是主工作者函数。root函数被rsForEach函数调用,它允许Renderscript代码被调用和执行在多核上,如果它们是可用的。root()函数必须返回void和接受以下参数:

 

* Pointers to memory allocations that are used for the input and output of the compute Renderscript. Both of these pointers are required for Android 3.2 (API level 13) platform versions or older. Android 4.0 (API level 14) and later requires one or both of these allocations.

 

* 指向内存分配的指针,它被用于计算Renderscript的输入和输出。这两种指针都是必需的,对于Android 3.2(API级别13)平台版本或更旧来说。Android 4.0(API级别14)和更晚需要这些分配中的一个或两个。

 

The following arguments are optional, but both must be supplied if you choose to use them:

 

以下参数是可选的,但必须同时提供两者如果你选择使用它们:

 

* A pointer for user-defined data that the Renderscript might need to carry out computations in addition to the necessary allocations. This can be a pointer to a simple primitive or a more complex struct.

 

* 一个用户定义数据的指针,Renderscript可能需要它来履行计算,除了必需的分配外。这可能是一个指向简单原始(注:原始类型)值或一个更复杂的结构体的指针。

 

* The size of the user-defined data.

 

* 用户定义数据的大小。

 

* An optional init() function. This allows you to do any initialization before the root() function runs, such as initializing variables. This function runs once and is called automatically when the Renderscript starts, before anything else in your Renderscript.

 

* 一个可选的init()函数。它允许你在root()函数运行前执行任意初始化,诸如初始化变量。这个函数运行一次,并且在Renderscript开始时自动地被调用,在你的Renderscript中其它任意事情发生之前。

 

* Any variables, pointers, and structures that you wish to use in your Renderscript code (can be declared in .rsh files if desired)

 

* 你希望在你的Renderscript代码中使用的任意变量、指针和结构体(可以被声明在.rsh文件中,如果这是你所期望的)

 

The following code shows how the mono.rs file is implemented:

 

以下代码展示mono.rs文件是如何被实现的:

 

-------------------------------

 

#pragma version(1)

#pragma rs java_package_name(com.example.android.rs.hellocompute)

 

//multipliers to convert a RGB colors to black and white

//转换一个RGB颜色为黑色和白色的乘数

const static float3 gMonoMult = {0.299f, 0.587f, 0.114f};

 

void root(const uchar4 *v_in, uchar4 *v_out) {

  //unpack a color to a float4

  //解压一个颜色至一个float4

  float4 f4 = rsUnpackColor8888(*v_in);

  //take the dot product of the color and the multiplier

  //取颜色和乘数的点积

  float3 mono = dot(f4.rgb, gMonoMult);

  //repack the float to a color

  //重新打包浮点到一个颜色

  *v_out = rsPackColorTo8888(mono);

}

 

-------------------------------

 

Calling the Renderscript code

 

调用Renderscript代码

 

You can do Renderscript to Renderscript calls with rsForEach in situations such as when a graphics Renderscript needs to do a lot of computational operations. The Renderscript Balls sample shows how this is setup. The balls.rs graphics Renderscript calls the balls_physics.rs compute Renderscript to calculate the location of the balls that are rendered to the screen.

 

你可以使用rsForEach执行Renderscript到Renderscript调用,在这些情况下诸如当一个图形Renderscript需要做许多计算型的操作。Renderscript球示例展示它是如何被配置的。balls.rs图形Renderscript调用balls_physics.rs计算Renderscript以计算被渲染到屏幕的球的位置。

 

Another way to use a compute Renderscript is to call it from your Android framework code by creating a Renderscript object by instantiating the (ScriptC_script_name) class. This class contains a method, forEach_root(), that lets you invoke rsForEach. You give it the same parameters that you would if you were invoking it at the Renderscript runtime level. This technique allows your Android application to offload intensive mathematical calculations to Renderscript. See the HelloCompute sample to see how a simple Android application can utilize a compute Renderscript.

 

使用一个计算Renderscript的另一种方式是通过由实例化(ScriptC_script_name)类创建的一个Renderscript对象,从你的Android框架代码中调用它。这个类包含一个方法,forEach_root(),它让你调用rsForEach。你给予它和你会在Renderscript运行时层上调用它的情况下给予的相同参数。这项技术允许你的Android应用程序把密集的数学计算托付(注:卸货)给Renderscript。参见HelloCompute以知道一个简单的应用程序可以如何利用一个计算Renderscript。

 

To call a compute Renderscript at the Android framework level:

 

为了在Android框架层上调用一个计算Renderscript:

 

1. Allocate memory that is needed by the compute Renderscript in your Android framework code. You need an input and output Allocation for Android 3.2 (API level 13) platform versions and older. The Android 4.0 (API level 14) platform version requires only one or both Allocations.

 

1. 在你的Android框架代码中计算Renderscript需要的分配内存。对于Android 3.2(API级别13)平台和更旧,你需要一个输入和输出Allocation。Android 4.0(API级别14)平台版本只需要一个或两个Allocation。

 

2. Create an instance of the ScriptC_script_name class.

 

2. 创建ScriptC_script_name类的一个实例。

 

3. Call forEach_root(), passing in the allocations, the Renderscript, and any optional user-defined data. The output allocation will contain the output of the compute Renderscript.

 

3. 调用forEach_root(),传递进分配,Renderscript,以及任意可选的用户定义数据。输出分配将包含计算Renderscript的输出。

 

In the following example, taken from the HelloCompute sample, processes a bitmap and outputs a black and white version of it. The createScript() method carries out the steps described previously. This method the compute Renderscript, mono.rs, passing in memory allocations that store the bitmap to be processed as well as the eventual output bitmap. It then displays the processed bitmap onto the screen:

 

在以下取自HelloCompute示例的例子中,处理一个位图并输出它的一个黑色和白色版本。createScript()方法履行前面描述的步骤。这个方法,计算Renderscript mono.rs传递进要被处理的存储位图的内存分配以及最终的输出位图。然后它显示被处理的位图到屏幕上:

 

-------------------------------

 

package com.example.android.rs.hellocompute;

 

import android.app.Activity;

import android.os.Bundle;

import android.graphics.BitmapFactory;

import android.graphics.Bitmap;

import android.renderscript.RenderScript;

import android.renderscript.Allocation;

import android.widget.ImageView;

 

public class HelloCompute extends Activity {

  private Bitmap mBitmapIn;

  private Bitmap mBitmapOut;

 

  private RenderScript mRS;

  private Allocation mInAllocation;

  private Allocation mOutAllocation;

  private ScriptC_mono mScript;

 

  @Override

  protected void onCreate(Bundle savedInstanceState) {

      super.onCreate(savedInstanceState);

      setContentView(R.layout.main);

 

      mBitmapIn = loadBitmap(R.drawable.data);

      mBitmapOut = Bitmap.createBitmap(mBitmapIn.getWidth(), mBitmapIn.getHeight(),

                                       mBitmapIn.getConfig());

 

      ImageView in = (ImageView) findViewById(R.id.displayin);

      in.setImageBitmap(mBitmapIn);

 

      ImageView out = (ImageView) findViewById(R.id.displayout);

      out.setImageBitmap(mBitmapOut);

 

      createScript();

  }

  private void createScript() {

      mRS = RenderScript.create(this);

      mInAllocation = Allocation.createFromBitmap(mRS, mBitmapIn,

          Allocation.MipmapControl.MIPMAP_NONE,

          Allocation.USAGE_SCRIPT);

      mOutAllocation = Allocation.createTyped(mRS, mInAllocation.getType());

      mScript = new ScriptC_mono(mRS, getResources(), R.raw.mono);

      mScript.forEach_root(mInAllocation, mOutAllocation);

      mOutAllocation.copyTo(mBitmapOut);

  }

 

  private Bitmap loadBitmap(int resource) {

      final BitmapFactory.Options options = new BitmapFactory.Options();

      options.inPreferredConfig = Bitmap.Config.ARGB_8888;

      return BitmapFactory.decodeResource(getResources(), resource, options);

  }

}

 

-------------------------------

 

To call a compute Renderscript from another Renderscript file:

 

为了从另一个Renderscript文件中调用一个计算Renderscript:

 

1. Allocate memory that is needed by the compute Renderscript in your Android framework code. You need an input and output Allocation for Android 3.2 (API level 13) platform versions and older. The Android 4.0 (API level 14) platform version requires only one or both Allocations.

 

1. 在你的Android框架代码中计算Renderscript所需的分配内存。对于Android 3.2(API级别13)平台版本和更旧,你需要一个输入和输出分配。Android 4.0(API级别14)平台版本只需要一个或两个Allocation。

 

2. Call rsForEach(), passing in the allocations and any optional user-defined data. The output allocation will contain the output of the compute Renderscript.

 

2. 调用rsForEach(),传递进分配和任意可选的用户定义数据。输出分配将包含计算Renderscript的输出。

 

The following example, taken from the Renderscript Balls sample, demonstrates how to do make a script to script call:

 

以下示例,取自Renderscript的球示例,演示如何制造一个脚本到脚本的调用:

 

-------------------------------

 

rs_script script;

rs_allocation in_allocation;

rs_allocation out_allocation;

UserData_t data;

...

rsForEach(script, in_allocation, out_allocation, &data, sizeof(data));

 

-------------------------------

 

In this example, assume that the script and memory allocations have already been allocated and bound at the Android framework level and that UserData_t is a struct declared previously. Passing a pointer to a struct and the size of the struct to rsForEach is optional, but useful if your compute Renderscript requires additional information other than the necessary memory allocations.

 

在这个示例中,假设脚本和内存分配已经被分配和在Android框架层上绑定,而UserData_t是之前声明的一个struct。传递一个指向一个struct的指针和struct的大小给rsForEach是可选的,但它是有用的如果你的计算Renderscript需要额外的信息而非必需的内存分配。

 

Except as noted, this content is licensed under Apache 2.0. For details and restrictions, see the Content License.

 

除特别说明外,本文在Apache 2.0下许可。细节和限制请参考内容许可证。

 

Android 4.0 r1 - 02 Apr 2012 19:36

 

-------------------------------

 

Portions of this page are modifications based on work created and shared by the Android Open Source Project and used according to terms described in the Creative Commons 2.5 Attribution License.

 

此页部分内容,是基于Android开源项目所创建和共享的工作,并且根据知识共享2.5署名许可证描述的条款来使用的修改版。

 

(本人翻译质量欠佳,请以官方最新内容为准,或者参考其它翻译版本:

* ソフトウェア技術ドキュメントを勝手に翻訳

http://www.techdoctranslator.com/android

* Ley's Blog

http://leybreeze.com/blog/

* 农民伯伯

http://www.cnblogs.com/over140/

* Android中文翻译组

http://androidbox.sinaapp.com/

 


    
[2] unity3D打造skybox淡入淡出
    来源: 互联网  发布时间: 2014-02-18
unity3D制作skybox淡入淡出
首先建立个shader
Shader "Custom/Skybox" {

Properties {
    _Tint ("Tint Color", Color) = (.5, .5, .5, .5)
    _FrontTex ("Front (+Z)", 2D) = "white" {}
    _BackTex ("Back (-Z)", 2D) = "white" {}
    _LeftTex ("Left (+X)", 2D) = "white" {}
    _RightTex ("Right (-X)", 2D) = "white" {}
    _UpTex ("Up (+Y)", 2D) = "white" {}
    _DownTex ("Down (-Y)", 2D) = "white" {}
    _FrontTex2("2 Front (+Z)", 2D) = "white" {}
    _BackTex2("2 Back (-Z)", 2D) = "white" {}
    _LeftTex2("2 Left (+X)", 2D) = "white" {}
    _RightTex2("2 Right (-X)", 2D) = "white" {}
    _UpTex2("2 Up (+Y)", 2D) = "white" {}
    _DownTex2("2 Down (-Y)", 2D) = "white" {}
    _Color ("Fade (use alpha)", Color) = (1,1,1,1)
}

SubShader {
    Tags { "Queue" = "Background" }
    Cull Off
    ZWrite On
    ZTest Always
    Fog { Mode Off }
    Lighting Off       
    Color [_Tint]
    Pass {
        SetTexture [_FrontTex] { combine texture }
        SetTexture[_FrontTex2] { 
            constantColor [_Color]
            combine texture lerp (constant) previous
        }
    }
    Pass {
        SetTexture [_BackTex] { combine texture }
        SetTexture[_BackTex2] { 
            constantColor [_Color]
            combine texture lerp (constant) previous
        }
    }
    Pass {
        SetTexture [_LeftTex] { combine texture }
        SetTexture[_LeftTex2] { 
            constantColor [_Color]
            combine texture lerp (constant) previous
        }
    }
    Pass {
        SetTexture [_RightTex] { combine texture }
        SetTexture[_RightTex2] { 
            constantColor [_Color]
            combine texture lerp (constant) previous
        }
    }
    Pass {
        SetTexture [_UpTex] { combine texture }
        SetTexture[_UpTex2] { 
            constantColor [_Color]
            combine texture lerp (constant) previous
        }
    }
    Pass {
        SetTexture [_DownTex] { combine texture }
        SetTexture[_DownTex2] { 
            constantColor [_Color]
            combine texture lerp (constant) previous
        }
    }
}

Fallback "RenderFX/Skybox", 1
}

材质间的动画转换
private var thisMaterial : Material;
private var fadeSpeed : float = 0.4;

function Start (){
    thisMaterial = RenderSettings.skybox;
    thisMaterial.color.a = 0.0;
}

function Update () {
    thisMaterial.color.a += (fadeSpeed * Time.deltaTime); 
    thisMaterial.color.a = Mathf.Clamp(thisMaterial.color.a, 0.0, 1.0);
}

skybox的纹理褪色,渐渐的转变。
public var blackTexture : Texture2D;

function Start (){
    thisMaterial = RenderSettings.skybox;
    thisMaterial.color.a = 0.0;

    thisMaterial.SetTexture("_FrontTex", blackTexture);
    thisMaterial.SetTexture("_BackTex", blackTexture);
    thisMaterial.SetTexture("_LeftTex", blackTexture);
    thisMaterial.SetTexture("_RightTex", blackTexture);
    thisMaterial.SetTexture("_UpTex", blackTexture);
    thisMaterial.SetTexture("_DownTex", blackTexture);
}
function Update () {
    thisMaterial.color.a += (fadeSpeed * Time.deltaTime); 
    thisMaterial.color.a = Mathf.Clamp(thisMaterial.color.a, 0.0, 1.0);
}

设置纹理等
thisMaterial.SetTexture("_FrontTex2", textureVariable);

    
[3] 反编译apk资料
    来源: 互联网  发布时间: 2014-02-18
反编译apk文件

Android拿来主义-反编译apk文件

 

 

前言

 

今天给大家分享一下Android中的拿来主义,我们时常会碰到自己觉得很有用的应用(apk),想同过此应用来学习,尝试用WinRAR等之类的工具查看,目录通常是这样的,如下图:

 

 

 

当然res里面的图片是可以拿来用的,但是layout里面的布局及权限文件(AndroidMainfest.xml)却是一堆乱码,完全看不懂,想看看别人的布局都不容易。还有源代码也被编译成classes.dex,完全看不出什么线索。基于以上困惑,给大家分享一下Android中的拿来主义。
一、所需的工具
1 下载dex2jar最新版本,下载地址http://code.google.com/p/dex2jar/downloads/list
2 下载class反编译工具,我用的是jad,大家可以根据自己情况选择(可以用jd-gui直接打开classes.dex经过反编译后生成的.jar文件-下载地址http://www.cr173.com/soft/22741.html)
3 下载 AXMLPrinter2.jar 用来查看布局文件

二、开始拿来主义


1、
用AXMLPrinter2.jar查看apl中的布局文件:
为了方便起见,将所下载的相关工具放在 D:\Android 中。将你找到的应用程序的apk用WinRAR等工具打开,将res/layout/main.xml解压出来(也放到D:\Android)
打开main.xml文件,内容如下(一堆天文):

这时候AXMLPrinter2.jar 派上用场,打开cmd终端,进入d:\Android目录下,输入如下命令:java -jar AXMLPrinter2.jar main.xml > main.txt (如下图所示)


 

代开main.text开别人的代码吧!!

1、
用 dex2jar 中的 dex2jar.bat生成jar文件
在cmd下进入dex2jar.bat所在路径,然后输入“dex2jar.bat  XXX”,XXX指的是你要反编译的apk中的classes.dex文件所在路径及名称,比如:我的dex2jar.bat在D:\Android\apk_decode\dex2jar-0.0.7-SNAPSHOT路径下, classes.dex在D:\Android
下,输入命令:dex2jar.bat D:\Android\classes.dex
此时在D:\Android目录下会生成一个JAR文件。

2、
用jad工具将.class文件反编译成.java文件

将上面生成的jar文件解压出来,会看到相关的.class文件,这是用jad 将.class文件反编译成.java文件 输入命令:jad example.class
(examples.class是文件解压出来的文件)

注:摘自http://dev.10086.cn/cmdn/bbs/viewthread.php?tid=21765


    
最新技术文章:
▪Android开发之登录验证实例教程
▪Android开发之注册登录方法示例
▪Android获取手机SIM卡运营商信息的方法
▪Android实现将已发送的短信写入短信数据库的...
▪Android发送短信功能代码
▪Android根据电话号码获得联系人头像实例代码
▪Android中GPS定位的用法实例
▪Android实现退出时关闭所有Activity的方法
▪Android实现文件的分割和组装
▪Android录音应用实例教程
▪Android双击返回键退出程序的实现方法
▪Android实现侦听电池状态显示、电量及充电动...
▪Android获取当前已连接的wifi信号强度的方法
▪Android实现动态显示或隐藏密码输入框的内容
▪根据USER-AGENT判断手机类型并跳转到相应的app...
▪Android Touch事件分发过程详解
▪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