Unity-3d Day08

粒子系统啊   粒! 子! 系! 统!

炫酷啊   吊炸天啊   

Particle System控制:
Particle 常用属性分为:状态属性,粒子过程属性和发射初始属性

ParticleSystem状态属性:
  isPaused 当前是否正处于暂停状态
  isPlaying 当前是否正处于播放状态
  isStopped 当前是否正处于停⽌状态
  loop 粒⼦是否时循环的
  playOnAwake 如果为true,将在开始时⾃动播放
  time 粒⼦播放的时间

ParticleSystem粒⼦过程属性:
  duration 粒⼦系统持续时间(单位:秒)
  emissionRate 发射速率
  enableEmission 当设置为false时,粒⼦系统不会发射粒⼦
  gravityModifier 缩放被应⽤到Physics.gravity所定义值的影响
  maxParticles 发射的最⼤粒⼦数量
  particleCount 当前粒⼦数量(只读)
  playbackSpeed 粒⼦系统播放速度,1为正常速度
  randomSeed 随机种⼦被⽤于粒⼦系统发射,如果设为0,将会在Awake的时候被指定为⼀个随机值
  safeCollisionEventSize ⽤于ParticleSystem.GetCollisionEvents事件的安全数组⼤⼩
  simulationSpace 粒⼦系统仿真的坐标空间,世界坐标空间或本地坐标空间

ParticleSystem发射初始属性:
  startColor 粒⼦发射时的初始颜⾊
  startDelay 秒计的初始发射延迟
  startLifetime 发射粒⼦的⽣命周期总计(单位:秒)
  startRotation 粒⼦发射时的初始旋转
  startSize 粒⼦发射时的初始⼤⼩
  startSpeed 粒⼦发射时的初始速度

ParticleSystem常⽤⽅法:
Clear 清除粒⼦系统⾥⾯的所有粒⼦
Emit ⽴即发射指定数量的粒⼦
GetCollisionEvents 获取GameObject上的粒⼦碰撞事件,返回写⼊数组⾥的事件数
GetParticles 获取当前粒⼦系统内的粒⼦,
返回被写⼊input particle数组中的粒⼦数量
  IsAlive 判断系统中是否还有粒⼦(或者产⽣更多粒⼦)
  Pause 暂停粒⼦系统的播放
  Play 播放粒⼦系统
  SetParticles 设置当前粒⼦系统的粒⼦(将⼀系列粒⼦置⼊particle system中),⼤⼩为被设置的粒⼦的数量
  Simulate 在给定的时间周期内快进仿真粒⼦系统,然后暂停它
  Stop 停⽌播放粒⼦系统
GetParticle:(一定要set回来 不然白整了都)

  • 定义particle system变量【⽤于存储获取的粒⼦序列】
  • 初始化粒⼦系统数组【⽤于初始化数组⼤⼩】
  • 获取粒⼦系统中的粒⼦序列【返回获取到的粒⼦数量】
  • 对每个粒⼦进⾏控制【颜⾊、旋转、⽣命周期、尺⼨、位置等】

SetParticles:
  • 通过GetParticles获取粒⼦
  • 根据实际需求对逐个粒⼦进⾏处理
  • 通过SetParticle将粒⼦赋回particleSystem

OnParticleCollision:OnParticleCollision事件在某个粒⼦碰到⼀个碰撞体的时候被触发。可以被⽤于控制物体在被粒⼦击中后被销毁。

using UnityEngine;
using System.Collections;
public class ParticleScript : MonoBehaviour
{
    ParticleSystem ps;
    public Transform sphere;
    // Use this for initialization
    void Start()
    {
        ps = particleSystem;
        
    }
    int count;
    ParticleSystem.Particle[] particles;
    private bool isSelect;
    // Update is called once per frame
    void Update()
    {
        count = ps.particleCount;
        particles = new ParticleSystem.Particle[count];
        ps.GetParticles(particles);
        if (isSelect)
        {
            for (int i = 0; i < particles.Length; i++)
            {
                
                particles[i].color = Color.red;
                //particles[i].position = Vector3.Lerp(particles[i].position, sphere.position,0.1f);
            }
            ps.SetParticles(particles, count);
            
        }

    }
    void OnGUI()
    {
        if (GUILayout.Button("开始"))
        {
            ps.Play();
        }
        if (GUILayout.Button("暂停"))
        {
            ps.Pause();
        } if (GUILayout.Button("停止"))
        {
            ps.Stop();
        }
        if (GUILayout.Button("发射"))
        {
            ps.Emit(1000);
        }
        if (GUILayout.Button("Clear"))
        {
            ps.Clear();
        }
        if (GUILayout.Button("Move"))
        {
            isSelect = true;
        }

    }
}

 


