Unity安装Android SDK

在使用Unity打包apk时,有时会期望设置Android API level

Unity的默认设置是使用安装的最高版本,例如Unity2019安装的是Android 29

如果期望使用别的SDK打包会出现提示

Unity提示使用SDK Manager安装自己需要的版本

在External Tools中找到SDK安装的目录,在Unity的安装目录中找到”Editor\Data\PlaybackEngines\AndroidPlayer\SDK\tools\bin”文件夹,sdkmanager.bat就是我们要找的SDK Manager

在该目录运行命令行工具,例如sdkmanager –help

执行安装:

1sdkmanager platforms;android-28

 安装完成重启Unity就可以选择新的API打包

FunPlus特效专家张韶勇:如何利用跨平台工具快速制作像素动画?(转)

有些用于主机端的特效工具和插件可以和手游工具相结合,从而提高手游特效品质和制作效率。

FunPlus首席特效专家张韶勇对此感受颇深。他拥有16年特效工作经验,此前在海外做主机游戏的特效,回国后曾在网易阿里等公司负责手游的特效,目前加入了FunPlus,负责美术特效的工作。

在今年的北京国际游戏创新大会(BIGC)上,张韶勇分享了他对游戏特效技巧-像素动画制作的心得。不仅从美术角度思考如何在手游上呈现出更好的美术表现,还尝试引入主机端的开发技术,让冗杂的特效制作过程简化,到快速落地在手游中。

在他看来,艺术挑战技术,技术启发艺术。新的技术和工具的出现,为艺术创作的实现带来新的可能性和便捷。数字艺术的创作常常受限于游戏开发所使用的引擎和插件。但是如果美术多一点对数学的理解,就会发现很多工具是相通的。

一些在主机游戏中使用的技术可以消化,简化或局部地应用到手游开发中。比如 FluidNinjia 是在 Unreal engine 里使用的插件,但是它输出的序列帧流程图等资源可以在ASE中使用。这样我们就可以使用 Unreal Cascade,Niagara 粒子系统来设计特效需要的动态,通过 FluidNinjia 输出贴图资源。将其材质在ASE中简化重构。

这样把跨平台的工具融会贯通地使用,极大扩展了特效的创作和实现的空间。这需要特效师对工具后面的数学多一点理解。

以下是葡萄君整理的演讲实录:

今天和大家分享的内容是:「像素动画的原理和应用」。我很想把它讲到就算外行也能弄懂。同时也通过这个案例,和大家分享一下美术岗位怎么用形象思维来解释数学。

我做了16年的特效。之前在美国、加拿大做过《使命召唤》《暗黑血统》等主机游戏,回国之后先后在网易,阿里游戏,最后来到FunPlus,现在主要负责手游的项目。

从主机游戏到手游转变,我本能地考虑怎么把一些主机的游戏技术应用到手游上面。其中的一个典型例子就是像素动画在手游上的应用。

我是一名特效师,这个岗位也可以叫做特效动画师。动画师动的是角色的胳膊和腿,而特效师动的图片的像素,因为大多数时候,我们都是利用像素运动来模拟各种特效。

比如这个《星空》。现在大家看到的是运动的数字版,它就代表了像素动画要呈现的效果。

要实现这种效果并不难,最近有个叫Fluid Ninja的Unreal的插件,特效师可以应用Cascade,Niagara粒子系统,贴图,或者力场在其中模拟出我们想要的运动形式,产出流程图等贴图资源,然后再应用到Unity的ASE材质中。这个过程给了特效师设计像素动画的极大自由,而且十分便捷。

我们先讲一下像素动画的基本原理:

每一张图片其实都是由像素构成的。假如图片的分辨率是1024×1024,那么这1024个像素点都有其对应的坐标。

我们可以用一张“流程图”来操纵一张图片像素坐标的运动方向和强度,以得到我们想要的运动形式。

它涉及到两个最基本的概念:

其一是平面坐标系,这个就是上下左右4个方向。

其二,通道。我们的图片有百万种颜色都是由RGB三个不同的通道组合产生的。

