Flash AS是什么制作一个魔方旋转,怎么做

Flash AS是什么制作一个魔方旋转,怎么做,第1张

1Flash AS是一门程序语言··只要有心 还是不难(的要有点英语基础)

2先学学FLASH 基础,利用形变动画也可以做出,不要急于求成就用Flash AS做一个魔方旋转的效果。等你学会以后自然会做出来的 ,其实你要的效果就是很多网上相册的效果,你可以下载下来 分解里面的代码

3FLASH as案例闪吧有的是你可以去逛逛 参考网址:>

首先要对三阶魔方有一个整体的理解,就是三阶魔方的轴是固定的,也就是说,在转一个面的时候,只有 8 个块在动(因为中心块相对位置是永远不变的),这一点很重要。还有就是三阶魔方一共 9 + 8 + 9 = 26 个块,其中有棱块 12 个(每层4个),角块 8 个,中心块 6 个(对应6个不同颜色的面),如下图。

  其次需要知道的是三阶魔方公式的含义。公式的定义是在魔方相对自己的位置不变的情况下成立的,也就是在进行一个公式之前,红色面冲自己,白色面朝上,那么这个公式期间,魔方始终保持红色冲自己,白色朝上,进行其他公式之前可以变换魔方的朝向,但是按照公式旋转期间,魔方朝向是不变的,这也很重要!!。这样才能引出公式中字母表示方法(没有撇就是顺时针,有撇就是逆时针,下标有2就是180度旋转,没有就是90度),顺逆时针都是从改该方向上看,这个面是什么方向转,所以从正面看 R 和 L 的方向是反着的:

R: 右侧面顺时针旋转,R’: 右侧面逆时针旋转, R2: 右侧面旋转180度

L: 左侧面 … 同理

F: 正面 … 同理

B: 背面 … 同理

U: 顶面 … 同理

因为底面还原后就不会再动了,一直在底下呆着,所以公式中不会出现底面这个东西。

  最后,就是这篇文章要将的傻瓜公式(有点傻瓜相机的感觉,因为我的公式是一个步骤记一个公式就可以了,虽然会慢,但是一学就会,一看就懂)了,也就是分七个阶段还原魔方(先把七个步骤写出来,后边再一一讲解):

1、底面十字

2、底面还原(一层归位)

3、中间层还原(两层归位)

4、顶面十字

5、顶面还原

6、顶层中间过程(只剩最后3或4个棱块)

7、顶层还原(完成!)

接下来一步一步讲:

一、底面十字

  前后如下图所示。

  还原魔方第一步就是选一个一开始想拼好的面(就是喜欢哪个颜色,先把那个面的9个块拼好),这一步还不是拼好,而是拼出个十字。虽然叫作底面,但是还原之后还是要要把这个面朝上观察比较方便,但是因为公式 3-7 步都是这个面朝下,所以我管它叫作底面。

这一步其实是没有公式的,只需要记住我们的目的是将底面的四个棱块对位到对应位置,同时记住上边讲的旋转一个面只会有8个块动,就可以完成了,只不过是熟能生巧,转多了就有比较快速的想法进行对位了。

二、底面还原

  还是以白色为底面,和第一步一样没有公式,就是简单的角块移动。

三、中间层还原

  前两步结束底面9个块就都归位了,把魔方掉个个儿,让底面真的朝下(白色朝下),然后它就一直朝下了。

这一步就是还原中间一层的四个棱块(只关心棱块即可!!!!)。这一步的思想就是,先看顶面颜色(也就是顶面中心块的颜色),然后在顶层四个棱块中找没有这个颜色的,如果找到了,那就把第三层的棱块转到相应颜色的面上,再看顶面上这个块是什么颜色(只可能是左边面颜色或者右边面颜色),

如果是左边面,如下图,那就用公式 F31:

公式 F31 :U'L'ULUFU'F'

  如果是右边面,如下图,那就用公式 F32:

公式 F32 : URU'R'U'F'UF

  上边两个公式其实很容易看出来是对称的,总结来说,就是要是要归位到左边,那就先把他往右掰,如果要归位到右边,那就先把他往左掰,然后用一个小白块(底面颜色)先出去,带上它,再回来。魔方小站里边管这一步叫作“远切回回,接孩子放学”,公式中体现不出来,但是实际拧的时候,会发现,前4步把孩子送到“学校”(离远点),后四步转一下魔方朝向,去接孩子,然后两个块一起“回家”,还是蛮形象的,“远切回回,接孩子放学”。