各种鼠标事件:

  OnMouseDown ⿏标在GUIElement或Collider之上,按下⿏标,该事件即被触发
  OnMouseDrag ⿏标在GUIElement或Collider之上,按下⿏标并保持按下状态,该事件即被触发
  OnMouseEnter 移动⿏标进⼊GUIElement或Collider区域的时候,该事件被触发
  OnMouseExit 移动⿏标移出GUIElement或Collider区域的时候,该事件被触发
  OnMouseOver ⿏标处于GUIElement或Collider之上时,每帧都会调⽤该事件
  OnMouseUp 当⿏标弹起的时候,该事件被触发调⽤
  OnMouseUpAsButton 当⿏标在同⼀个GUIElement或Collider上按下⼜弹起的情况下会触发调⽤该事件

Trigger事件:

  OnTriggerEnter 碰撞体进⼊其它Trigger触发器的时候,OnTriggerEnter事件被调⽤
  OnTriggerExit 碰撞体退出Trigger触发器的时候,OnTriggerExit事件被调⽤
  OnTriggerStay 事件所在的碰撞体保持处于某个触发器之中的时候,每⼀帧OnTriggerStay事件都会被调⽤⼀次

Collision事件:
OnCollisionEnter OnCollisionEnter事件在这个collider/rigidbody 已经开始接触到另⼀个rigidbody/collider时被调⽤
OnCollisionExit OnCollisionExit事件在这个collider/rigidbody停⽌接触另⼀个rigidbody/collider的时候被调⽤
OnCollisionStay OnCollisionStay事件在collider/rigidbody接触另⼀个rigidbody/collider时,每⼀帧调⽤⼀次

秀一下炫酷的粒子吧  哈哈哈  纯面板调处来的粒子

 

转载于:https://www.cnblogs.com/little-sun/p/4389009.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Vue-Unity-WebGL 是一个具有极高可扩展性和灵活性的 Unity3D web 端开发框架,它将 Vue.js 与 Unity Web Player 和 WebGL 等技术相结合,为开发者提供了最佳的解决方案。 Vue-Unity-WebGL 框架具有很高的兼容性和易用性,开发者可以更加灵活地应用该框架来定制自己的项目。由于该框架具备了许多优秀的特性,如自适应布局、多平台支持等,使得开发者可以轻松地实现用户体验和开发效率的提升。此外,Vue-Unity-WebGL 框架不仅提供了可视化开发工具,还提供了完整的运行环境,为开发者提供了优秀的开发体验。 Vue-Unity-WebGL 框架的另一个重要特点是其大量的插件与扩展功能,这些插件和扩展可以为项目的开发和管理提供坚强的技术支持。比如,通过 vue-router 可以控制路由,Vue-Unity-WebGL 可以协作处理组件数据和 Unity3D 渲染等复杂的操作,而 Vuex 则可以使开发者方便地处理应用数据流和组件状态的管理。这些插件和扩展功能极大地提高了 Vue-Unity-WebGL 框架的可扩展性和灵活性,使得开发者可以更加容易地进行定制。 综上所述,Vue-Unity-WebGL 框架是一个快速、可靠且强大的解决方案,这使得开发者能够轻松地编写出高质量的 Unity3D web 应用程序。该框架具有大量的功能,实现可扩展性、灵活性、易用性和可维护性,比其他框架更具有竞争力。在未来的发展中,Vue-Unity-WebGL 框架将会被更多的开发者喜爱和应用,并在技术社区中拥有更广泛的影响力。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值