那么我们可以试着将他们合在一起:把红绿通道分别对应坐标系的X值和Y值,这样就可以把图片的「灰度」和坐标系的数值对应起来。

坐标系大家都很清楚。下图在坐标系中左下角是(0,0),右上角可以设为(1,1),这就是一张相片最基本的的坐标系。当然,电脑里的坐标有些不太一样,它是左上角(0,0),右下(1,1)。

但是为了产生上下左右四个方向的运动,我们就得处理出正值和负值的区别。

我们让X和Y分别减去0.5,那么我的图片就能居中,中间点到了(0, 0)的位置;

原本(0, 1)的区间就变成(-0.5, 0.5)的区间,由此我们就能拥有正负两个方向的运动。

这张图是 Unreal 和 Unity 中的坐标节点图标:

你看到当中红绿的过度,其实就是两个通道灰度从黑到白的渐变过程,左边在红色通道里面,我们将黑色设置为0,白色设置为1,那么就有0到1的渐变;右边的绿色通道也同理,不过我们将它的位置设置为纵向,从黑色0到白色1。

这就是红绿通道的灰度值,对应坐标系的值。

知道了颜色的坐标运动,我们简单地描述成这样:

通常图片的灰度值是0到256,在流程图的红色通道里面,黑色产生向右的运动,白色向左运动;如果是绿色通道就是黑色向上,白色向下。128的中间灰为静止状态。换句话说,它不会产生任何的运动。

那么举一个实例,假如我们有这样一张图A:

怎样让他做左右运动成这样?

或者又怎样如此上下运动呢?

答案就是做出一张流程图。

这张流程图就是黑白两个条组成,红色通道、绿色通道是相同的黑白条(因为不用其他方向运动,所以我们把蓝色通道设置为黑色)。

我们现在回头看一下,这个左右运动就是红色通道起作用(绿色通道的灰度值是128的中间灰);而上下运动就是绿色通道起了作用(红色通道的灰度值是128的中间灰)。

这张图就可以解释背后的原理:当我们需要左右运动的时候,我们让红色通有黑白,让绿色通道是128灰度,不产生运动。

同样的图,我们将红色通道设置为128的灰度,绿色通道有黑白,那么他只有上下运动。

基于这个原理,我们找3张图来说明实操。平常工作当中,我们经常要做河流、烟雾、岩浆的运动,这几张静止的图片,几分钟之内就可以做成运动的图片。

我们只需要在Flowmap Painter软件里,像手指划过一样,顺着运动方向抹一下,它就会根据轨迹流动。

我们打开“涂抹”出来的流程图,原理就很显而易见了:因为除了我们需要运动的部分,其他部分都是128的灰度,运动着的部分就是比中间灰或亮或暗一些。

下面这个是像素动画用到的材质球,我用一张流程图扭曲了自己的照片。为了说明白一些,我将它分为ABC三个部分。

点击图片可放大查看原图

A部分看似复杂,其实只是加减乘除一样的算法,目的就是让图片的坐标移动:

One Minus——减1,其实就是首先把(0,0)放到左上角去,符合电脑的坐标规则;Append是将横纵两个方向坐标合在一起;Flow_Strength则是控制扭曲强度;

下面是B部分,Time,也是很重要的节点。打个比方,我们这里有个坐标,时间就是穿过0的过程,往下是过去,往上是未来,它是一条无限延伸的对角线。

而我们想获得重复的效果,就是让时间来回重复,就可以用Fract节点去掉整数。

让时间这一条线,从0开始,0.1走到0.9,到1的时候再重复回到0。意味着时间永远不会有的整数,他只会在0.1 – 0.9之间往复。这就产生了循环。

B部分和A部分是一样的运动,只是慢了0.5秒。但是可以看到都有跳帧的现象。我们用淡入淡出的遮罩来过滤掉跳帧部分——也就是C部分的工作。

试着把它还原成更形象的坐标图,这是Time原始的样子:

我们第一步把它变成小数往复:

再减去0.5以获得负值:

再用Abs把负值翻正过来,让它连续:

最后再乘以2来增大波动幅度,形成连续的波浪线。