如果四个棱块都有**,那就说明中间层棱块已经在中间层上了,因为没有别的地方可以躲了 = =,要不就是反了(如下图),要不就是已经好了,要不就是出现在不该在的位置,那么就用上述两个公式中其中一个,把这个不该在这个位置的棱块转出来,再按上边公式归位到正确位置即可。

四、顶面十字

  顶面十字过程,只需要观察顶面的棱块即可(角块不关心),所以这一步的示例图就用平面图代替(顶面)。这一步的公式依然只有一个,不过对于不同情况,需要使用 0 ~ 3 次公式进行还原(公式中顶面仍然是T,不过这里只展示顶面平面图)。

公式 F4 : FRUR'U'F'

  这一个步骤,只观察顶面棱块和中心块,也就是只关心这个 5 个块,一共只会出现4总情况:

1、一个点:就是只有中心块,4个棱块在顶面的颜色都不是中心块颜色(情况1)

2、小拐弯:就是中心块和左边、上边棱块是对的,其他情况旋转一下可以得到这个相对位置(情况2)

3、“一”字 :就是中心块和左边、右边边棱块是对的,上下对的情况旋转一下可以得到这个相对位置(情况3)

4、“十”字:就是中心块以及4个棱块都是对的了,这是这一步的目标(情况4)

如果第三步完成后,直接就是情况4,那第4步已经完成,可以跳过了。如果不是情况4,那就按照下图所示路线,进行最少一次,最多三次的公式 F4,一定要注意顶面棱块的相对位置!!也就是 “一”字 一定是横着的,小拐弯 一定在左上角。

  另外,因为小拐弯一次公式后,就是情况3,不需要再旋转,所以其实公式中的 F 和 F’ 是可以省略的,多练一练就熟悉了。

五、顶面还原

  这一步的目的就是让顶面9个块颜色变为一致(只需要调整顶层四个角块的朝向)。公式依然只有一个,虽然确实是有别的公式可以更快完成,但是本着“傻瓜公式”原则,只需要记一个公式即可。

公式 F5 : RU'U'R'U'RU'R'

  这一步情况比较多,记住每种情况怎么拿着魔方即可,因为公式只有一个(而且这个公式很好记的一点是,顶面只会逆时针转!上右右下右上右下!)。

  总结来说,就是出现像小鱼的情况,那就让鱼头朝右上方即可,如果忘记了魔方朝向应该是什么样,就一直重复公式5,知道出现很重要的那条小鱼为止。

其实这步用“上右右下右上右下”记好记,“上”代表右侧面向上拧(顺时针),“右”代表顶面向右拧(逆时针),“下”代表右侧面向下拧。可以发现有几次“上”,就一定有几次“下”(因为要保证底面不被破坏),而且顶面只向右拧,且一定是4的倍数次(因为要让底面出去的小白块回来)。

多转几次就会发现,其实这个公式5,是让顶面的四个角块交叉变换,如下图所示。

六、顶层中间过程

  第五步结束,顶面颜色都对了,但是顶层的9个颜色不一定是对的,这一步是中间过程,目的是让顶层只有棱块不对,角块都对。公式依然只有一个。

公式 F6 : RB'RF2R'BRF2R2

  这一步一共只有三种情况:

1、没有一个面上角块是对的

2、有一个面角块是对的

3、四个面角块都是对的。

  我们的目标就是情况3,所以如果直接就是情况3,这一步就跳过了。

七、顶层还原

  这是三阶魔方的最后一个步骤,把顶层的4个棱块归位。这步一共也是只有三种情况:

1、四个棱块都不对

2、有一个棱块是对的

3、四个棱块都是对的。

目标就是情况3,不用多说,因为情况3魔方就已经还原了。第2中情况是有两种小情况的,一是三个不对的棱块颜色应该按照顺时针转就对了,二是逆时针转。再次本着“傻瓜公式”原则,只给出一个公式。公式7是从顶面观察的效果。其实很好记,就是4个棱块都不对时,魔方朝向随便,拧一次公式后,会有一个棱块是对的,把这个面朝后边,再拧公式即可。公式可以同5中一样,记为 上右上左上左上右下右,右侧180。

