diff --git a/AxibugEmuOnline.Client/Assets/Script/NesEmulator/NesEmulator.cs b/AxibugEmuOnline.Client/Assets/Script/NesEmulator/NesEmulator.cs index a61075f..5ff5c18 100644 --- a/AxibugEmuOnline.Client/Assets/Script/NesEmulator/NesEmulator.cs +++ b/AxibugEmuOnline.Client/Assets/Script/NesEmulator/NesEmulator.cs @@ -12,10 +12,14 @@ namespace AxibugEmuOnline.Client { public class NesEmulator : MonoBehaviour, IEmuCore { + //模拟器核心实例化对象 public NES NesCore { get; private set; } + //视频驱动(这里是Unity接收模拟器画面数据的并渲染出来的实现) public VideoProvider VideoProvider; + //音频驱动(这里是Unity接收模拟器音频数据的并播放出来的实现) public AudioProvider AudioProvider; + //是否暂停 public bool m_bPause; private void Start() @@ -25,6 +29,10 @@ namespace AxibugEmuOnline.Client AudioProvider.NesEmu = this; } + /// + /// 指定ROM开始游戏 + /// + /// public void StartGame(RomFile rom) { StopGame(); @@ -45,12 +53,18 @@ namespace AxibugEmuOnline.Client } } + /// + /// 停止游戏 + /// public void StopGame() { NesCore?.Dispose(); NesCore = null; } + /// + /// Unity的逐帧驱动 + /// private unsafe void Update() { if (m_bPause) return; @@ -66,6 +80,7 @@ namespace AxibugEmuOnline.Client } } + //是否跳帧,单机无效 private void FixEmulatorFrame() { var skipFrameCount = App.roomMgr.netReplay.GetSkipFrameCount(); @@ -78,6 +93,7 @@ namespace AxibugEmuOnline.Client } ControllerState lastState; + //推进帧 private bool PushEmulatorFrame() { Supporter.SampleInput(NesCore.FrameCount); @@ -132,11 +148,19 @@ namespace AxibugEmuOnline.Client return NesCore.GetState(); } + /// + /// 获取即时存档 + /// + /// public byte[] GetStateBytes() { return NesCore.GetState().ToBytes(); } + /// + /// 加载即时存档 + /// + /// public void LoadStateFromBytes(byte[] data) { State st = new State(); @@ -145,6 +169,9 @@ namespace AxibugEmuOnline.Client } + /// + /// 编辑器用 + /// [Conditional("UNITY_EDITOR")] [ContextMenu("ImportNesDB")] public void ImportNesDB()