最终我们得到这样一个淡入淡出的遮罩图融合A和B两部分,形成无缝循环。

像素动画可以用到很多的地方。比如说这个星球的游戏界面里,巨型风暴原本是一张静止的图片。

银河的运动、太阳的火焰、木星的风暴,全部都是用这种材质球处理的,而且效率非常高

在这个特效里,一张很多小点的黑白图和一张螺旋形状的流程图,两者合在一起,便可以做出一个近似黑洞的旋转结果。

这是我们的一款三消游戏,里面云的动态、怪物的斗篷、水的运动,都用到了这种Flowmap效果。

这个将怪物吸进瓶子的效果,烟雾消散的效果也是用Flowmap处理的像素动画。

制作流程图有很多讨巧的方法:

拿这张图片来举例,先将原图导入Flowmap Painter里面,用涂抹工具顺着运动方向抹几下,于是就可以导出这样一张流程图,十分钟不到。

如果是像木星上这么复杂的风暴运动我肯定是没有时间顺着方向一点点抹的,太复杂了,不过这也有办法。

可以用PS将它的红色通道灰度调整,不动的部分刷成128灰度;然后把绿色通黑白反相,把不想运动的地方用128灰度的刷一刷,于是,几分钟不到的时间就得到了一张木星风暴的流程图。

再比如我只有这样一个灰度图,它的运动也是有很多细节:

可以用CrazyBump拿这张灰度图直接产生Normal Map,我把蓝色通道设置黑的,只用红绿通道,就变成了流程图:

不过最酷的还是用FluidNinja这个插件,如火球、烟雾、爆炸,流体等各种运动,我们都可以用3种方式百分百地控制生产它们的运动。

第一种就是粒子系统。无非是用运动的粒子产生不同的黑白间隔比例,配上算法,就有了种种流体模拟的效果。不光是单帧,也可以设置成序列帧。第二种是用黑白图片,第三种是用力场。它让像素动画特效设计增加了极大的空间。

我们做手游因为包体的大小会受到控制,特效贴图用512×512就会是常大的图了,尤其我们做序列帧的时候。比如说512×512,我们把它分割成4×4=16帧,每个单位都是256,低于这个值,手机上就会看得很模糊。

游戏是每秒30帧播放,16帧的序列图勉强可以在1s内让你觉得特效过得去。现在有了序列帧的流动图,我们就可以将它做到几倍的特效时长。

比如一个爆炸特效,左边这个爆炸是用8×8 64的序列帧,2秒的特效,很顺滑。但假如这是一个原子弹爆炸,让你做30s以上, 1秒就是30帧,30秒就得900帧,那得多大的序列帧贴图啊?右边这个就是用了序列帧流程图的效果,很长但没有卡顿。

材质球就会稍微复杂一些:

目的是用序列帧的流动图为序列帧增加中间帧:

基本道理就是将当前帧往外扭曲,然后下一帧往内扭曲,关键帧缩紧放大后,就出现了两个中间帧,帧数变多,画面自然变丝滑。

最后总结一下像素动画的优缺点:

优点是可以很快、精确地产生我们想要的运动。方法非常简单,制作流程图可以用Flowmap Painter、PS、CrazyBump,还有现在最酷的FluidNinja,借助它我们可以把Unreal、Unity结合起来使用。

序列帧流动图除了产生很细节的运动以外,可以大幅度降低我们的图片大小。

像素动画的的缺点就是动作是重复的。

复数的物理意义

原文地址:https://www.zhihu.com/question/23234701/answer/26017000

复数最直观的理解就是旋转!

4*i*i = -4

就是“4”在数轴上旋转了180度。

那么4*i就是旋转了90度。

另外,e^t是什么样呢?

但当你在指数上加上i之后呢?

变成了一个螺旋线。是不是和电磁场很像?(想拿欧拉公式去跟女生炫学术的男生注意了:她们,真的,不CARE)

当然,更重要的意义在于复数运算保留了二维信息。

假如我让你计算3+5,虽然你可以轻松的计算出8,但是如果让你分解8你会有无数种分解的方法,3和5原始在各自维度上的信息被覆盖了。
但是计算3+5i的话,你依然可以分解出实部和虚部,就像上图那样。

