public static int _amUpdatePlane(object r) { AppMain.AMS_AME_RUNTIME runtime = (AppMain.AMS_AME_RUNTIME)r; AppMain.AMS_AME_NODE_PLANE node = (AppMain.AMS_AME_NODE_PLANE)runtime.node; AppMain.AMS_AME_LIST next = runtime.active_head.next; AppMain.AMS_AME_LIST activeTail = runtime.active_tail; int transparency = runtime.ecb.transparency; float num1; float num2; if ((double)node.life >= 0.0) { num1 = node.life; num2 = 1f / num1; } else { num1 = float.MaxValue; num2 = 0.0f; } float sizeRate = runtime.ecb.size_rate; float num3 = node.scale_x_start * sizeRate; float num4 = node.scale_y_start * sizeRate; float num5 = node.scale_x_end * sizeRate; float num6 = node.scale_y_end * sizeRate; AppMain.NNS_VECTOR4D amEffectVel = AppMain._amEffect_vel; AppMain.NNS_QUATERNION nnsQuaternion = new AppMain.NNS_QUATERNION(); AppMain.NNS_VECTOR4D pVec = new AppMain.NNS_VECTOR4D(); for (; next != activeTail; next = next.next) { AppMain.AMS_AME_RUNTIME_WORK_PLANE runtimeWorkPlane = (AppMain.AMS_AME_RUNTIME_WORK_PLANE)(AppMain.AMS_AME_RUNTIME_WORK) next; runtimeWorkPlane.time += AppMain._am_unit_frame; float rate = runtimeWorkPlane.time * num2; AppMain.amVectorScale(amEffectVel, runtimeWorkPlane.velocity, AppMain._am_unit_time); AppMain.amVectorAdd(runtimeWorkPlane.position, amEffectVel); if ((double)runtimeWorkPlane.time >= (double)num1) { if (runtime.spawn_runtime != null) { AppMain._amCreateSpawnParticle(runtime, (AppMain.AMS_AME_RUNTIME_WORK)(AppMain.AMS_AME_LIST) runtimeWorkPlane); } AppMain.amEffectDisconnectLink((AppMain.AMS_AME_LIST)runtimeWorkPlane); --runtime.active_num; AppMain.amEffectFreeRuntimeWork((AppMain.AMS_AME_RUNTIME_WORK)(AppMain.AMS_AME_LIST) runtimeWorkPlane); } else { pVec.x = runtimeWorkPlane.rotate_axis.x; pVec.y = runtimeWorkPlane.rotate_axis.y; pVec.z = runtimeWorkPlane.rotate_axis.z; pVec.w = runtimeWorkPlane.rotate_axis.w; AppMain.amQuatRotAxisToQuat(ref nnsQuaternion, pVec, pVec.w * AppMain._am_unit_time); AppMain.NNS_QUATERNION rotate = runtimeWorkPlane.rotate; AppMain.amQuatMulti(ref rotate, ref nnsQuaternion, ref rotate); runtimeWorkPlane.rotate = rotate; float num7 = 1f - rate; float num8 = (float)((double)num3 * (double)num7 + (double)num5 * (double)rate); float num9 = (float)((double)num4 * (double)num7 + (double)num6 * (double)rate); runtimeWorkPlane.set_size(runtimeWorkPlane.size.z * num8, runtimeWorkPlane.size.z * num9, runtimeWorkPlane.size.z, runtimeWorkPlane.size.w); AppMain.AMS_RGBA8888 pCO; AppMain.amEffectLerpColor(out pCO, ref node.color_start, ref node.color_end, rate); pCO.a = (byte)((int)pCO.a * transparency >> 8); runtimeWorkPlane.set_color(pCO.color); if (((int)node.flag & 32768) != 0) { AppMain.AMS_AME_TEX_ANIM texAnim = node.tex_anim; if (((int)runtimeWorkPlane.flag & 2) == 0) { runtimeWorkPlane.tex_time += AppMain._am_unit_frame; if ((double)runtimeWorkPlane.tex_time >= (double)texAnim.key_buf[runtimeWorkPlane.tex_no].time) { runtimeWorkPlane.tex_time = 0.0f; ++runtimeWorkPlane.tex_no; if (runtimeWorkPlane.tex_no == texAnim.key_num) { if (((int)node.flag & 65536) != 0) { runtimeWorkPlane.tex_no = 0; } else { runtimeWorkPlane.tex_no = texAnim.key_num - 1; runtimeWorkPlane.flag |= 2U; } } } } AppMain.AMS_AME_TEX_ANIM_KEY amsAmeTexAnimKey = texAnim.key_buf[runtimeWorkPlane.tex_no]; runtimeWorkPlane.set_st(amsAmeTexAnimKey.l, amsAmeTexAnimKey.t, amsAmeTexAnimKey.r, amsAmeTexAnimKey.b); if (((int)runtimeWorkPlane.flag & 8) != 0) { runtimeWorkPlane.set_st(runtimeWorkPlane.st.z, runtimeWorkPlane.st.y, runtimeWorkPlane.st.x, runtimeWorkPlane.st.w); } if (((int)runtimeWorkPlane.flag & 16) != 0) { runtimeWorkPlane.set_st(runtimeWorkPlane.st.x, runtimeWorkPlane.st.w, runtimeWorkPlane.st.z, runtimeWorkPlane.st.y); } } else if (((int)node.flag & 16384) != 0) { float num10 = node.scroll_u * AppMain._am_unit_time; float num11 = node.scroll_v * AppMain._am_unit_time; if (((int)runtimeWorkPlane.flag & 8) != 0) { num10 = -num10; } if (((int)runtimeWorkPlane.flag & 16) != 0) { num11 = -num11; } runtimeWorkPlane.set_st(runtimeWorkPlane.st.x + num10, runtimeWorkPlane.st.y + num11, runtimeWorkPlane.st.z + num10, runtimeWorkPlane.st.w + num11); } } } //AppMain.GlobalPool<AppMain.NNS_VECTOR4D>.Release(pVec); return(0); }
public static int _amInitPlane(object p) { AppMain.AMS_AME_CREATE_PARAM amsAmeCreateParam = (AppMain.AMS_AME_CREATE_PARAM)p; AppMain.AMS_AME_NODE_PLANE node = (AppMain.AMS_AME_NODE_PLANE)amsAmeCreateParam.node; AppMain.AMS_AME_RUNTIME_WORK_PLANE work = (AppMain.AMS_AME_RUNTIME_WORK_PLANE)amsAmeCreateParam.work; work.time = -node.start_time; AppMain.AMS_RGBA8888 colorStart = node.color_start; work.set_color(colorStart.r, colorStart.g, colorStart.b, (byte)((int)colorStart.a * amsAmeCreateParam.ecb.transparency >> 8)); AppMain.amVectorAdd(work.position, amsAmeCreateParam.parent_position.Value, amsAmeCreateParam.position.Value); AppMain.amVectorAdd(work.position, node.translate); AppMain.amVectorScale(work.velocity, amsAmeCreateParam.parent_velocity.Value, node.inheritance_rate); AppMain.amVectorAdd(work.velocity, amsAmeCreateParam.velocity.Value); if (((int)node.flag & 4) != 0) { AppMain.NNS_VECTOR4D nnsVectoR4D = new AppMain.NNS_VECTOR4D(); float radian = (float)((double)AppMain.nnRandom() * 2.0 * 3.14159274101257); AppMain.amVectorRandom(nnsVectoR4D); AppMain.NNS_QUATERNION rotate = work.rotate; AppMain.amQuatRotAxisToQuat(ref rotate, nnsVectoR4D, radian); work.rotate = rotate; //AppMain.GlobalPool<AppMain.NNS_VECTOR4D>.Release(nnsVectoR4D); } else { work.rotate = node.rotate; } if (((int)node.flag & 8) != 0) { AppMain.NNS_VECTOR4D pDst = new AppMain.NNS_VECTOR4D(); AppMain.amVectorRandom(pDst); work.set_rotate_axis(pDst.x, pDst.y, pDst.z, node.rotate_axis.w); //AppMain.GlobalPool<AppMain.NNS_VECTOR4D>.Release(pDst); } else { work.rotate_axis.Assign(node.rotate_axis); } float z = node.size + node.size_chaos * AppMain.nnRandom(); work.set_size(z * node.scale_x_start, z * node.scale_y_start, z, 0.0f); if (((int)node.flag & 32768) != 0) { work.tex_time = 0.0f; work.tex_no = 0; if (((int)node.flag & 524288) != 0) { work.tex_no = (int)(100.0 * (double)AppMain.nnRandom()) % node.tex_anim.key_num; } AppMain.AMS_AME_TEX_ANIM_KEY amsAmeTexAnimKey = node.tex_anim.key_buf[work.tex_no]; work.set_st(amsAmeTexAnimKey.l, amsAmeTexAnimKey.t, amsAmeTexAnimKey.r, amsAmeTexAnimKey.b); } else if (((int)node.flag & 8192) != 0) { work.set_st(node.cropping_l, node.cropping_t, node.cropping_r, node.cropping_b); } else { work.set_st(0.0f, 0.0f, 1f, 1f); } if (((int)node.flag & 1048576) != 0 || ((int)node.flag & 131072) != 0 && (double)AppMain.nnRandom() > 0.5) { work.flag |= 8U; work.set_st(work.st.z, work.st.y, work.st.x, work.st.w); } if (((int)node.flag & 2097152) != 0 || ((int)node.flag & 262144) != 0 && (double)AppMain.nnRandom() > 0.5) { work.flag |= 16U; work.set_st(work.st.x, work.st.w, work.st.z, work.st.y); } return(0); }