公式 F7 : RU'RURURU'R'U'R2

Private Sub Command1_Click()

    Dim S(1 To 5, 1 To 5) As Long

    Dim x As Long, y As Long

    Dim n As Long

   

    x = 3

    y = 1

    S(3, 1) = 1

    

    For n = 2 To 25

        If x = 5 And y = 1 Then

            y = y + 1

        ElseIf x = 5 Then

            x = 1

            y = y - 1

        ElseIf y = 1 Then

            x = x + 1

            y = 5

        ElseIf S(x + 1, y - 1) <> 0 Then

            y = y + 1

        Else

            x = x + 1

            y = y - 1

        End If

        

        S(x, y) = n

    Next

    

    For y = 1 To 5

        For x = 1 To 5

            Print S(x, y) & vbTab;

        Next

        Print

    Next

    

End Sub

因为main作为程序执行的入口只可能有一个,所以无论写在程序的什么位置上,在编译程序的过程中被识别出来即可,执行的时候就从main开始执行。

打个比方说,房子盖好之后,大门无论开在东面还是南面都可以,但只能有一个门,我们进入房间就从这个门进入即可。

具体做法:

方法一;

/此程序使我按照上面介绍的魔方阵的规律编写的,不过只能求奇数魔方阵,经过测试可以算到508阶/

#define N 7

#include<stdioh>

void main()

{

int a[N][N],i,j,k;

for(i=0;i<N;i++) /先处理第一行/

for(j=0;j<N;j++)

{

a[i][j]=0; /先令所有元素都为0/

}

j=(N-1)/2; /判断j的位置/

a[0][j]=1; /将1放在第一行中间一列/

for(k=2;k<=NN;k++) /再从2开始处理/

{

i=i-1; /存放的行比前一个数的行数减1/

j=j+1; /存放的列比前一个数的列数加1/

if((i<0)&&(j==N)) /前一个数是第一行第N列时,把下一个数放在上一个数的下面/

{

i=i+2;

j=j-1;

}

else

{

if(i<0) /当行数减到第一行,返回到最后一行/

i=N-1;

if(j>N-1) /当列数加到最后一行,返回到第一行/

j=0;

}

if(a[i][j]==0) /如果该元素为0,继续执行程序/

a[i][j]=k;

else /如果该元素不为0,就说明要填的数的位置已经被占,则该数放在上一个数的下面/

{

i=i+2;

j=j-1;

a[i][j]=k;

}

}

for(i=0;i<N;i++) /输出数组/

{

for(j=0;j<N;j++)

printf("%5d",a[i][j]);

printf("\n\n");

}

}

方法二:

/这个是网友qfyzy为帮助我找错而提供的,可以算到99阶/

#define N 7

#include<stdioh>

void main()

{

int a[N][N]={0},i=0,j,k; /先令所有元素都为0/

j=(N-1)/2;

i=0;

for(k=1;k<=NN;) /开始处理/

{

if((i<0)&&(j==N)) /前一个数是第一行第N列时,把下一个数放在上一个数的下面/

{

i=i+2;

j=j-1;

}

else if(i<0) /当行数减到第一行,返回到最后一行/

i=N-1;

else if(j>N-1) /当列数加到最后一行,返回到第一行/

j=0;

else if(!a[i][j]){ /如果该元素为0,继续执行程序/

a[i][j]=k++;

i=i-1;

j=j+1;

}

else /如果该元素不为0,就说明要填的数的位置已经被占,则该数放在上一个数的下面/

{

i=i+2;

j=j-1;

}

}

for(i=0;i<N;i++) /输出数组/

{

for(j=0;j<N;j++)

printf("%5d",a[i][j]);

printf("\n\n");

}

}

以上就是关于Flash AS是什么制作一个魔方旋转,怎么做全部的内容,包括:Flash AS是什么制作一个魔方旋转,怎么做、"魔方阵”程序的算法、3阶魔方教程 1~7步骤等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/zz/9280358.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-04-26
下一篇 2023-04-26

发表评论

登录后才能评论

评论列表(0条)

保存