forked from sin365/AxibugEmuOnline
迭代
This commit is contained in:
parent
450eaa8f31
commit
1beb69c7a6
@ -1,65 +1,65 @@
|
|||||||
#define TRACE
|
#define TRACE
|
||||||
using System;
|
using System;
|
||||||
using System.Diagnostics;
|
using UnityEngine;
|
||||||
|
|
||||||
namespace MyNes.Core
|
namespace MyNes.Core
|
||||||
{
|
{
|
||||||
public sealed class Tracer
|
public sealed class Tracer
|
||||||
{
|
{
|
||||||
public static event EventHandler<TracerEventArgs> EventRaised;
|
public static event EventHandler<TracerEventArgs> EventRaised;
|
||||||
|
|
||||||
public static void WriteLine(string message)
|
public static void WriteLine(string message)
|
||||||
{
|
{
|
||||||
Tracer.EventRaised?.Invoke(null, new TracerEventArgs(message, TracerStatus.Normal));
|
Tracer.EventRaised?.Invoke(null, new TracerEventArgs(message, TracerStatus.Normal));
|
||||||
Trace.WriteLine(message);
|
Debug.Log(message);
|
||||||
}
|
}
|
||||||
|
|
||||||
public static void WriteLine(string message, string category)
|
public static void WriteLine(string message, string category)
|
||||||
{
|
{
|
||||||
Tracer.EventRaised?.Invoke(null, new TracerEventArgs($"{category}: {message}", TracerStatus.Normal));
|
Tracer.EventRaised?.Invoke(null, new TracerEventArgs($"{category}: {message}", TracerStatus.Normal));
|
||||||
Trace.WriteLine($"{category}: {message}");
|
Debug.Log(message);
|
||||||
}
|
}
|
||||||
|
|
||||||
public static void WriteLine(string message, TracerStatus status)
|
public static void WriteLine(string message, TracerStatus status)
|
||||||
{
|
{
|
||||||
Tracer.EventRaised?.Invoke(null, new TracerEventArgs(message, status));
|
Tracer.EventRaised?.Invoke(null, new TracerEventArgs(message, status));
|
||||||
Trace.WriteLine(message);
|
Debug.Log(message);
|
||||||
}
|
}
|
||||||
|
|
||||||
public static void WriteLine(string message, string category, TracerStatus status)
|
public static void WriteLine(string message, string category, TracerStatus status)
|
||||||
{
|
{
|
||||||
Tracer.EventRaised?.Invoke(null, new TracerEventArgs($"{category}: {message}", status));
|
Tracer.EventRaised?.Invoke(null, new TracerEventArgs($"{category}: {message}", status));
|
||||||
Trace.WriteLine($"{category}: {message}");
|
Debug.Log($"{category}:{message}");
|
||||||
}
|
}
|
||||||
|
|
||||||
public static void WriteError(string message)
|
public static void WriteError(string message)
|
||||||
{
|
{
|
||||||
WriteLine(message, TracerStatus.Error);
|
WriteLine(message, TracerStatus.Error);
|
||||||
}
|
}
|
||||||
|
|
||||||
public static void WriteError(string message, string category)
|
public static void WriteError(string message, string category)
|
||||||
{
|
{
|
||||||
WriteLine(message, category, TracerStatus.Error);
|
WriteLine(message, category, TracerStatus.Error);
|
||||||
}
|
}
|
||||||
|
|
||||||
public static void WriteWarning(string message)
|
public static void WriteWarning(string message)
|
||||||
{
|
{
|
||||||
WriteLine(message, TracerStatus.Warning);
|
WriteLine(message, TracerStatus.Warning);
|
||||||
}
|
}
|
||||||
|
|
||||||
public static void WriteWarning(string message, string category)
|
public static void WriteWarning(string message, string category)
|
||||||
{
|
{
|
||||||
WriteLine(message, category, TracerStatus.Warning);
|
WriteLine(message, category, TracerStatus.Warning);
|
||||||
}
|
}
|
||||||
|
|
||||||
public static void WriteInformation(string message)
|
public static void WriteInformation(string message)
|
||||||
{
|
{
|
||||||
WriteLine(message, TracerStatus.Infromation);
|
WriteLine(message, TracerStatus.Infromation);
|
||||||
}
|
}
|
||||||
|
|
||||||
public static void WriteInformation(string message, string category)
|
public static void WriteInformation(string message, string category)
|
||||||
{
|
{
|
||||||
WriteLine(message, category, TracerStatus.Infromation);
|
WriteLine(message, category, TracerStatus.Infromation);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -122,6 +122,50 @@ NavMeshSettings:
|
|||||||
debug:
|
debug:
|
||||||
m_Flags: 0
|
m_Flags: 0
|
||||||
m_NavMeshData: {fileID: 0}
|
m_NavMeshData: {fileID: 0}
|
||||||
|
--- !u!1 &258485946
|
||||||
|
GameObject:
|
||||||
|
m_ObjectHideFlags: 0
|
||||||
|
m_CorrespondingSourceObject: {fileID: 0}
|
||||||
|
m_PrefabInstance: {fileID: 0}
|
||||||
|
m_PrefabAsset: {fileID: 0}
|
||||||
|
serializedVersion: 6
|
||||||
|
m_Component:
|
||||||
|
- component: {fileID: 258485947}
|
||||||
|
- component: {fileID: 258485948}
|
||||||
|
m_Layer: 0
|
||||||
|
m_Name: NesCoreProxy
|
||||||
|
m_TagString: Untagged
|
||||||
|
m_Icon: {fileID: 0}
|
||||||
|
m_NavMeshLayer: 0
|
||||||
|
m_StaticEditorFlags: 0
|
||||||
|
m_IsActive: 1
|
||||||
|
--- !u!4 &258485947
|
||||||
|
Transform:
|
||||||
|
m_ObjectHideFlags: 0
|
||||||
|
m_CorrespondingSourceObject: {fileID: 0}
|
||||||
|
m_PrefabInstance: {fileID: 0}
|
||||||
|
m_PrefabAsset: {fileID: 0}
|
||||||
|
m_GameObject: {fileID: 258485946}
|
||||||
|
serializedVersion: 2
|
||||||
|
m_LocalRotation: {x: 0, y: 0, z: 0, w: 1}
|
||||||
|
m_LocalPosition: {x: 0, y: 0, z: 0}
|
||||||
|
m_LocalScale: {x: 1, y: 1, z: 1}
|
||||||
|
m_ConstrainProportionsScale: 0
|
||||||
|
m_Children: []
|
||||||
|
m_Father: {fileID: 0}
|
||||||
|
m_LocalEulerAnglesHint: {x: 0, y: 0, z: 0}
|
||||||
|
--- !u!114 &258485948
|
||||||
|
MonoBehaviour:
|
||||||
|
m_ObjectHideFlags: 0
|
||||||
|
m_CorrespondingSourceObject: {fileID: 0}
|
||||||
|
m_PrefabInstance: {fileID: 0}
|
||||||
|
m_PrefabAsset: {fileID: 0}
|
||||||
|
m_GameObject: {fileID: 258485946}
|
||||||
|
m_Enabled: 1
|
||||||
|
m_EditorHideFlags: 0
|
||||||
|
m_Script: {fileID: 11500000, guid: ac8cd27a180bf3e489b2ca27c821bffe, type: 3}
|
||||||
|
m_Name:
|
||||||
|
m_EditorClassIdentifier:
|
||||||
--- !u!1 &708549044
|
--- !u!1 &708549044
|
||||||
GameObject:
|
GameObject:
|
||||||
m_ObjectHideFlags: 0
|
m_ObjectHideFlags: 0
|
||||||
@ -314,3 +358,4 @@ SceneRoots:
|
|||||||
m_Roots:
|
m_Roots:
|
||||||
- {fileID: 1232273654}
|
- {fileID: 1232273654}
|
||||||
- {fileID: 708549046}
|
- {fileID: 708549046}
|
||||||
|
- {fileID: 258485947}
|
||||||
|
@ -1,6 +1,6 @@
|
|||||||
{
|
{
|
||||||
"name": "AxibugEmuOnline.Client",
|
"name": "AxibugEmuOnline.Client",
|
||||||
"rootNamespace": "",
|
"rootNamespace": "AxibugEmuOnline.Client",
|
||||||
"references": [
|
"references": [
|
||||||
"GUID:0c194730510bd1b4fad0398ccfe4235b"
|
"GUID:0c194730510bd1b4fad0398ccfe4235b"
|
||||||
],
|
],
|
||||||
|
@ -11,146 +11,12 @@ namespace AxibugEmuOnline.Client.Manager
|
|||||||
{
|
{
|
||||||
public class AppEmu
|
public class AppEmu
|
||||||
{
|
{
|
||||||
INes _nes;
|
|
||||||
|
|
||||||
public static WINSettings Settings { get; private set; }
|
|
||||||
|
|
||||||
private bool isMaxing;
|
|
||||||
|
|
||||||
private bool isMoving;
|
|
||||||
|
|
||||||
private bool pausedByMainWindow;
|
|
||||||
|
|
||||||
private bool isMouseVisible;
|
|
||||||
|
|
||||||
private int mouseHiderCounter;
|
|
||||||
|
|
||||||
private const int mouseHiderReload = 1;
|
|
||||||
|
|
||||||
private bool gameLoaded;
|
|
||||||
|
|
||||||
private IContainer components;
|
|
||||||
|
|
||||||
public AppEmu()
|
|
||||||
{
|
|
||||||
}
|
|
||||||
|
|
||||||
public void Init()
|
public void Init()
|
||||||
{
|
{
|
||||||
_nes = new INes();
|
MyNesMain.Initialize(setupRenderers: false);
|
||||||
|
MyNesMain.SetVideoProvider();
|
||||||
|
MyNesMain.SetAudioProvider();
|
||||||
|
MyNesMain.SetRenderingMethods();
|
||||||
}
|
}
|
||||||
|
|
||||||
internal void LoadGame(string filePath)
|
|
||||||
{
|
|
||||||
bool success = false;
|
|
||||||
switch (Path.GetExtension(filePath).ToLower())
|
|
||||||
{
|
|
||||||
case ".nes":
|
|
||||||
NesEmu.LoadGame(filePath, out success);
|
|
||||||
break;
|
|
||||||
case ".7z":
|
|
||||||
case ".zip":
|
|
||||||
case ".rar":
|
|
||||||
case ".gzip":
|
|
||||||
case ".tar":
|
|
||||||
case ".bzip2":
|
|
||||||
case ".xz":
|
|
||||||
{
|
|
||||||
string text = filePath;
|
|
||||||
string text2 = Path.GetTempPath() + "\\MYNES\\";
|
|
||||||
SevenZipExtractor sevenZipExtractor;
|
|
||||||
try
|
|
||||||
{
|
|
||||||
sevenZipExtractor = new SevenZipExtractor(text);
|
|
||||||
}
|
|
||||||
catch (Exception ex)
|
|
||||||
{
|
|
||||||
MessageBox.Show(Resources.Message35 + ": \n" + ex.Message);
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
if (sevenZipExtractor.ArchiveFileData.Count == 1)
|
|
||||||
{
|
|
||||||
if (sevenZipExtractor.ArchiveFileData[0].FileName.Substring(sevenZipExtractor.ArchiveFileData[0].FileName.Length - 4, 4).ToLower() == ".nes")
|
|
||||||
{
|
|
||||||
sevenZipExtractor.ExtractArchive(text2);
|
|
||||||
text = text2 + sevenZipExtractor.ArchiveFileData[0].FileName;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
List<string> list = new List<string>();
|
|
||||||
foreach (ArchiveFileInfo archiveFileDatum in sevenZipExtractor.ArchiveFileData)
|
|
||||||
{
|
|
||||||
list.Add(archiveFileDatum.FileName);
|
|
||||||
}
|
|
||||||
FormFilesList formFilesList = new FormFilesList(list.ToArray());
|
|
||||||
if (formFilesList.ShowDialog(this) != DialogResult.OK)
|
|
||||||
{
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
string[] fileNames = new string[1] { formFilesList.SelectedRom };
|
|
||||||
sevenZipExtractor.ExtractFiles(text2, fileNames);
|
|
||||||
text = text2 + formFilesList.SelectedRom;
|
|
||||||
}
|
|
||||||
|
|
||||||
NesEmu.LoadGame(text, out success);
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
if (success)
|
|
||||||
{
|
|
||||||
if (Settings.Misc_RecentFiles == null)
|
|
||||||
{
|
|
||||||
Settings.Misc_RecentFiles = new string[0];
|
|
||||||
}
|
|
||||||
List<string> list2 = new List<string>(Settings.Misc_RecentFiles);
|
|
||||||
if (list2.Contains(filePath))
|
|
||||||
{
|
|
||||||
list2.Remove(filePath);
|
|
||||||
}
|
|
||||||
list2.Insert(0, filePath);
|
|
||||||
if (list2.Count > 19)
|
|
||||||
{
|
|
||||||
list2.RemoveAt(list2.Count - 1);
|
|
||||||
}
|
|
||||||
Settings.Misc_RecentFiles = list2.ToArray();
|
|
||||||
gameLoaded = true;
|
|
||||||
if (Settings.Win_StartInFullscreen)
|
|
||||||
{
|
|
||||||
if (base.WindowState != FormWindowState.Maximized)
|
|
||||||
{
|
|
||||||
MyNesMain.VideoProvider.ResizeBegin();
|
|
||||||
Thread.Sleep(100);
|
|
||||||
MyNesMain.RendererSettings.Vid_Fullscreen = true;
|
|
||||||
base.FormBorderStyle = FormBorderStyle.None;
|
|
||||||
menuStrip1.Visible = false;
|
|
||||||
base.WindowState = FormWindowState.Maximized;
|
|
||||||
MyNesMain.VideoProvider.ResizeEnd();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
else if (MyNesMain.RendererSettings.Vid_AutoStretch)
|
|
||||||
{
|
|
||||||
ApplyStretch(applyRegion: true);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
ApplyWindowTitle();
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
#region Setting
|
|
||||||
|
|
||||||
internal void LoadSettings()
|
|
||||||
{
|
|
||||||
base.Location = new Point(Program.Settings.Win_Location_X, Program.Settings.Win_Location_Y);
|
|
||||||
base.Size = new Size(Program.Settings.Win_Size_W, Program.Settings.Win_Size_H);
|
|
||||||
for (int i = 0; i < Program.SupportedLanguages.Length / 3; i++)
|
|
||||||
{
|
|
||||||
ToolStripMenuItem toolStripMenuItem = new ToolStripMenuItem();
|
|
||||||
toolStripMenuItem.Text = Program.SupportedLanguages[i, 2];
|
|
||||||
toolStripMenuItem.Checked = Program.SupportedLanguages[i, 0] == Program.Settings.InterfaceLanguage;
|
|
||||||
interfaceLanguageToolStripMenuItem.DropDownItems.Add(toolStripMenuItem);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
#endregion
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
17
AxibugEmuOnline.Client/Assets/Script/NesCoreProxy.cs
Normal file
17
AxibugEmuOnline.Client/Assets/Script/NesCoreProxy.cs
Normal file
@ -0,0 +1,17 @@
|
|||||||
|
using AxibugEmuOnline.Client.Manager;
|
||||||
|
using System.Collections;
|
||||||
|
using System.Collections.Generic;
|
||||||
|
using UnityEngine;
|
||||||
|
|
||||||
|
namespace AxibugEmuOnline.Client
|
||||||
|
{
|
||||||
|
public class NesCoreProxy : MonoBehaviour
|
||||||
|
{
|
||||||
|
private AppEmu m_appEnum = new AppEmu();
|
||||||
|
|
||||||
|
private void Start()
|
||||||
|
{
|
||||||
|
m_appEnum.Init();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
11
AxibugEmuOnline.Client/Assets/Script/NesCoreProxy.cs.meta
Normal file
11
AxibugEmuOnline.Client/Assets/Script/NesCoreProxy.cs.meta
Normal file
@ -0,0 +1,11 @@
|
|||||||
|
fileFormatVersion: 2
|
||||||
|
guid: ac8cd27a180bf3e489b2ca27c821bffe
|
||||||
|
MonoImporter:
|
||||||
|
externalObjects: {}
|
||||||
|
serializedVersion: 2
|
||||||
|
defaultReferences: []
|
||||||
|
executionOrder: 0
|
||||||
|
icon: {instanceID: 0}
|
||||||
|
userData:
|
||||||
|
assetBundleName:
|
||||||
|
assetBundleVariant:
|
Loading…
Reference in New Issue
Block a user