基于以上两个理由,用复数来描述电场与磁场简直完美到爆棚!
我们即可以让电场强度与复数磁场强度相加而不损失各自的信息,又满足了电场与磁场90度垂直的要求。另外,一旦我们需要让任何一个场旋转90度,只要乘一个“i”就可以了

正弦波在频域可以看作是自然数中的“1”,可以构成其他数字的基础元素。当你需要5的时候,你可以看成是1*5(基础元素的五倍)也看以看成2+3(一个基础元素2倍与基础元素3倍的和)。这些用基础元素构成新元素的运算是线性运算。
但是现在你如何用线性运算吧2sin(wt)变换成4sin(wt+pi/6)呢?

利用欧拉公式,我们可以将任何一个正弦波看作其在实轴上的投影。假如两个不同的正弦波,可以用数学表达为:

好了,现在如果我想用第一个正弦波利用线性变换为第二个,我们就只需要将A乘对应的系数使其放大至B(本例为乘2),然后将θ1加上一定的角度使其变为θ2(本例为加30度),然后将得到的第二个虚数重新投影回实轴,就完成了在实数中完全无法做到的变换。

这种利用复指数来计算正弦波的方法也对电磁波极其适用,因为电磁波都是正弦波,当我们需要一个电磁波在时间上延迟/提前,或是在空间上前移/后移,只需要乘一个复指数就可以完成对相位的调整了。

———————————————————————————–

复数不仅有意义,而且可以用图示来优雅地解释。

1、实函数与数轴变换

[公式]

大家都认识y=e^x,对于这样的初等函数,我们从小就学会使用直角坐标系来刻画它们:


它们的特点都大同小异:把实数轴对应到实数轴。然而,既然是一维函数,用二维图像来描述未免太过奢侈。如果我们把数轴涂上不同颜色,再把一条新数轴上对应的函数值涂上相应颜色,就可以清晰地用数轴-数轴对应来展示函数这一关系:

可以发现每个函数的作用无非是在有些地方把数轴往中间压了压,在有些地方又把数轴往两边扯了扯(观察图中小棒棒之间的间距是变窄还是变宽):

  • e^x越往左越挤压数轴,越往右越拉伸数轴
  • x^2离0越远,对数轴的拉伸越厉害(在图上左半边图像和右半边图像重叠在了一起)。如果有一个小球在实数轴上向右滑行,那么它的像则先向左滑行到0,然后再向右滑行。
  • x^3离0越远,对数轴的拉伸比楼上更厉害,但是不同的是,向右滑行的小球的像也一直向右滑行。

是挤压还是拉伸,就看函数在那一点的导数的绝对值是小于1还是大于1。因此导数大小的意义就是局部小区间在变换下的伸缩倍数。导数正负符号的意义是小区间是否反向,比如第二个函数x^2在x小于0时导数也小于零,那么指向右方的数轴负数部分经过变换指向了左方。

2. 复数与平面变换
既然可以用上面的数轴-数轴对应来描述一维函数,那么类似地,就可以用平面-平面对应来描述二维函数。我们用一个复数表示平面上的点,用字母i区分纵坐标,就可以来研究复数函数w=f(z)的性质,其中z=x+iy,w=u+iv。假设我们已经默认了复数的运算:

  • 加法:z+w=(x+u)+i(y+v)
  • 乘法:zw=(xu-yv)+i(xv+yu)
  • 极坐标分解:z=re^it=rcos(t)+i*rsin(t),其中r是复数代表的平面向量到原点的距离,t是和横轴正方向的夹角。

拿出一个涂色的平面网格(从左上开始逆时针依次涂成红黄蓝绿色),把每个网点的像算出来,按顺序连起来,就可以来研究复函数了。

2.1. 复数的加法:

  • 从图中可知,加法就是平面的平移,平移量恰好是那个复数对应的平面向量。

2.2 复数的乘法:

根据上面的运算法则很容易得到函数w=iz的二维对应关系是[x,y]=>[-y,x],画在图上就是:

仔细看可以发现,各点乘以i的效果是平面逆时针旋转了90度,也就是

[公式]

弧度。

各点乘以e^it的后果是平面逆时针旋转t弧度,这里是30度。

乘以一个一般的复数,就是把整个平面按它对应的角度旋转t弧度,再均匀放大r倍。

因此,复数的加法就是自变量对应的平面整体平移,复数的乘法就是平面整体旋转和伸缩,旋转量和放大缩小量恰好是这个复数对应向量的夹角和长度。二维平移和缩放是一维左右平移伸缩的扩展,旋转是一个至少要二维才能明显的特征,限制在一维上,只剩下旋转0度或者旋转180度,对应于一维导数正负值(小线段是否反向)。

3. 复变函数与伸缩旋转

如果在每一个点处的旋转、放缩和平移量都不同(导数不同),就可以得到比较复杂的复数函数,举个例子:

3.1 

w=e^z

e^z=e^(x+iy)=e^x+e^iy,从上一小节的知识可知,e^z的作用就是把平面上每个点按自己对应的坐标放大e^x倍、旋转y弧度。我们立即可以猜测这个函数在x较大的地方放大的倍数更多,因为放大率e^x更大;在x轴上只伸缩不旋转,因为没有e^iy旋转分量;在y轴上只旋转不伸缩,因为没有e^x放缩分量:

  • 请看左图中的横向中轴,它在右图中的像也是横向中轴,只不过左边压缩,右边扩展,这正是我们一开始就提到的一维指数函数。而这个图,恰好就是一开始那个数轴-数轴对应朝两边扩展形成平面-平面对应的结果
  • 再请看左图中的竖直中轴,它在右图发生了弯曲,贴在了单位圆周上,因此变成了一系列纯旋转的复数乘子。这一点在一维中可完全没有类似物,请谨慎类比。
  • 其他点介于纯粹旋转和纯缩放之间。最后,请你回过头再仔细看看这幅图,你会发现这几段话也适用于图中的每个小正方形。小正方形变换前后的旋转和伸缩比例对应于函数的导数,本例中函数的导数就是原函数自己。

3.2. w=z^3+10

  • 加10就是整体向右平移10个单位,可以最后再看。
  • 咱们来看w=z^3,令z=re^it,可以得到:w=r^3e^i*3t,这说明单位圆以内(r<1)函数压缩,单位圆以外(r>1)函数拉伸,离原点越远拉伸越厉害,正方形网格应该越来越大。
  • 原正方形的四个彩色顶点的角度是135、225、315和45度,分别乘以3再取余360到[0,360]度之间变成45、315、225、135。因此正方形的像从左上逆时针看颜色从红黄蓝绿变成了绿蓝黄红。

图像也和上面的分析完全吻合:

举上面两个例子是想向大家展示伸缩和旋转是优雅地解释复数的有力工具。

4. 复变函数和小正方形
接着我们随便看几个复数函数对应的平面变换图像:

漂亮吧,但是且慢!为什么第二个函数图像比较丑?因为二维函数很复杂,有一小类二维函数的变量之间具有一定关系,导致的结果是虽然整体变换多姿多彩,但是如果只观察局部,这些函数一定把足够小的小正方形变成小正方形,不会压扁它或拆散它,只不过平面不同地方小正方形放缩和旋转程度不同。第二个函数就不属于这种特殊的函数类。

这种性质很好,图像很美的函数称为解析函数,它的变量之间的联系称为柯西黎曼方程,局部小正方形的放缩和旋转幅度恰好等于这个复函数在那一点的导数值(和第一段一维函数的原理极其类似,在那里一维导数用来刻画伸缩和左右方向)。简单的一维函数,可以唯一地向两边扩展成为对应的复解析函数。

如果把初始的正方形网格用极坐标进行参数化,解析函数仍然把小正方形变换为小正方形,与上图对应的图像为:

以后看到复变(准确地说是解析)函数,可要记得它们的本质是对平面局部做旋转和缩放,但保持小正方形形状不变。而一个复数就是一个能把平面进行均匀缩放和旋转的乘子。最后,请记得我的彩色正方形!