Compare commits
17 Commits
bak_before
...
main
Author | SHA1 | Date | |
---|---|---|---|
fb463f9bc2 | |||
aae3707ff0 | |||
9ab88bd6a9 | |||
bac00afcdc | |||
697fb8f63b | |||
5310a9923a | |||
8bd8c27772 | |||
9a631912f3 | |||
bfc8651b1e | |||
d553052006 | |||
89bab5f308 | |||
c1a8733431 | |||
3a0e28a68f | |||
660ce05d0c | |||
c1e030026f | |||
3816e73e5e | |||
7c6fc880d1 |
@ -1,21 +1,36 @@
|
||||
using System;
|
||||
using System.Runtime.InteropServices;
|
||||
|
||||
namespace MAME.Core.AxiBitmap
|
||||
{
|
||||
|
||||
[StructLayout(LayoutKind.Explicit)]
|
||||
public struct AxiColor
|
||||
{
|
||||
public byte r, g, b, a;
|
||||
// 构造函数
|
||||
[FieldOffset(0)]
|
||||
public int sdColor;
|
||||
[FieldOffset(0)]
|
||||
public byte r;
|
||||
[FieldOffset(1)]
|
||||
public byte g;
|
||||
[FieldOffset(2)]
|
||||
public byte b;
|
||||
[FieldOffset(3)]
|
||||
public byte a;
|
||||
|
||||
public AxiColor(byte _r, byte _g, byte _b)
|
||||
{
|
||||
r = g = b = a = 0;
|
||||
sdColor = 0;
|
||||
r = _r;
|
||||
g = _g;
|
||||
b = _b;
|
||||
a = 255;
|
||||
a = byte.MaxValue;
|
||||
}
|
||||
|
||||
public AxiColor(byte _r, byte _g, byte _b, byte _a)
|
||||
{
|
||||
r = g = b = a = 0;
|
||||
sdColor = 0;
|
||||
r = _r;
|
||||
g = _g;
|
||||
b = _b;
|
||||
@ -23,15 +38,17 @@ namespace MAME.Core.AxiBitmap
|
||||
}
|
||||
public static AxiColor FromArgb(int argb)
|
||||
{
|
||||
byte a = (byte)((argb >> 24) & 0xFF);
|
||||
byte r = (byte)((argb >> 16) & 0xFF);
|
||||
byte g = (byte)((argb >> 8) & 0xFF);
|
||||
byte b = (byte)(argb & 0xFF);
|
||||
return new AxiColor { r = r, g = g, b = b, a = a };
|
||||
return new AxiColor { sdColor = argb };
|
||||
}
|
||||
|
||||
public override string ToString()
|
||||
{
|
||||
return String.Format("{0:X8}", sdColor);
|
||||
}
|
||||
|
||||
public static int ToArgb(AxiColor color)
|
||||
{
|
||||
return (color.a << 24) | (color.r << 16) | (color.g << 8) | color.b;
|
||||
return color.sdColor;
|
||||
}
|
||||
|
||||
#region 颜色定义
|
||||
@ -177,6 +194,52 @@ namespace MAME.Core.AxiBitmap
|
||||
#endregion
|
||||
}
|
||||
|
||||
|
||||
|
||||
public static class AxiBitmapEx
|
||||
{
|
||||
public static int ToArgb(this AxiColor color)
|
||||
{
|
||||
return (color.a << 24) | (color.r << 16) | (color.g << 8) | color.b;
|
||||
}
|
||||
|
||||
|
||||
//public static void CloneIntColorArr(int[] baseBitmap, int[] targetBitmap, int baseWidth, int baseHeight, Rectangle rect)
|
||||
//{
|
||||
// // 检查矩形是否超出位图边界
|
||||
// if (rect.X < 0 || rect.X + rect.Width > baseWidth || rect.Y < 0 || rect.Y + rect.Height > baseHeight)
|
||||
// {
|
||||
// throw new ArgumentException("Rectangle is out of bitmap bounds.");
|
||||
// }
|
||||
|
||||
// int baseStartIndex = rect.Y * baseWidth + rect.X;
|
||||
// int targetStartIndex = rect.Y * rect.Width;
|
||||
|
||||
// for (int y = 0; y < rect.Height; y++)
|
||||
// {
|
||||
// // 注意这里使用了rect.Width作为要拷贝的元素数量,而不是baseWidth
|
||||
// Buffer.BlockCopy(baseBitmap, baseStartIndex + y * baseWidth, targetBitmap, targetStartIndex + y * rect.Width, rect.Width * sizeof(int));
|
||||
// // 或者使用Array.Copy,但要注意类型的大小(在这里是int)
|
||||
// // Array.Copy(baseBitmap, baseStartIndex + y * baseWidth, targetBitmap, targetStartIndex + y * rect.Width, rect.Width);
|
||||
// }
|
||||
//}
|
||||
|
||||
public static void CloneIntColorArr(int[] baseBitmap, int[] targetBitmap, int Width, int Height, Rectangle rect)
|
||||
{
|
||||
// 检查矩形是否超出位图边界
|
||||
if (rect.X < 0 || rect.Right > Width || rect.Y < 0 || rect.Bottom > Height)
|
||||
{
|
||||
throw new ArgumentException("out of");
|
||||
}
|
||||
|
||||
int srcStartIndex = rect.Y * Width + rect.X;
|
||||
|
||||
for (int y = 0; y < rect.Height; y++)
|
||||
{
|
||||
Array.Copy(baseBitmap, srcStartIndex + y * Width, targetBitmap, y * rect.Width, rect.Width);
|
||||
}
|
||||
}
|
||||
|
||||
public struct Rectangle
|
||||
{
|
||||
public int X;
|
||||
@ -195,261 +258,6 @@ namespace MAME.Core.AxiBitmap
|
||||
public int Area { get { return Width * Height; } }
|
||||
public bool Contains(int pointX, int pointY) { return pointX >= X && pointX < X + Width && pointY >= Y && pointY < Y + Height; }
|
||||
}
|
||||
public enum RotateFlipType
|
||||
{
|
||||
RotateNoneFlipNone = 0,
|
||||
Rotate90FlipNone = 1,
|
||||
Rotate180FlipNone = 2,
|
||||
Rotate270FlipNone = 3,
|
||||
RotateNoneFlipX = 4,
|
||||
Rotate90FlipX = 5,
|
||||
Rotate180FlipX = 6,
|
||||
Rotate270FlipX = 7,
|
||||
RotateNoneFlipY = Rotate180FlipX, // 注意:FlipY 可以通过FlipX两次来实现,但这里为了完整性列出
|
||||
Rotate90FlipY = 5, // 注意:FlipY在这里与FlipX相同角度的旋转结合,因为直接FlipY不是90度的倍数
|
||||
Rotate180FlipY = 6,
|
||||
Rotate270FlipY = 7,
|
||||
// 注意:上面的FlipY情况实际上在90度旋转的上下文中并不直接对应,因为FlipY通常意味着沿Y轴翻转,
|
||||
// 但在这里我们假设FlipX和FlipY在枚举中是为了完整性。在实际应用中,您可能只需要处理FlipNone。
|
||||
}
|
||||
|
||||
public class AxiBitmap
|
||||
{
|
||||
public AxiColor[] mData;
|
||||
public int Width;
|
||||
public int Height;
|
||||
|
||||
public AxiBitmap(int width, int height)
|
||||
{
|
||||
Width = width;
|
||||
Height = height;
|
||||
mData = new AxiColor[width * height];
|
||||
}
|
||||
|
||||
public void SetPixel(int x, int y, AxiColor color)
|
||||
{
|
||||
mData[y * Width + x] = color;
|
||||
}
|
||||
|
||||
public AxiColor GetPixel(int x, int y)
|
||||
{
|
||||
return mData[y * Width + x];
|
||||
}
|
||||
|
||||
|
||||
//public AxiBitmap Clone(Rectangle rect)
|
||||
//{
|
||||
// // 检查矩形是否超出位图边界
|
||||
// if (rect.X < 0 || rect.Right > Width || rect.Y < 0 || rect.Bottom > Height)
|
||||
// {
|
||||
// throw new ArgumentException("out of");
|
||||
// }
|
||||
|
||||
// AxiBitmap clonedBitmap = new AxiBitmap(rect.Width, rect.Height);
|
||||
|
||||
// int srcStartIndex = rect.Y * Width + rect.X;
|
||||
|
||||
// for (int y = 0; y < rect.Height; y++)
|
||||
// {
|
||||
// Array.Copy(mData, srcStartIndex + y * Width, clonedBitmap.mData, y * rect.Width, rect.Width);
|
||||
// }
|
||||
// return clonedBitmap;
|
||||
//}
|
||||
|
||||
}
|
||||
|
||||
public static class AxiBitmapEx
|
||||
{
|
||||
public static int ToArgb(this AxiColor color)
|
||||
{
|
||||
return (color.a << 24) | (color.r << 16) | (color.g << 8) | color.b;
|
||||
}
|
||||
//public static AxiBitmap Clone(this AxiBitmap baseBitmap, Rectangle rect)
|
||||
//{
|
||||
// unsafe
|
||||
// {
|
||||
// if (rect.X < 0 || rect.Right > baseBitmap.Width || rect.Y < 0 || rect.Bottom > baseBitmap.Height)
|
||||
// {
|
||||
// throw new ArgumentException("The rectangle is out of the bitmap bounds.");
|
||||
// }
|
||||
// AxiBitmap clonedBitmap = new AxiBitmap(rect.Width, rect.Height);
|
||||
|
||||
// for (int y = 0; y < rect.Height; y++)
|
||||
// {
|
||||
// int srcStartIndex = (rect.Y + y) * baseBitmap.Width * sizeof(AxiColor) + rect.X * sizeof(AxiColor);
|
||||
// int dstStartIndex = y * rect.Width * sizeof(AxiColor);
|
||||
// Array.Copy(baseBitmap.mData, srcStartIndex, clonedBitmap.mData, dstStartIndex, rect.Width * sizeof(AxiColor));
|
||||
// }
|
||||
// return clonedBitmap;
|
||||
// }
|
||||
//}
|
||||
|
||||
public static void Clear(this AxiBitmap baseBitmap, AxiColor color)
|
||||
{
|
||||
}
|
||||
|
||||
|
||||
public static int[] CloneIntColorArr(int[] baseBitmap, int Width, int Height, Rectangle rect)
|
||||
{
|
||||
// 检查矩形是否超出位图边界
|
||||
if (rect.X < 0 || rect.Right > Width || rect.Y < 0 || rect.Bottom > Height)
|
||||
{
|
||||
throw new ArgumentException("out of");
|
||||
}
|
||||
|
||||
//int[] result = new int[Width * Height];
|
||||
|
||||
int[] result = new int[rect.Width * rect.Height];
|
||||
|
||||
int srcStartIndex = rect.Y * Width + rect.X;
|
||||
|
||||
for (int y = 0; y < rect.Height; y++)
|
||||
{
|
||||
Array.Copy(baseBitmap, srcStartIndex + y * Width, result, y * rect.Width, rect.Width);
|
||||
}
|
||||
|
||||
return result;
|
||||
}
|
||||
|
||||
//public static int[] CloneIntColorArr(int[] baseBitmap, int Width, int Height, Rectangle rect)
|
||||
//{
|
||||
// unsafe
|
||||
// {
|
||||
// if (rect.X < 0 || rect.Right > Width || rect.Y < 0 || rect.Bottom > Height)
|
||||
// {
|
||||
// throw new ArgumentException("The rectangle is out of the bitmap bounds.");
|
||||
// }
|
||||
// int[] result = new int[Width * Height];
|
||||
// for (int y = 0; y < rect.Height; y++)
|
||||
// {
|
||||
// int srcStartIndex = (rect.Y + y) * Width * sizeof(int) + rect.X * sizeof(int);
|
||||
// int dstStartIndex = y * rect.Width * sizeof(int);
|
||||
// Array.Copy(baseBitmap, srcStartIndex, result, dstStartIndex, rect.Width * sizeof(int));
|
||||
// }
|
||||
// return result;
|
||||
// }
|
||||
//}
|
||||
|
||||
// DrawImage 方法,用于在当前 AxiBitmap 上绘制另一个 AxiBitmap 的一部分
|
||||
public static void DrawImage(this AxiBitmap baseBitmap, AxiBitmap source, Rectangle destRect, Rectangle srcRect)
|
||||
{
|
||||
|
||||
if (!source.Contains(srcRect.X, srcRect.Y, srcRect.Width, srcRect.Height))
|
||||
throw new ArgumentException("Err");
|
||||
|
||||
// 遍历源矩形的每个像素
|
||||
for (int y = srcRect.Y; y < srcRect.Bottom; y++)
|
||||
{
|
||||
for (int x = srcRect.X; x < srcRect.Right; x++)
|
||||
{
|
||||
// 计算目标位置
|
||||
int destX = destRect.X + (x - srcRect.X);
|
||||
int destY = destRect.Y + (y - srcRect.Y);
|
||||
|
||||
// 确保目标位置在当前位图范围内(如果需要)
|
||||
// if (destX < 0 || destX >= Width || destY < 0 || destY >= Height)
|
||||
// continue; // 或者抛出异常,取决于你的需求
|
||||
|
||||
// 获取源像素并设置到目标位置
|
||||
AxiColor sourceColor = source.GetPixel(x, y);
|
||||
baseBitmap.SetPixel(destX, destY, sourceColor);
|
||||
|
||||
// 如果需要处理透明度混合,则在这里添加代码
|
||||
// 注意:你的 AxiColor 已经包含了 alpha 通道,但 SetPixel 并没有使用它
|
||||
// 你可能需要实现一个混合像素的方法,比如 BlendPixels
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
// 辅助方法,用于检查一个点是否在位图范围内
|
||||
private static bool Contains(this AxiBitmap baseBitmap, int x, int y, int width, int height)
|
||||
{
|
||||
return x >= 0 && x + width <= baseBitmap.Width && y >= 0 && y + height <= baseBitmap.Height;
|
||||
}
|
||||
|
||||
// ... 其他省略 ...
|
||||
|
||||
public static void RotateFlip(this AxiBitmap baseBitmap, RotateFlipType rotateFlipType)
|
||||
{
|
||||
// 先处理旋转部分
|
||||
switch (rotateFlipType)
|
||||
{
|
||||
case RotateFlipType.Rotate90FlipNone:
|
||||
Rotate90(baseBitmap);
|
||||
break;
|
||||
case RotateFlipType.Rotate180FlipNone:
|
||||
Rotate180(baseBitmap);
|
||||
break;
|
||||
case RotateFlipType.Rotate270FlipNone:
|
||||
Rotate270(baseBitmap);
|
||||
break;
|
||||
// 如果需要处理FlipX或FlipY,可以添加额外的case或方法
|
||||
default:
|
||||
// 无需旋转或翻转
|
||||
break;
|
||||
}
|
||||
|
||||
// 注意:这里没有处理FlipX或FlipY,因为通常它们不是通过旋转来实现的
|
||||
// 如果需要FlipX或FlipY,请添加额外的逻辑
|
||||
}
|
||||
|
||||
private static void Rotate90(this AxiBitmap baseBitmap)
|
||||
{
|
||||
int newWidth = baseBitmap.Height;
|
||||
int newHeight = baseBitmap.Width;
|
||||
AxiColor[] newData = new AxiColor[baseBitmap.mData.Length];
|
||||
|
||||
for (int x = 0; x < baseBitmap.Width; x++)
|
||||
{
|
||||
for (int y = 0; y < baseBitmap.Height; y++)
|
||||
{
|
||||
int oldIndex = (y * baseBitmap.Width + x);
|
||||
int newIndex = (newHeight - 1 - x) * newWidth + y;
|
||||
newData[newIndex] = baseBitmap.mData[oldIndex];
|
||||
}
|
||||
}
|
||||
|
||||
baseBitmap.mData = newData;
|
||||
baseBitmap.Width = newWidth;
|
||||
baseBitmap.Height = newHeight;
|
||||
}
|
||||
|
||||
private static void Rotate180(this AxiBitmap baseBitmap)
|
||||
{
|
||||
for (int y = 0; y < baseBitmap.Height / 2; y++)
|
||||
{
|
||||
for (int x = 0; x < baseBitmap.Width; x++)
|
||||
{
|
||||
int topLeftIndex = y * baseBitmap.Width + x;
|
||||
int bottomRightIndex = (baseBitmap.Height - 1 - y) * baseBitmap.Width + x;
|
||||
AxiColor temp = baseBitmap.mData[topLeftIndex];
|
||||
baseBitmap.mData[topLeftIndex] = baseBitmap.mData[bottomRightIndex];
|
||||
baseBitmap.mData[bottomRightIndex] = temp;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
private static void Rotate270(this AxiBitmap baseBitmap)
|
||||
{
|
||||
// Rotate270 可以通过 Rotate90 两次或 Rotate180 后再 Rotate90 来实现
|
||||
// 这里直接实现 Rotate270 以避免额外的旋转调用
|
||||
int newWidth = baseBitmap.Height;
|
||||
int newHeight = baseBitmap.Width;
|
||||
AxiColor[] newData = new AxiColor[baseBitmap.mData.Length];
|
||||
|
||||
for (int x = 0; x < baseBitmap.Width; x++)
|
||||
{
|
||||
for (int y = 0; y < baseBitmap.Height; y++)
|
||||
{
|
||||
int oldIndex = (y * baseBitmap.Width + x);
|
||||
int newIndex = y * newWidth + (newWidth - 1 - x);
|
||||
newData[newIndex] = baseBitmap.mData[oldIndex];
|
||||
}
|
||||
}
|
||||
|
||||
baseBitmap.mData = newData;
|
||||
baseBitmap.Width = newWidth;
|
||||
baseBitmap.Height = newHeight;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
@ -1,7 +1,7 @@
|
||||
using MAME.Core.run_interface;
|
||||
using MAME.Core;
|
||||
using System;
|
||||
|
||||
namespace mame
|
||||
namespace MAME.Core
|
||||
{
|
||||
public static class EmuLogger
|
||||
{
|
||||
|
13
MAME.Core/MAME - Backup.Core.csproj
Normal file
13
MAME.Core/MAME - Backup.Core.csproj
Normal file
@ -0,0 +1,13 @@
|
||||
<Project Sdk="Microsoft.NET.Sdk">
|
||||
|
||||
<PropertyGroup>
|
||||
<TargetFramework>netstandard2.0</TargetFramework>
|
||||
<AllowUnsafeBlocks>True</AllowUnsafeBlocks>
|
||||
</PropertyGroup>
|
||||
|
||||
<ItemGroup>
|
||||
<PackageReference Include="ImageProcessor.Core" Version="1.1.0" />
|
||||
<PackageReference Include="LamarCodeGeneration" Version="6.3.0" />
|
||||
</ItemGroup>
|
||||
|
||||
</Project>
|
6
MAME.Core/MAME.Core.csproj.user
Normal file
6
MAME.Core/MAME.Core.csproj.user
Normal file
@ -0,0 +1,6 @@
|
||||
<?xml version="1.0" encoding="utf-8"?>
|
||||
<Project ToolsVersion="Current" xmlns="http://schemas.microsoft.com/developer/msbuild/2003">
|
||||
<PropertyGroup>
|
||||
<_LastSelectedProfileId>G:\Sin365\MAME.Core\MAME.Core\Properties\PublishProfiles\FolderProfile.pubxml</_LastSelectedProfileId>
|
||||
</PropertyGroup>
|
||||
</Project>
|
62
MAME.Core/MAMEEmu.cs
Normal file
62
MAME.Core/MAMEEmu.cs
Normal file
@ -0,0 +1,62 @@
|
||||
using System;
|
||||
using System.Collections.Generic;
|
||||
using System.IO;
|
||||
using System.Threading;
|
||||
|
||||
namespace MAME.Core
|
||||
{
|
||||
public class MAMEEmu : IDisposable
|
||||
{
|
||||
MameMainMotion mameMainMotion;
|
||||
|
||||
//byte[] mGameTileData;
|
||||
//byte[] mtileListData;
|
||||
public MAMEEmu()
|
||||
{
|
||||
mameMainMotion = new MameMainMotion();
|
||||
}
|
||||
|
||||
public bool bRom => mameMainMotion.bRom;
|
||||
|
||||
public void Init(
|
||||
string RomDir,
|
||||
ILog ilog,
|
||||
IResources iRes,
|
||||
IVideoPlayer ivp,
|
||||
ISoundPlayer isp,
|
||||
IKeyboard ikb,
|
||||
IMouse imou
|
||||
) => mameMainMotion.Init(RomDir, ilog, iRes, ivp, isp, ikb, imou);
|
||||
public Dictionary<string, RomInfo> GetGameList() => mameMainMotion.GetGameList();
|
||||
public void LoadRom(string Name) => mameMainMotion.LoadRom(Name);
|
||||
public void GetGameScreenSize(out int _width, out int _height, out IntPtr _framePtr) => mameMainMotion.GetGameScreenSize(out _width, out _height, out _framePtr);
|
||||
public void StartGame() => mameMainMotion.StartGame();
|
||||
public void StopGame() => mameMainMotion.StopGame();
|
||||
|
||||
public void LoadState(BinaryReader sr)
|
||||
{
|
||||
Mame.paused = true;
|
||||
Thread.Sleep(20);
|
||||
State.loadstate_callback.Invoke(sr);
|
||||
Mame.postload();
|
||||
Thread.Sleep(20);
|
||||
Mame.paused = false;
|
||||
}
|
||||
|
||||
public void SaveState(BinaryWriter sw)
|
||||
{
|
||||
Mame.paused = true;
|
||||
Thread.Sleep(20);
|
||||
State.savestate_callback.Invoke(sw);
|
||||
Thread.Sleep(20);
|
||||
Mame.paused = false;
|
||||
}
|
||||
|
||||
public void Dispose()
|
||||
{
|
||||
mameMainMotion.StopGame();
|
||||
mameMainMotion = null;
|
||||
GC.Collect();
|
||||
}
|
||||
}
|
||||
}
|
@ -1,36 +1,37 @@
|
||||
using mame;
|
||||
using MAME.Core.run_interface;
|
||||
using MAME.Core;
|
||||
using System;
|
||||
using System.Collections.Generic;
|
||||
using System.Linq;
|
||||
using System.Threading;
|
||||
using System.Xml.Linq;
|
||||
|
||||
namespace MAME.Core.Common
|
||||
namespace MAME.Core
|
||||
{
|
||||
public class mainMotion
|
||||
public class MameMainMotion
|
||||
{
|
||||
public string tsslStatus;
|
||||
public cheatMotion cheatmotion;
|
||||
public m68000Motion m68000motion;
|
||||
public z80Motion z80motion;
|
||||
public m6809Motion m6809motion;
|
||||
public cpsMotion cpsmotion;
|
||||
public neogeoMotion neogeomotion;
|
||||
public konami68000Motion konami68000motion;
|
||||
public CheatMotion cheatmotion;
|
||||
public M68000Motion m68000motion;
|
||||
public Z80Motion z80motion;
|
||||
public M6809Motion m6809motion;
|
||||
public CpsMotion cpsmotion;
|
||||
public NeogeoMotion neogeomotion;
|
||||
public Konami68000Motion konami68000motion;
|
||||
public string sSelect;
|
||||
public static Thread t1;
|
||||
public static Thread mainThread;
|
||||
|
||||
public static IResources resource;
|
||||
public bool bRom => Machine.bRom;
|
||||
|
||||
public mainMotion()
|
||||
public MameMainMotion()
|
||||
{
|
||||
neogeomotion = new neogeoMotion();
|
||||
cheatmotion = new cheatMotion();
|
||||
m68000motion = new m68000Motion();
|
||||
m6809motion = new m6809Motion();
|
||||
z80motion = new z80Motion();
|
||||
cpsmotion = new cpsMotion();
|
||||
konami68000motion = new konami68000Motion();
|
||||
neogeomotion = new NeogeoMotion();
|
||||
cheatmotion = new CheatMotion();
|
||||
m68000motion = new M68000Motion();
|
||||
m6809motion = new M6809Motion();
|
||||
z80motion = new Z80Motion();
|
||||
cpsmotion = new CpsMotion();
|
||||
konami68000motion = new Konami68000Motion();
|
||||
}
|
||||
|
||||
public void Init(
|
||||
@ -40,7 +41,8 @@ namespace MAME.Core.Common
|
||||
IVideoPlayer ivp,
|
||||
ISoundPlayer isp,
|
||||
IKeyboard ikb,
|
||||
IMouse imou)
|
||||
IMouse imou
|
||||
)
|
||||
{
|
||||
Mame.RomRoot = RomDir;
|
||||
EmuLogger.BindFunc(ilog);
|
||||
@ -48,33 +50,40 @@ namespace MAME.Core.Common
|
||||
Sound.BindFunc(isp);
|
||||
resource = iRes;
|
||||
|
||||
//StreamReader sr1 = new StreamReader("mame.ini");
|
||||
//sr1.ReadLine();
|
||||
//sSelect = sr1.ReadLine();
|
||||
//sr1.Close();
|
||||
|
||||
//TODO 上次选择
|
||||
sSelect = "samsho2";
|
||||
|
||||
sSelect = string.Empty;
|
||||
|
||||
RomInfo.Rom = new RomInfo();
|
||||
LoadROMXML();
|
||||
//TODO Wavebuffer
|
||||
//desc1.BufferBytes = 0x9400;
|
||||
Keyboard.InitializeInput(this, ikb);
|
||||
Mouse.InitialMouse(this, imou);
|
||||
Keyboard.InitializeInput(ikb);
|
||||
Mouse.InitialMouse(imou);
|
||||
}
|
||||
|
||||
private void LoadROMXML()
|
||||
{
|
||||
XElement xe = XElement.Parse(resource.Get_mame_xml());
|
||||
XElement xe = XElement.Parse(resource.mame);
|
||||
IEnumerable<XElement> elements = from ele in xe.Elements("game") select ele;
|
||||
showInfoByElements(elements);
|
||||
}
|
||||
|
||||
public Dictionary<string, RomInfo> GetGameList()
|
||||
{
|
||||
return RomInfo.dictName2Rom;
|
||||
}
|
||||
|
||||
public void GetGameScreenSize(out int _width, out int _height, out IntPtr _framePtr)
|
||||
{
|
||||
//_width = Video.fullwidth;
|
||||
//_height = Video.fullheight;
|
||||
//_framePtr = Video.bitmapcolor_Ptr;
|
||||
_width = Video.width;
|
||||
_height = Video.height;
|
||||
_framePtr = Video.bitmapcolorRect_Ptr;
|
||||
}
|
||||
|
||||
private void showInfoByElements(IEnumerable<XElement> elements)
|
||||
{
|
||||
RomInfo.romList = new List<RomInfo>();
|
||||
RomInfo.dictName2Rom = new Dictionary<string, RomInfo>();
|
||||
foreach (var ele in elements)
|
||||
{
|
||||
RomInfo rom = new RomInfo();
|
||||
@ -86,6 +95,7 @@ namespace MAME.Core.Common
|
||||
rom.Year = ele.Element("year").Value;
|
||||
rom.Manufacturer = ele.Element("manufacturer").Value;
|
||||
RomInfo.romList.Add(rom);
|
||||
RomInfo.dictName2Rom[rom.Name] = rom;
|
||||
//loadform.listView1.Items.Add(new ListViewItem(new string[] { rom.Description, rom.Year, rom.Name, rom.Parent, rom.Direction, rom.Manufacturer, rom.Board }));
|
||||
}
|
||||
}
|
||||
@ -99,9 +109,9 @@ namespace MAME.Core.Common
|
||||
return;
|
||||
}
|
||||
|
||||
mame.Timer.lt = new List<mame.Timer.emu_timer>();
|
||||
EmuTimer.lt = new List<EmuTimer.emu_timer>();
|
||||
sSelect = RomInfo.Rom.Name;
|
||||
Machine.FORM = this;
|
||||
Machine.mainMotion = this;
|
||||
Machine.rom = RomInfo.Rom;
|
||||
Machine.sName = Machine.rom.Name;
|
||||
Machine.sParent = Machine.rom.Parent;
|
||||
@ -116,107 +126,96 @@ namespace MAME.Core.Common
|
||||
case "CPS-1":
|
||||
case "CPS-1(QSound)":
|
||||
case "CPS2":
|
||||
Video.nMode = 3;
|
||||
|
||||
Video.nMode = 1;
|
||||
Video.iMode = 2;
|
||||
//Video.nMode = 3;
|
||||
itemSelect();
|
||||
CPS.CPSInit();
|
||||
CPS.GDIInit();
|
||||
break;
|
||||
case "Data East":
|
||||
Video.nMode = 1;
|
||||
Video.iMode = 0;
|
||||
itemSelect();
|
||||
Dataeast.DataeastInit();
|
||||
Dataeast.GDIInit();
|
||||
break;
|
||||
case "Tehkan":
|
||||
Video.nMode = 1;
|
||||
Video.iMode = 0;
|
||||
itemSelect();
|
||||
Tehkan.PbactionInit();
|
||||
Tehkan.GDIInit();
|
||||
break;
|
||||
case "Neo Geo":
|
||||
Video.nMode = 1;
|
||||
Video.iMode = 0;
|
||||
itemSelect();
|
||||
Neogeo.NeogeoInit();
|
||||
Neogeo.GDIInit();
|
||||
break;
|
||||
case "SunA8":
|
||||
Video.nMode = 1;
|
||||
Video.iMode = 0;
|
||||
itemSelect();
|
||||
SunA8.SunA8Init();
|
||||
SunA8.GDIInit();
|
||||
break;
|
||||
case "Namco System 1":
|
||||
Video.nMode = 1;
|
||||
Video.iMode = 0;
|
||||
itemSelect();
|
||||
Namcos1.Namcos1Init();
|
||||
Namcos1.GDIInit();
|
||||
break;
|
||||
case "IGS011":
|
||||
Video.nMode = 1;
|
||||
Video.iMode = 0;
|
||||
itemSelect();
|
||||
IGS011.IGS011Init();
|
||||
IGS011.GDIInit();
|
||||
break;
|
||||
case "PGM":
|
||||
Video.nMode = 1;
|
||||
Video.iMode = 0;
|
||||
itemSelect();
|
||||
PGM.PGMInit();
|
||||
PGM.GDIInit();
|
||||
break;
|
||||
case "M72":
|
||||
Video.nMode = 1;
|
||||
Video.iMode = 0;
|
||||
itemSelect();
|
||||
M72.M72Init();
|
||||
M72.GDIInit();
|
||||
break;
|
||||
case "M92":
|
||||
Video.nMode = 1;
|
||||
Video.iMode = 0;
|
||||
itemSelect();
|
||||
M92.M92Init();
|
||||
M92.GDIInit();
|
||||
break;
|
||||
case "Taito":
|
||||
Video.nMode = 1;
|
||||
Video.iMode = 0;
|
||||
itemSelect();
|
||||
Taito.TaitoInit();
|
||||
Taito.GDIInit();
|
||||
break;
|
||||
case "Taito B":
|
||||
Video.nMode = 1;
|
||||
Video.iMode = 0;
|
||||
itemSelect();
|
||||
Taitob.TaitobInit();
|
||||
Taitob.GDIInit();
|
||||
break;
|
||||
case "Konami 68000":
|
||||
Video.nMode = 1;
|
||||
Video.iMode = 0;
|
||||
itemSelect();
|
||||
Konami68000.Konami68000Init();
|
||||
Konami68000.GDIInit();
|
||||
break;
|
||||
case "Capcom":
|
||||
Video.nMode = 1;
|
||||
Video.iMode = 0;
|
||||
itemSelect();
|
||||
Capcom.CapcomInit();
|
||||
Capcom.GDIInit();
|
||||
break;
|
||||
}
|
||||
if (Machine.bRom)
|
||||
{
|
||||
EmuLogger.Log("MAME.NET: " + Machine.sDescription + " [" + Machine.sName + "]");
|
||||
Mame.init_machine(this);
|
||||
Mame.init_machine();
|
||||
Generic.nvram_load();
|
||||
}
|
||||
else
|
||||
@ -225,6 +224,24 @@ namespace MAME.Core.Common
|
||||
}
|
||||
}
|
||||
|
||||
public void StartGame()
|
||||
{
|
||||
M68000Motion.iStatus = 0;
|
||||
M68000Motion.iValue = 0;
|
||||
Mame.exit_pending = false;
|
||||
mainThread = new Thread(Mame.mame_execute);
|
||||
mainThread.Start();
|
||||
}
|
||||
|
||||
public void StopGame()
|
||||
{
|
||||
if (Machine.bRom)
|
||||
{
|
||||
Mame.exit_pending = true;
|
||||
Thread.Sleep(50);
|
||||
}
|
||||
}
|
||||
|
||||
private void itemSelect()
|
||||
{
|
||||
switch (Machine.sBoard)
|
@ -1,12 +1,11 @@
|
||||
using cpu.m68000;
|
||||
using cpu.nec;
|
||||
using mame;
|
||||
using System;
|
||||
using System.Collections.Generic;
|
||||
|
||||
namespace MAME.Core.Common
|
||||
namespace MAME.Core
|
||||
{
|
||||
public partial class cheatMotion
|
||||
public partial class CheatMotion
|
||||
{
|
||||
public enum LockState
|
||||
{
|
||||
@ -25,7 +24,7 @@ namespace MAME.Core.Common
|
||||
#region
|
||||
List<string> mTxList_tbResult = new List<string>();
|
||||
#endregion
|
||||
public cheatMotion()
|
||||
public CheatMotion()
|
||||
{
|
||||
cheatForm_Load();
|
||||
}
|
||||
|
@ -1,8 +1,8 @@
|
||||
using System.Collections.Generic;
|
||||
|
||||
namespace MAME.Core.Common
|
||||
namespace MAME.Core
|
||||
{
|
||||
public partial class cpsMotion
|
||||
public partial class CpsMotion
|
||||
{
|
||||
private string[] sde2 = new string[] { "," };
|
||||
private int locationX, locationY;
|
||||
@ -31,7 +31,7 @@ namespace MAME.Core.Common
|
||||
public string tbScrollsy = string.Empty;
|
||||
public List<string> tbResult = new List<string>();
|
||||
#endregion
|
||||
public cpsMotion()
|
||||
public CpsMotion()
|
||||
{
|
||||
}
|
||||
}
|
||||
|
@ -1,6 +1,6 @@
|
||||
namespace MAME.Core.Common
|
||||
namespace MAME.Core
|
||||
{
|
||||
public class konami68000Motion
|
||||
public class Konami68000Motion
|
||||
{
|
||||
private int locationX, locationY;
|
||||
|
||||
@ -11,7 +11,7 @@
|
||||
public bool cbSprite = false;
|
||||
public string tbSprite;
|
||||
#endregion
|
||||
public konami68000Motion()
|
||||
public Konami68000Motion()
|
||||
{
|
||||
tbSprite = "0000-4000";
|
||||
}
|
||||
|
@ -2,9 +2,9 @@
|
||||
using System;
|
||||
using System.Collections.Generic;
|
||||
|
||||
namespace MAME.Core.Common
|
||||
namespace MAME.Core
|
||||
{
|
||||
public class m68000Motion
|
||||
public class M68000Motion
|
||||
{
|
||||
private string[] sde6 = new string[1] { "," }, sde7 = new string[1] { ";" }, sde9 = new string[1] { "$" }, sde10 = new string[] { "+" };
|
||||
private bool bLogNew, bNew;
|
||||
@ -54,7 +54,7 @@ namespace MAME.Core.Common
|
||||
M68000_STOP,
|
||||
}
|
||||
public static M68000State m68000State, m68000FState;
|
||||
public m68000Motion()
|
||||
public M68000Motion()
|
||||
{
|
||||
int i;
|
||||
mTxList_tbDs = new string[8];
|
||||
|
@ -1,11 +1,10 @@
|
||||
using cpu.m6809;
|
||||
using mame;
|
||||
using System.Collections.Generic;
|
||||
|
||||
namespace MAME.Core.Common
|
||||
namespace MAME.Core
|
||||
{
|
||||
|
||||
public partial class m6809Motion
|
||||
public partial class M6809Motion
|
||||
{
|
||||
//private Disassembler disassembler;
|
||||
private bool bLogNew;
|
||||
@ -34,7 +33,7 @@ namespace MAME.Core.Common
|
||||
public string tbDisassemble = string.Empty;
|
||||
#endregion
|
||||
|
||||
public m6809Motion()
|
||||
public M6809Motion()
|
||||
{
|
||||
}
|
||||
public void GetData()
|
||||
|
@ -1,11 +1,8 @@
|
||||
using mame;
|
||||
using System;
|
||||
using System.Collections.Generic;
|
||||
using System.IO;
|
||||
using System.Collections.Generic;
|
||||
|
||||
namespace MAME.Core.Common
|
||||
namespace MAME.Core
|
||||
{
|
||||
public partial class neogeoMotion
|
||||
public partial class NeogeoMotion
|
||||
{
|
||||
private string[] sde2 = new string[] { "," };
|
||||
private int locationX, locationY;
|
||||
@ -20,7 +17,7 @@ namespace MAME.Core.Common
|
||||
bool cbL0 = false;
|
||||
bool cbL1 = false;
|
||||
#endregion
|
||||
public neogeoMotion()
|
||||
public NeogeoMotion()
|
||||
{
|
||||
tbResult = new List<string>();
|
||||
neogeoForm_Load();
|
||||
@ -35,58 +32,5 @@ namespace MAME.Core.Common
|
||||
tbSOffset = "01cb0600";
|
||||
tbPensoffset = "ed0";
|
||||
}
|
||||
private void DumpRam()
|
||||
{
|
||||
int i, j;
|
||||
BinaryWriter bw1 = new BinaryWriter(new FileStream("dump1.dat", FileMode.Create));
|
||||
bw1.Write(Memory.mainram, 0, 0x10000);
|
||||
bw1.Close();
|
||||
BinaryWriter bw2 = new BinaryWriter(new FileStream("dump2.dat", FileMode.Create));
|
||||
bw2.Write(Neogeo.mainram2, 0, 0x10000);
|
||||
bw2.Close();
|
||||
BinaryWriter bw3 = new BinaryWriter(new FileStream("dump3.dat", FileMode.Create));
|
||||
for (i = 0; i < 0x10000; i++)
|
||||
{
|
||||
bw3.Write(Neogeo.neogeo_videoram[i]);
|
||||
}
|
||||
BinaryWriter bw4 = new BinaryWriter(new FileStream("dump4.dat", FileMode.Create));
|
||||
for (i = 0; i < 2; i++)
|
||||
{
|
||||
for (j = 0; j < 0x1000; j++)
|
||||
{
|
||||
bw4.Write(Neogeo.palettes[i, j]);
|
||||
}
|
||||
}
|
||||
}
|
||||
private void WriteRam()
|
||||
{
|
||||
int i, j;
|
||||
byte[] bb1 = new byte[0x10000], bb2 = new byte[0x10000], bb3 = new byte[0x20000], bb4 = new byte[0x4000];
|
||||
BinaryReader br1 = new BinaryReader(new FileStream("dump1.dat", FileMode.Open));
|
||||
br1.Read(bb1, 0, 0x10000);
|
||||
br1.Close();
|
||||
Array.Copy(bb1, Memory.mainram, 0x10000);
|
||||
BinaryReader br2 = new BinaryReader(new FileStream("dump2.dat", FileMode.Open));
|
||||
br2.Read(bb2, 0, 0x10000);
|
||||
br2.Close();
|
||||
Array.Copy(bb2, Neogeo.mainram2, 0x10000);
|
||||
BinaryReader br3 = new BinaryReader(new FileStream("dump3.dat", FileMode.Open));
|
||||
br3.Read(bb3, 0, 0x20000);
|
||||
br3.Close();
|
||||
for (i = 0; i < 0x10000; i++)
|
||||
{
|
||||
Neogeo.neogeo_videoram[i] = (ushort)(bb3[i * 2] + bb3[i * 2 + 1] * 0x100);
|
||||
}
|
||||
BinaryReader br4 = new BinaryReader(new FileStream("dump4.dat", FileMode.Open));
|
||||
br4.Read(bb4, 0, 0x4000);
|
||||
br4.Close();
|
||||
for (i = 0; i < 2; i++)
|
||||
{
|
||||
for (j = 0; j < 0x1000; j++)
|
||||
{
|
||||
Neogeo.palettes[i, j] = (ushort)(bb4[i * 0x2000 + j * 2] + bb4[i * 0x2000 + j * 2 + 1] * 0x100);
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
@ -1,7 +1,7 @@
|
||||
using cpu.z80;
|
||||
using System.Collections.Generic;
|
||||
|
||||
namespace MAME.Core.Common
|
||||
namespace MAME.Core
|
||||
{
|
||||
public enum CPUState
|
||||
{
|
||||
@ -12,7 +12,7 @@ namespace MAME.Core.Common
|
||||
STEP3,
|
||||
STOP,
|
||||
}
|
||||
public partial class z80Motion
|
||||
public partial class Z80Motion
|
||||
{
|
||||
private Disassembler disassembler;
|
||||
private bool bLogNew;
|
||||
@ -55,7 +55,7 @@ namespace MAME.Core.Common
|
||||
Z80A_STOP,
|
||||
}
|
||||
public static Z80AState z80State, z80FState;
|
||||
public z80Motion()
|
||||
public Z80Motion()
|
||||
{
|
||||
disassembler = new Disassembler();
|
||||
Disassembler.GenerateOpcodeSizes();
|
||||
|
13
MAME.Core/Properties/PublishProfiles/FolderProfile.pubxml
Normal file
13
MAME.Core/Properties/PublishProfiles/FolderProfile.pubxml
Normal file
@ -0,0 +1,13 @@
|
||||
<?xml version="1.0" encoding="utf-8"?>
|
||||
<!--
|
||||
https://go.microsoft.com/fwlink/?LinkID=208121.
|
||||
-->
|
||||
<Project>
|
||||
<PropertyGroup>
|
||||
<Configuration>Release</Configuration>
|
||||
<Platform>Any CPU</Platform>
|
||||
<PublishDir>bin\Release\netstandard2.0\publish\</PublishDir>
|
||||
<PublishProtocol>FileSystem</PublishProtocol>
|
||||
<_TargetId>Folder</_TargetId>
|
||||
</PropertyGroup>
|
||||
</Project>
|
@ -0,0 +1,10 @@
|
||||
<?xml version="1.0" encoding="utf-8"?>
|
||||
<!--
|
||||
https://go.microsoft.com/fwlink/?LinkID=208121.
|
||||
-->
|
||||
<Project>
|
||||
<PropertyGroup>
|
||||
<History>True|2024-08-30T07:41:53.2597006Z||;True|2024-08-29T17:00:35.4694695+08:00||;True|2024-08-29T16:40:23.7314446+08:00||;True|2024-08-29T16:17:16.6219882+08:00||;False|2024-08-29T15:55:34.5778980+08:00||;True|2024-08-29T15:34:15.1410739+08:00||;False|2024-08-29T15:31:15.0815441+08:00||;False|2024-08-29T15:29:46.6749330+08:00||;False|2024-08-29T15:27:48.9116490+08:00||;False|2024-08-29T15:27:23.2208875+08:00||;True|2024-08-28T16:12:23.3416224+08:00||;True|2024-08-28T13:18:21.7983285+08:00||;True|2024-08-28T12:54:14.9742502+08:00||;True|2024-08-28T12:09:37.5280942+08:00||;True|2024-08-28T12:07:03.6717540+08:00||;True|2024-08-07T18:02:59.4096796+08:00||;False|2024-08-07T18:02:44.0239078+08:00||;True|2024-07-31T17:00:23.0585720+08:00||;True|2024-07-31T17:00:19.8123170+08:00||;True|2024-07-30T20:51:40.9773933+08:00||;True|2024-07-30T17:04:12.3440051+08:00||;True|2024-07-30T17:01:28.0849009+08:00||;True|2024-07-30T10:36:57.5301145+08:00||;</History>
|
||||
<LastFailureDetails />
|
||||
</PropertyGroup>
|
||||
</Project>
|
47
MAME.Core/bin/Debug/netstandard2.0/MAME.Core.deps.json
Normal file
47
MAME.Core/bin/Debug/netstandard2.0/MAME.Core.deps.json
Normal file
@ -0,0 +1,47 @@
|
||||
{
|
||||
"runtimeTarget": {
|
||||
"name": ".NETStandard,Version=v2.0/",
|
||||
"signature": ""
|
||||
},
|
||||
"compilationOptions": {},
|
||||
"targets": {
|
||||
".NETStandard,Version=v2.0": {},
|
||||
".NETStandard,Version=v2.0/": {
|
||||
"MAME.Core/1.0.0": {
|
||||
"dependencies": {
|
||||
"NETStandard.Library": "2.0.3"
|
||||
},
|
||||
"runtime": {
|
||||
"MAME.Core.dll": {}
|
||||
}
|
||||
},
|
||||
"Microsoft.NETCore.Platforms/1.1.0": {},
|
||||
"NETStandard.Library/2.0.3": {
|
||||
"dependencies": {
|
||||
"Microsoft.NETCore.Platforms": "1.1.0"
|
||||
}
|
||||
}
|
||||
}
|
||||
},
|
||||
"libraries": {
|
||||
"MAME.Core/1.0.0": {
|
||||
"type": "project",
|
||||
"serviceable": false,
|
||||
"sha512": ""
|
||||
},
|
||||
"Microsoft.NETCore.Platforms/1.1.0": {
|
||||
"type": "package",
|
||||
"serviceable": true,
|
||||
"sha512": "sha512-kz0PEW2lhqygehI/d6XsPCQzD7ff7gUJaVGPVETX611eadGsA3A877GdSlU0LRVMCTH/+P3o2iDTak+S08V2+A==",
|
||||
"path": "microsoft.netcore.platforms/1.1.0",
|
||||
"hashPath": "microsoft.netcore.platforms.1.1.0.nupkg.sha512"
|
||||
},
|
||||
"NETStandard.Library/2.0.3": {
|
||||
"type": "package",
|
||||
"serviceable": true,
|
||||
"sha512": "sha512-st47PosZSHrjECdjeIzZQbzivYBJFv6P2nv4cj2ypdI204DO+vZ7l5raGMiX4eXMJ53RfOIg+/s4DHVZ54Nu2A==",
|
||||
"path": "netstandard.library/2.0.3",
|
||||
"hashPath": "netstandard.library.2.0.3.nupkg.sha512"
|
||||
}
|
||||
}
|
||||
}
|
BIN
MAME.Core/bin/Debug/netstandard2.0/MAME.Core.dll
Normal file
BIN
MAME.Core/bin/Debug/netstandard2.0/MAME.Core.dll
Normal file
Binary file not shown.
BIN
MAME.Core/bin/Debug/netstandard2.0/MAME.Core.pdb
Normal file
BIN
MAME.Core/bin/Debug/netstandard2.0/MAME.Core.pdb
Normal file
Binary file not shown.
47
MAME.Core/bin/Release/netstandard2.0/MAME.Core.deps.json
Normal file
47
MAME.Core/bin/Release/netstandard2.0/MAME.Core.deps.json
Normal file
@ -0,0 +1,47 @@
|
||||
{
|
||||
"runtimeTarget": {
|
||||
"name": ".NETStandard,Version=v2.0/",
|
||||
"signature": ""
|
||||
},
|
||||
"compilationOptions": {},
|
||||
"targets": {
|
||||
".NETStandard,Version=v2.0": {},
|
||||
".NETStandard,Version=v2.0/": {
|
||||
"MAME.Core/1.0.0": {
|
||||
"dependencies": {
|
||||
"NETStandard.Library": "2.0.3"
|
||||
},
|
||||
"runtime": {
|
||||
"MAME.Core.dll": {}
|
||||
}
|
||||
},
|
||||
"Microsoft.NETCore.Platforms/1.1.0": {},
|
||||
"NETStandard.Library/2.0.3": {
|
||||
"dependencies": {
|
||||
"Microsoft.NETCore.Platforms": "1.1.0"
|
||||
}
|
||||
}
|
||||
}
|
||||
},
|
||||
"libraries": {
|
||||
"MAME.Core/1.0.0": {
|
||||
"type": "project",
|
||||
"serviceable": false,
|
||||
"sha512": ""
|
||||
},
|
||||
"Microsoft.NETCore.Platforms/1.1.0": {
|
||||
"type": "package",
|
||||
"serviceable": true,
|
||||
"sha512": "sha512-kz0PEW2lhqygehI/d6XsPCQzD7ff7gUJaVGPVETX611eadGsA3A877GdSlU0LRVMCTH/+P3o2iDTak+S08V2+A==",
|
||||
"path": "microsoft.netcore.platforms/1.1.0",
|
||||
"hashPath": "microsoft.netcore.platforms.1.1.0.nupkg.sha512"
|
||||
},
|
||||
"NETStandard.Library/2.0.3": {
|
||||
"type": "package",
|
||||
"serviceable": true,
|
||||
"sha512": "sha512-st47PosZSHrjECdjeIzZQbzivYBJFv6P2nv4cj2ypdI204DO+vZ7l5raGMiX4eXMJ53RfOIg+/s4DHVZ54Nu2A==",
|
||||
"path": "netstandard.library/2.0.3",
|
||||
"hashPath": "netstandard.library.2.0.3.nupkg.sha512"
|
||||
}
|
||||
}
|
||||
}
|
BIN
MAME.Core/bin/Release/netstandard2.0/MAME.Core.dll
Normal file
BIN
MAME.Core/bin/Release/netstandard2.0/MAME.Core.dll
Normal file
Binary file not shown.
BIN
MAME.Core/bin/Release/netstandard2.0/MAME.Core.pdb
Normal file
BIN
MAME.Core/bin/Release/netstandard2.0/MAME.Core.pdb
Normal file
Binary file not shown.
@ -0,0 +1,47 @@
|
||||
{
|
||||
"runtimeTarget": {
|
||||
"name": ".NETStandard,Version=v2.0/",
|
||||
"signature": ""
|
||||
},
|
||||
"compilationOptions": {},
|
||||
"targets": {
|
||||
".NETStandard,Version=v2.0": {},
|
||||
".NETStandard,Version=v2.0/": {
|
||||
"MAME.Core/1.0.0": {
|
||||
"dependencies": {
|
||||
"NETStandard.Library": "2.0.3"
|
||||
},
|
||||
"runtime": {
|
||||
"MAME.Core.dll": {}
|
||||
}
|
||||
},
|
||||
"Microsoft.NETCore.Platforms/1.1.0": {},
|
||||
"NETStandard.Library/2.0.3": {
|
||||
"dependencies": {
|
||||
"Microsoft.NETCore.Platforms": "1.1.0"
|
||||
}
|
||||
}
|
||||
}
|
||||
},
|
||||
"libraries": {
|
||||
"MAME.Core/1.0.0": {
|
||||
"type": "project",
|
||||
"serviceable": false,
|
||||
"sha512": ""
|
||||
},
|
||||
"Microsoft.NETCore.Platforms/1.1.0": {
|
||||
"type": "package",
|
||||
"serviceable": true,
|
||||
"sha512": "sha512-kz0PEW2lhqygehI/d6XsPCQzD7ff7gUJaVGPVETX611eadGsA3A877GdSlU0LRVMCTH/+P3o2iDTak+S08V2+A==",
|
||||
"path": "microsoft.netcore.platforms/1.1.0",
|
||||
"hashPath": "microsoft.netcore.platforms.1.1.0.nupkg.sha512"
|
||||
},
|
||||
"NETStandard.Library/2.0.3": {
|
||||
"type": "package",
|
||||
"serviceable": true,
|
||||
"sha512": "sha512-st47PosZSHrjECdjeIzZQbzivYBJFv6P2nv4cj2ypdI204DO+vZ7l5raGMiX4eXMJ53RfOIg+/s4DHVZ54Nu2A==",
|
||||
"path": "netstandard.library/2.0.3",
|
||||
"hashPath": "netstandard.library.2.0.3.nupkg.sha512"
|
||||
}
|
||||
}
|
||||
}
|
BIN
MAME.Core/bin/Release/netstandard2.0/publish/MAME.Core.dll
Normal file
BIN
MAME.Core/bin/Release/netstandard2.0/publish/MAME.Core.dll
Normal file
Binary file not shown.
BIN
MAME.Core/bin/Release/netstandard2.0/publish/MAME.Core.pdb
Normal file
BIN
MAME.Core/bin/Release/netstandard2.0/publish/MAME.Core.pdb
Normal file
Binary file not shown.
@ -1,6 +1,7 @@
|
||||
using mame;
|
||||
using MAME.Core;
|
||||
using System;
|
||||
using System.IO;
|
||||
//using System.IO;
|
||||
|
||||
namespace cpu.m6502
|
||||
{
|
||||
@ -140,15 +141,6 @@ namespace cpu.m6502
|
||||
}
|
||||
public int m6502_execute(int cycles)
|
||||
{
|
||||
StreamWriter sw30 = null, sw31 = null;
|
||||
if (Cpuexec.bLog0 == 1 && Cpuexec.bLog02)
|
||||
{
|
||||
sw30 = new StreamWriter(@"\VS2008\compare1\compare1\bin\Debug\20.txt", true);
|
||||
}
|
||||
if (Cpuexec.bLog1 == 1 && Cpuexec.bLog12)
|
||||
{
|
||||
sw31 = new StreamWriter(@"\VS2008\compare1\compare1\bin\Debug\21.txt", true);
|
||||
}
|
||||
pendingCycles = cycles;
|
||||
do
|
||||
{
|
||||
@ -189,26 +181,8 @@ namespace cpu.m6502
|
||||
pending_irq = 1;
|
||||
}
|
||||
}
|
||||
if (Cpuexec.bLog0 == 1 && Cpuexec.bLog02)
|
||||
{
|
||||
sw30.WriteLine(ppc.d.ToString("x") + "\t" + op.ToString("x") + "\t" + pendingCycles.ToString("x"));
|
||||
sw30.WriteLine(sp.LowWord.ToString("x") + "\t" + p.ToString("x") + "\t" + a.ToString("x") + "\t" + x.ToString("x") + "\t" + y.ToString("x") + "\t" + pending_irq.ToString("x") + "\t" + after_cli.ToString("x") + "\t" + nmi_state.ToString("x") + "\t" + irq_state.ToString("x") + "\t" + so_state.ToString("x"));
|
||||
}
|
||||
if (Cpuexec.bLog1 == 1 && Cpuexec.bLog12)
|
||||
{
|
||||
sw31.WriteLine(ppc.d.ToString("x") + "\t" + op.ToString("x") + "\t" + pendingCycles.ToString("x"));
|
||||
sw31.WriteLine(sp.LowWord.ToString("x") + "\t" + p.ToString("x") + "\t" + a.ToString("x") + "\t" + x.ToString("x") + "\t" + y.ToString("x") + "\t" + pending_irq.ToString("x") + "\t" + after_cli.ToString("x") + "\t" + nmi_state.ToString("x") + "\t" + irq_state.ToString("x") + "\t" + so_state.ToString("x"));
|
||||
}
|
||||
}
|
||||
while (pendingCycles > 0);
|
||||
if (Cpuexec.bLog0 == 1 && Cpuexec.bLog02)
|
||||
{
|
||||
sw30.Close();
|
||||
}
|
||||
if (Cpuexec.bLog1 == 1 && Cpuexec.bLog12)
|
||||
{
|
||||
sw31.Close();
|
||||
}
|
||||
return cycles - pendingCycles;
|
||||
}
|
||||
public override void set_irq_line(int irqline, LineState state)
|
||||
@ -217,7 +191,7 @@ namespace cpu.m6502
|
||||
}
|
||||
public override void cpunum_set_input_line_and_vector(int cpunum, int line, LineState state, int vector)
|
||||
{
|
||||
Timer.timer_set_internal(Cpuint.cpunum_empty_event_queue, "cpunum_empty_event_queue");
|
||||
EmuTimer.timer_set_internal(Cpuint.cpunum_empty_event_queue, "cpunum_empty_event_queue");
|
||||
}
|
||||
private void m6502_set_irq_line(int irqline, LineState state)
|
||||
{
|
||||
|
@ -1,4 +1,4 @@
|
||||
using mame;
|
||||
using MAME.Core;
|
||||
|
||||
namespace cpu.m6502
|
||||
{
|
||||
|
@ -1,4 +1,4 @@
|
||||
using mame;
|
||||
using MAME.Core;
|
||||
using System;
|
||||
using System.IO;
|
||||
|
||||
@ -26,7 +26,7 @@ namespace cpu.m6800
|
||||
public byte trcsr, rmcr, rdr, tdr, rsr, tsr;
|
||||
public int rxbits, txbits, trcsr_read, tx;
|
||||
public M6800_TX_STATE txstate;
|
||||
public Timer.emu_timer m6800_rx_timer, m6800_tx_timer;
|
||||
public EmuTimer.emu_timer m6800_rx_timer, m6800_tx_timer;
|
||||
private byte TCSR_OLVL = 0x01, TCSR_IEDG = 0x02, TCSR_ETOI = 0x04, TCSR_EOCI = 0x08, TCSR_EICI = 0x10, TCSR_TOF = 0x20, TCSR_OCF = 0x40, TCSR_ICF = 0x80;
|
||||
protected byte M6800_WAI = 8, M6800_SLP = 0x10;
|
||||
private const byte M6800_IRQ_LINE = 0, M6800_TIN_LINE = 1;
|
||||
@ -246,8 +246,8 @@ namespace cpu.m6800
|
||||
cycles = cycles_63701;
|
||||
clock = 1536000;
|
||||
irq_callback = null;
|
||||
m6800_rx_timer = Timer.timer_alloc_common(m6800_rx_tick, "m6800_rx_tick", false);
|
||||
m6800_tx_timer = Timer.timer_alloc_common(m6800_tx_tick, "m6800_tx_tick", false);
|
||||
m6800_rx_timer = EmuTimer.timer_alloc_common(m6800_rx_tick, "m6800_rx_tick", false);
|
||||
m6800_tx_timer = EmuTimer.timer_alloc_common(m6800_tx_tick, "m6800_tx_tick", false);
|
||||
}
|
||||
public override void Reset()
|
||||
{
|
||||
@ -844,8 +844,8 @@ namespace cpu.m6800
|
||||
ram_ctrl |= 0x40;
|
||||
trcsr = M6800_TRCSR_TDRE;
|
||||
rmcr = 0;
|
||||
Timer.timer_enable(m6800_rx_timer, false);
|
||||
Timer.timer_enable(m6800_tx_timer, false);
|
||||
EmuTimer.timer_enable(m6800_rx_timer, false);
|
||||
EmuTimer.timer_enable(m6800_tx_timer, false);
|
||||
txstate = M6800_TX_STATE.INIT;
|
||||
txbits = rxbits = 0;
|
||||
trcsr_read = 0;
|
||||
@ -905,7 +905,7 @@ namespace cpu.m6800
|
||||
}
|
||||
public override void cpunum_set_input_line_and_vector(int cpunum, int line, LineState state, int vector)
|
||||
{
|
||||
Timer.timer_set_internal(Cpuint.cpunum_empty_event_queue, "cpunum_empty_event_queue");
|
||||
EmuTimer.timer_set_internal(Cpuint.cpunum_empty_event_queue, "cpunum_empty_event_queue");
|
||||
}
|
||||
public override int ExecuteCycles(int cycles)
|
||||
{
|
||||
@ -1167,16 +1167,16 @@ namespace cpu.m6800
|
||||
{
|
||||
case 0:
|
||||
case 3: // not implemented
|
||||
Timer.timer_enable(m6800_rx_timer, false);
|
||||
Timer.timer_enable(m6800_tx_timer, false);
|
||||
EmuTimer.timer_enable(m6800_rx_timer, false);
|
||||
EmuTimer.timer_enable(m6800_tx_timer, false);
|
||||
break;
|
||||
|
||||
case 1:
|
||||
case 2:
|
||||
{
|
||||
int divisor = M6800_RMCR_SS[rmcr & M6800_RMCR_SS_MASK];
|
||||
Timer.timer_adjust_periodic(m6800_rx_timer, Attotime.ATTOTIME_ZERO, new Atime(0, (long)(1e18 / (clock / divisor))));
|
||||
Timer.timer_adjust_periodic(m6800_tx_timer, Attotime.ATTOTIME_ZERO, new Atime(0, (long)(1e18 / (clock / divisor))));
|
||||
EmuTimer.timer_adjust_periodic(m6800_rx_timer, Attotime.ATTOTIME_ZERO, new Atime(0, (long)(1e18 / (clock / divisor))));
|
||||
EmuTimer.timer_adjust_periodic(m6800_tx_timer, Attotime.ATTOTIME_ZERO, new Atime(0, (long)(1e18 / (clock / divisor))));
|
||||
}
|
||||
break;
|
||||
}
|
||||
@ -1345,8 +1345,8 @@ namespace cpu.m6800
|
||||
};
|
||||
clock = 1000000;
|
||||
irq_callback = Cpuint.cpu_3_irq_callback;
|
||||
m6800_rx_timer = Timer.timer_alloc_common(m6800_rx_tick, "m6800_rx_tick", false);
|
||||
m6800_tx_timer = Timer.timer_alloc_common(m6800_tx_tick, "m6800_tx_tick", false);
|
||||
m6800_rx_timer = EmuTimer.timer_alloc_common(m6800_rx_tick, "m6800_rx_tick", false);
|
||||
m6800_tx_timer = EmuTimer.timer_alloc_common(m6800_tx_tick, "m6800_tx_tick", false);
|
||||
}
|
||||
public override int ExecuteCycles(int cycles)
|
||||
{
|
||||
|
@ -1,4 +1,4 @@
|
||||
using mame;
|
||||
using MAME.Core;
|
||||
|
||||
namespace cpu.m6800
|
||||
{
|
||||
|
@ -1,4 +1,4 @@
|
||||
using mame;
|
||||
using MAME.Core;
|
||||
using System;
|
||||
using System.Globalization;
|
||||
using System.IO;
|
||||
@ -192,7 +192,7 @@ namespace cpu.m68000
|
||||
}
|
||||
public override void cpunum_set_input_line_and_vector(int cpunum, int line, LineState state, int vector)
|
||||
{
|
||||
Timer.timer_set_internal(Cpuint.cpunum_empty_event_queue, "cpunum_empty_event_queue");
|
||||
EmuTimer.timer_set_internal(Cpuint.cpunum_empty_event_queue, "cpunum_empty_event_queue");
|
||||
}
|
||||
public void Pulse_Reset()
|
||||
{
|
||||
|
@ -1,4 +1,4 @@
|
||||
using mame;
|
||||
using MAME.Core;
|
||||
using System;
|
||||
using System.IO;
|
||||
|
||||
@ -540,7 +540,7 @@ namespace cpu.m6805
|
||||
}
|
||||
public override void cpunum_set_input_line_and_vector(int cpunum, int line, LineState state, int vector)
|
||||
{
|
||||
Timer.timer_set_internal(Cpuint.cpunum_empty_event_queue, "cpunum_empty_event_queue");
|
||||
EmuTimer.timer_set_internal(Cpuint.cpunum_empty_event_queue, "cpunum_empty_event_queue");
|
||||
}
|
||||
public override int ExecuteCycles(int cycles)
|
||||
{
|
||||
|
@ -1,4 +1,4 @@
|
||||
using mame;
|
||||
using MAME.Core;
|
||||
|
||||
namespace cpu.m6805
|
||||
{
|
||||
|
@ -1,4 +1,4 @@
|
||||
using mame;
|
||||
using MAME.Core;
|
||||
using System;
|
||||
using System.IO;
|
||||
|
||||
@ -555,7 +555,7 @@ namespace cpu.m6809
|
||||
}
|
||||
public override void cpunum_set_input_line_and_vector(int cpunum, int line, LineState state, int vector)
|
||||
{
|
||||
Timer.timer_set_internal(Cpuint.cpunum_empty_event_queue, "cpunum_empty_event_queue");
|
||||
EmuTimer.timer_set_internal(Cpuint.cpunum_empty_event_queue, "cpunum_empty_event_queue");
|
||||
}
|
||||
public override int ExecuteCycles(int cycles)
|
||||
{
|
||||
|
@ -1,4 +1,4 @@
|
||||
using mame;
|
||||
using MAME.Core;
|
||||
|
||||
namespace cpu.m6809
|
||||
{
|
||||
|
@ -1,4 +1,4 @@
|
||||
using mame;
|
||||
using MAME.Core;
|
||||
using System;
|
||||
using System.IO;
|
||||
|
||||
@ -61,7 +61,7 @@ namespace cpu.nec
|
||||
{
|
||||
if (line >= 0 && line < 35)
|
||||
{
|
||||
Cpuint.lirq.Add(new irq(cpunum, line, state, vector, Timer.get_current_time()));
|
||||
Cpuint.lirq.Add(new irq(cpunum, line, state, vector, EmuTimer.get_current_time()));
|
||||
int event_index = Cpuint.input_event_index[cpunum, line]++;
|
||||
if (event_index >= 35)
|
||||
{
|
||||
@ -74,7 +74,7 @@ namespace cpu.nec
|
||||
//Cpuint.input_event_queue[cpunum][line][event_index] = input_event;
|
||||
//if (event_index == 0)
|
||||
{
|
||||
Timer.timer_set_internal(Cpuint.cpunum_empty_event_queue, "cpunum_empty_event_queue");
|
||||
EmuTimer.timer_set_internal(Cpuint.cpunum_empty_event_queue, "cpunum_empty_event_queue");
|
||||
}
|
||||
}
|
||||
}
|
||||
|
@ -1,4 +1,4 @@
|
||||
using mame;
|
||||
using MAME.Core;
|
||||
using System;
|
||||
using System.Globalization;
|
||||
using System.IO;
|
||||
@ -86,7 +86,7 @@ namespace cpu.z80
|
||||
public override void cpunum_set_input_line_and_vector(int cpunum, int line, LineState state, int vector)
|
||||
{
|
||||
Atime time1;
|
||||
time1 = Timer.get_current_time();
|
||||
time1 = EmuTimer.get_current_time();
|
||||
bool b1 = false;
|
||||
foreach (irq irq1 in Cpuint.lirq)
|
||||
{
|
||||
@ -109,7 +109,7 @@ namespace cpu.z80
|
||||
}
|
||||
else
|
||||
{
|
||||
Timer.timer_set_internal(Cpuint.cpunum_empty_event_queue, "cpunum_empty_event_queue");
|
||||
EmuTimer.timer_set_internal(Cpuint.cpunum_empty_event_queue, "cpunum_empty_event_queue");
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -1,4 +1,4 @@
|
||||
namespace mame
|
||||
namespace MAME.Core
|
||||
{
|
||||
public struct Atime
|
||||
{
|
||||
|
@ -5,11 +5,10 @@ using cpu.m6805;
|
||||
using cpu.m6809;
|
||||
using cpu.nec;
|
||||
using cpu.z80;
|
||||
using MAME.Core.Common;
|
||||
using System;
|
||||
using System.IO;
|
||||
|
||||
namespace mame
|
||||
namespace MAME.Core
|
||||
{
|
||||
public class cpuexec_data
|
||||
{
|
||||
@ -26,7 +25,7 @@ namespace mame
|
||||
public int cycles_running;
|
||||
public int cycles_stolen;
|
||||
public int icount;
|
||||
public Timer.emu_timer partial_frame_timer;
|
||||
public EmuTimer.emu_timer partial_frame_timer;
|
||||
public Atime partial_frame_period;
|
||||
public virtual ulong TotalExecutedCycles { get; set; }
|
||||
public virtual int PendingCycles { get; set; }
|
||||
@ -43,14 +42,14 @@ namespace mame
|
||||
public static bool b11 = true, b12 = true, b13 = true, b14 = true;
|
||||
public static int iloops, activecpu, icpu, ncpu, iloops2;
|
||||
public static cpuexec_data[] cpu;
|
||||
public static Timer.emu_timer timedint_timer;
|
||||
public static EmuTimer.emu_timer timedint_timer;
|
||||
public static Atime timedint_period, timeslice_period;
|
||||
public delegate void vblank_delegate();
|
||||
public static vblank_delegate vblank_interrupt;
|
||||
public static Action vblank_interrupt2;
|
||||
public static Timer.emu_timer interleave_boost_timer;
|
||||
public static Timer.emu_timer interleave_boost_timer_end;
|
||||
public static Timer.emu_timer timeslice_timer;
|
||||
public static EmuTimer.emu_timer interleave_boost_timer;
|
||||
public static EmuTimer.emu_timer interleave_boost_timer_end;
|
||||
public static EmuTimer.emu_timer timeslice_timer;
|
||||
public static Atime perfect_interleave;
|
||||
public static int vblank_interrupts_per_frame;
|
||||
public static void cpuexec_init()
|
||||
@ -2118,46 +2117,46 @@ namespace mame
|
||||
case "Neo Geo":
|
||||
case "PGM":
|
||||
case "Taito B":
|
||||
m68000Motion.m68000State = m68000Motion.M68000State.M68000_RUN;
|
||||
MC68000.m1.debugger_start_cpu_hook_callback = Machine.FORM.m68000motion.m68000_start_debug;
|
||||
MC68000.m1.debugger_stop_cpu_hook_callback = Machine.FORM.m68000motion.m68000_stop_debug;
|
||||
z80Motion.z80State = z80Motion.Z80AState.Z80A_RUN;
|
||||
Z80A.zz1[0].debugger_start_cpu_hook_callback = Machine.FORM.z80motion.z80_start_debug;
|
||||
Z80A.zz1[0].debugger_stop_cpu_hook_callback = Machine.FORM.z80motion.z80_stop_debug;
|
||||
M68000Motion.m68000State = M68000Motion.M68000State.M68000_RUN;
|
||||
MC68000.m1.debugger_start_cpu_hook_callback = Machine.mainMotion.m68000motion.m68000_start_debug;
|
||||
MC68000.m1.debugger_stop_cpu_hook_callback = Machine.mainMotion.m68000motion.m68000_stop_debug;
|
||||
Z80Motion.z80State = Z80Motion.Z80AState.Z80A_RUN;
|
||||
Z80A.zz1[0].debugger_start_cpu_hook_callback = Machine.mainMotion.z80motion.z80_start_debug;
|
||||
Z80A.zz1[0].debugger_stop_cpu_hook_callback = Machine.mainMotion.z80motion.z80_stop_debug;
|
||||
break;
|
||||
case "Tehkan":
|
||||
z80Motion.z80State = z80Motion.Z80AState.Z80A_RUN;
|
||||
Z80A.zz1[0].debugger_start_cpu_hook_callback = Machine.FORM.z80motion.z80_start_debug;
|
||||
Z80A.zz1[0].debugger_stop_cpu_hook_callback = Machine.FORM.z80motion.z80_stop_debug;
|
||||
Z80Motion.z80State = Z80Motion.Z80AState.Z80A_RUN;
|
||||
Z80A.zz1[0].debugger_start_cpu_hook_callback = Machine.mainMotion.z80motion.z80_start_debug;
|
||||
Z80A.zz1[0].debugger_stop_cpu_hook_callback = Machine.mainMotion.z80motion.z80_stop_debug;
|
||||
Z80A.zz1[1].debugger_start_cpu_hook_callback = null_callback;
|
||||
Z80A.zz1[1].debugger_stop_cpu_hook_callback = null_callback;
|
||||
break;
|
||||
case "IGS011":
|
||||
m68000Motion.m68000State = m68000Motion.M68000State.M68000_RUN;
|
||||
MC68000.m1.debugger_start_cpu_hook_callback = Machine.FORM.m68000motion.m68000_start_debug;
|
||||
MC68000.m1.debugger_stop_cpu_hook_callback = Machine.FORM.m68000motion.m68000_stop_debug;
|
||||
M68000Motion.m68000State = M68000Motion.M68000State.M68000_RUN;
|
||||
MC68000.m1.debugger_start_cpu_hook_callback = Machine.mainMotion.m68000motion.m68000_start_debug;
|
||||
MC68000.m1.debugger_stop_cpu_hook_callback = Machine.mainMotion.m68000motion.m68000_stop_debug;
|
||||
break;
|
||||
case "SunA8":
|
||||
z80Motion.z80State = z80Motion.Z80AState.Z80A_RUN;
|
||||
Z80A.zz1[0].debugger_start_cpu_hook_callback = Machine.FORM.z80motion.z80_start_debug;
|
||||
Z80A.zz1[0].debugger_stop_cpu_hook_callback = Machine.FORM.z80motion.z80_stop_debug;
|
||||
Z80Motion.z80State = Z80Motion.Z80AState.Z80A_RUN;
|
||||
Z80A.zz1[0].debugger_start_cpu_hook_callback = Machine.mainMotion.z80motion.z80_start_debug;
|
||||
Z80A.zz1[0].debugger_stop_cpu_hook_callback = Machine.mainMotion.z80motion.z80_stop_debug;
|
||||
Z80A.zz1[1].debugger_start_cpu_hook_callback = null_callback;
|
||||
Z80A.zz1[1].debugger_stop_cpu_hook_callback = null_callback;
|
||||
break;
|
||||
case "Namco System 1":
|
||||
m6809Motion.m6809State = CPUState.RUN;
|
||||
M6809Motion.m6809State = CPUState.RUN;
|
||||
M6809.mm1[0].DisassemblerInit();
|
||||
M6809.mm1[0].debugger_start_cpu_hook_callback = Machine.FORM.m6809motion.m6809_start_debug;
|
||||
M6809.mm1[0].debugger_stop_cpu_hook_callback = Machine.FORM.m6809motion.m6809_stop_debug;
|
||||
M6809.mm1[0].debugger_start_cpu_hook_callback = Machine.mainMotion.m6809motion.m6809_start_debug;
|
||||
M6809.mm1[0].debugger_stop_cpu_hook_callback = Machine.mainMotion.m6809motion.m6809_stop_debug;
|
||||
M6809.mm1[1].debugger_start_cpu_hook_callback = null_callback;
|
||||
M6809.mm1[1].debugger_stop_cpu_hook_callback = null_callback;
|
||||
M6809.mm1[2].debugger_start_cpu_hook_callback = null_callback;
|
||||
M6809.mm1[2].debugger_stop_cpu_hook_callback = null_callback;
|
||||
break;
|
||||
case "M72":
|
||||
z80Motion.z80State = z80Motion.Z80AState.Z80A_RUN;
|
||||
Z80A.zz1[0].debugger_start_cpu_hook_callback = Machine.FORM.z80motion.z80_start_debug;
|
||||
Z80A.zz1[0].debugger_stop_cpu_hook_callback = Machine.FORM.z80motion.z80_stop_debug;
|
||||
Z80Motion.z80State = Z80Motion.Z80AState.Z80A_RUN;
|
||||
Z80A.zz1[0].debugger_start_cpu_hook_callback = Machine.mainMotion.z80motion.z80_start_debug;
|
||||
Z80A.zz1[0].debugger_stop_cpu_hook_callback = Machine.mainMotion.z80motion.z80_stop_debug;
|
||||
break;
|
||||
case "M92":
|
||||
break;
|
||||
@ -2186,35 +2185,35 @@ namespace mame
|
||||
case "boblcave":
|
||||
case "bublcave11":
|
||||
case "bublcave10":
|
||||
z80Motion.z80State = z80Motion.Z80AState.Z80A_RUN;
|
||||
Z80A.zz1[0].debugger_start_cpu_hook_callback = Machine.FORM.z80motion.z80_start_debug;
|
||||
Z80A.zz1[0].debugger_stop_cpu_hook_callback = Machine.FORM.z80motion.z80_stop_debug;
|
||||
Z80A.zz1[1].debugger_start_cpu_hook_callback = Machine.FORM.z80motion.z80_start_debug;
|
||||
Z80A.zz1[1].debugger_stop_cpu_hook_callback = Machine.FORM.z80motion.z80_stop_debug;
|
||||
Z80A.zz1[2].debugger_start_cpu_hook_callback = Machine.FORM.z80motion.z80_start_debug;
|
||||
Z80A.zz1[2].debugger_stop_cpu_hook_callback = Machine.FORM.z80motion.z80_stop_debug;
|
||||
Z80Motion.z80State = Z80Motion.Z80AState.Z80A_RUN;
|
||||
Z80A.zz1[0].debugger_start_cpu_hook_callback = Machine.mainMotion.z80motion.z80_start_debug;
|
||||
Z80A.zz1[0].debugger_stop_cpu_hook_callback = Machine.mainMotion.z80motion.z80_stop_debug;
|
||||
Z80A.zz1[1].debugger_start_cpu_hook_callback = Machine.mainMotion.z80motion.z80_start_debug;
|
||||
Z80A.zz1[1].debugger_stop_cpu_hook_callback = Machine.mainMotion.z80motion.z80_stop_debug;
|
||||
Z80A.zz1[2].debugger_start_cpu_hook_callback = Machine.mainMotion.z80motion.z80_start_debug;
|
||||
Z80A.zz1[2].debugger_stop_cpu_hook_callback = Machine.mainMotion.z80motion.z80_stop_debug;
|
||||
break;
|
||||
case "opwolf":
|
||||
case "opwolfa":
|
||||
case "opwolfj":
|
||||
case "opwolfu":
|
||||
case "opwolfp":
|
||||
m68000Motion.m68000State = m68000Motion.M68000State.M68000_RUN;
|
||||
MC68000.m1.debugger_start_cpu_hook_callback = Machine.FORM.m68000motion.m68000_start_debug;
|
||||
MC68000.m1.debugger_stop_cpu_hook_callback = Machine.FORM.m68000motion.m68000_stop_debug;
|
||||
z80Motion.z80State = z80Motion.Z80AState.Z80A_RUN;
|
||||
Z80A.zz1[0].debugger_start_cpu_hook_callback = Machine.FORM.z80motion.z80_start_debug;
|
||||
Z80A.zz1[0].debugger_stop_cpu_hook_callback = Machine.FORM.z80motion.z80_stop_debug;
|
||||
M68000Motion.m68000State = M68000Motion.M68000State.M68000_RUN;
|
||||
MC68000.m1.debugger_start_cpu_hook_callback = Machine.mainMotion.m68000motion.m68000_start_debug;
|
||||
MC68000.m1.debugger_stop_cpu_hook_callback = Machine.mainMotion.m68000motion.m68000_stop_debug;
|
||||
Z80Motion.z80State = Z80Motion.Z80AState.Z80A_RUN;
|
||||
Z80A.zz1[0].debugger_start_cpu_hook_callback = Machine.mainMotion.z80motion.z80_start_debug;
|
||||
Z80A.zz1[0].debugger_stop_cpu_hook_callback = Machine.mainMotion.z80motion.z80_stop_debug;
|
||||
break;
|
||||
case "opwolfb":
|
||||
m68000Motion.m68000State = m68000Motion.M68000State.M68000_RUN;
|
||||
MC68000.m1.debugger_start_cpu_hook_callback = Machine.FORM.m68000motion.m68000_start_debug;
|
||||
MC68000.m1.debugger_stop_cpu_hook_callback = Machine.FORM.m68000motion.m68000_stop_debug;
|
||||
z80Motion.z80State = z80Motion.Z80AState.Z80A_RUN;
|
||||
Z80A.zz1[0].debugger_start_cpu_hook_callback = Machine.FORM.z80motion.z80_start_debug;
|
||||
Z80A.zz1[0].debugger_stop_cpu_hook_callback = Machine.FORM.z80motion.z80_stop_debug;
|
||||
Z80A.zz1[1].debugger_start_cpu_hook_callback = Machine.FORM.z80motion.z80_start_debug;
|
||||
Z80A.zz1[1].debugger_stop_cpu_hook_callback = Machine.FORM.z80motion.z80_stop_debug;
|
||||
M68000Motion.m68000State = M68000Motion.M68000State.M68000_RUN;
|
||||
MC68000.m1.debugger_start_cpu_hook_callback = Machine.mainMotion.m68000motion.m68000_start_debug;
|
||||
MC68000.m1.debugger_stop_cpu_hook_callback = Machine.mainMotion.m68000motion.m68000_stop_debug;
|
||||
Z80Motion.z80State = Z80Motion.Z80AState.Z80A_RUN;
|
||||
Z80A.zz1[0].debugger_start_cpu_hook_callback = Machine.mainMotion.z80motion.z80_start_debug;
|
||||
Z80A.zz1[0].debugger_stop_cpu_hook_callback = Machine.mainMotion.z80motion.z80_stop_debug;
|
||||
Z80A.zz1[1].debugger_start_cpu_hook_callback = Machine.mainMotion.z80motion.z80_start_debug;
|
||||
Z80A.zz1[1].debugger_stop_cpu_hook_callback = Machine.mainMotion.z80motion.z80_stop_debug;
|
||||
break;
|
||||
}
|
||||
break;
|
||||
@ -2222,17 +2221,17 @@ namespace mame
|
||||
switch (Machine.sName)
|
||||
{
|
||||
case "cuebrick":
|
||||
m68000Motion.m68000State = m68000Motion.M68000State.M68000_RUN;
|
||||
MC68000.m1.debugger_start_cpu_hook_callback = Machine.FORM.m68000motion.m68000_start_debug;
|
||||
MC68000.m1.debugger_stop_cpu_hook_callback = Machine.FORM.m68000motion.m68000_stop_debug;
|
||||
M68000Motion.m68000State = M68000Motion.M68000State.M68000_RUN;
|
||||
MC68000.m1.debugger_start_cpu_hook_callback = Machine.mainMotion.m68000motion.m68000_start_debug;
|
||||
MC68000.m1.debugger_stop_cpu_hook_callback = Machine.mainMotion.m68000motion.m68000_stop_debug;
|
||||
break;
|
||||
default:
|
||||
m68000Motion.m68000State = m68000Motion.M68000State.M68000_RUN;
|
||||
MC68000.m1.debugger_start_cpu_hook_callback = Machine.FORM.m68000motion.m68000_start_debug;
|
||||
MC68000.m1.debugger_stop_cpu_hook_callback = Machine.FORM.m68000motion.m68000_stop_debug;
|
||||
z80Motion.z80State = z80Motion.Z80AState.Z80A_RUN;
|
||||
Z80A.zz1[0].debugger_start_cpu_hook_callback = Machine.FORM.z80motion.z80_start_debug;
|
||||
Z80A.zz1[0].debugger_stop_cpu_hook_callback = Machine.FORM.z80motion.z80_stop_debug;
|
||||
M68000Motion.m68000State = M68000Motion.M68000State.M68000_RUN;
|
||||
MC68000.m1.debugger_start_cpu_hook_callback = Machine.mainMotion.m68000motion.m68000_start_debug;
|
||||
MC68000.m1.debugger_stop_cpu_hook_callback = Machine.mainMotion.m68000motion.m68000_stop_debug;
|
||||
Z80Motion.z80State = Z80Motion.Z80AState.Z80A_RUN;
|
||||
Z80A.zz1[0].debugger_start_cpu_hook_callback = Machine.mainMotion.z80motion.z80_start_debug;
|
||||
Z80A.zz1[0].debugger_stop_cpu_hook_callback = Machine.mainMotion.z80motion.z80_stop_debug;
|
||||
break;
|
||||
}
|
||||
break;
|
||||
@ -2250,13 +2249,13 @@ namespace mame
|
||||
case "makaimurc":
|
||||
case "makaimurg":
|
||||
case "diamond":
|
||||
m6809Motion.m6809State = CPUState.RUN;
|
||||
M6809Motion.m6809State = CPUState.RUN;
|
||||
M6809.mm1[0].DisassemblerInit();
|
||||
M6809.mm1[0].debugger_start_cpu_hook_callback = Machine.FORM.m6809motion.m6809_start_debug;
|
||||
M6809.mm1[0].debugger_stop_cpu_hook_callback = Machine.FORM.m6809motion.m6809_stop_debug;
|
||||
z80Motion.z80State = z80Motion.Z80AState.Z80A_RUN;
|
||||
Z80A.zz1[0].debugger_start_cpu_hook_callback = Machine.FORM.z80motion.z80_start_debug;
|
||||
Z80A.zz1[0].debugger_stop_cpu_hook_callback = Machine.FORM.z80motion.z80_stop_debug;
|
||||
M6809.mm1[0].debugger_start_cpu_hook_callback = Machine.mainMotion.m6809motion.m6809_start_debug;
|
||||
M6809.mm1[0].debugger_stop_cpu_hook_callback = Machine.mainMotion.m6809motion.m6809_stop_debug;
|
||||
Z80Motion.z80State = Z80Motion.Z80AState.Z80A_RUN;
|
||||
Z80A.zz1[0].debugger_start_cpu_hook_callback = Machine.mainMotion.z80motion.z80_start_debug;
|
||||
Z80A.zz1[0].debugger_stop_cpu_hook_callback = Machine.mainMotion.z80motion.z80_stop_debug;
|
||||
break;
|
||||
case "sf":
|
||||
case "sfua":
|
||||
@ -2264,14 +2263,14 @@ namespace mame
|
||||
case "sfjan":
|
||||
case "sfan":
|
||||
case "sfp":
|
||||
m68000Motion.m68000State = m68000Motion.M68000State.M68000_RUN;
|
||||
MC68000.m1.debugger_start_cpu_hook_callback = Machine.FORM.m68000motion.m68000_start_debug;
|
||||
MC68000.m1.debugger_stop_cpu_hook_callback = Machine.FORM.m68000motion.m68000_stop_debug;
|
||||
z80Motion.z80State = z80Motion.Z80AState.Z80A_RUN;
|
||||
Z80A.zz1[0].debugger_start_cpu_hook_callback = Machine.FORM.z80motion.z80_start_debug;
|
||||
Z80A.zz1[0].debugger_stop_cpu_hook_callback = Machine.FORM.z80motion.z80_stop_debug;
|
||||
Z80A.zz1[1].debugger_start_cpu_hook_callback = Machine.FORM.z80motion.z80_start_debug;
|
||||
Z80A.zz1[1].debugger_stop_cpu_hook_callback = Machine.FORM.z80motion.z80_stop_debug;
|
||||
M68000Motion.m68000State = M68000Motion.M68000State.M68000_RUN;
|
||||
MC68000.m1.debugger_start_cpu_hook_callback = Machine.mainMotion.m68000motion.m68000_start_debug;
|
||||
MC68000.m1.debugger_stop_cpu_hook_callback = Machine.mainMotion.m68000motion.m68000_stop_debug;
|
||||
Z80Motion.z80State = Z80Motion.Z80AState.Z80A_RUN;
|
||||
Z80A.zz1[0].debugger_start_cpu_hook_callback = Machine.mainMotion.z80motion.z80_start_debug;
|
||||
Z80A.zz1[0].debugger_stop_cpu_hook_callback = Machine.mainMotion.z80motion.z80_stop_debug;
|
||||
Z80A.zz1[1].debugger_start_cpu_hook_callback = Machine.mainMotion.z80motion.z80_start_debug;
|
||||
Z80A.zz1[1].debugger_stop_cpu_hook_callback = Machine.mainMotion.z80motion.z80_stop_debug;
|
||||
break;
|
||||
}
|
||||
break;
|
||||
@ -2295,7 +2294,7 @@ namespace mame
|
||||
Generic.irq_1_0_line_hold();
|
||||
if (iloops2 > 1)
|
||||
{
|
||||
Timer.timer_adjust_periodic(Cpuexec.cpu[1].partial_frame_timer, Cpuexec.cpu[1].partial_frame_period, Attotime.ATTOTIME_NEVER);
|
||||
EmuTimer.timer_adjust_periodic(Cpuexec.cpu[1].partial_frame_timer, Cpuexec.cpu[1].partial_frame_period, Attotime.ATTOTIME_NEVER);
|
||||
}
|
||||
}
|
||||
public static byte null_callback1(int address)
|
||||
@ -2321,12 +2320,12 @@ namespace mame
|
||||
case "CPS-1(QSound)":
|
||||
case "CPS2":
|
||||
timedint_period = new Atime(0, (long)(1e18 / 250));
|
||||
timedint_timer = Timer.timer_alloc_common(Generic.irq_1_0_line_hold, "irq_1_0_line_hold", false);
|
||||
Timer.timer_adjust_periodic(timedint_timer, timedint_period, timedint_period);
|
||||
timedint_timer = EmuTimer.timer_alloc_common(Generic.irq_1_0_line_hold, "irq_1_0_line_hold", false);
|
||||
EmuTimer.timer_adjust_periodic(timedint_timer, timedint_period, timedint_period);
|
||||
break;
|
||||
case "Neo Geo":
|
||||
interleave_boost_timer = Timer.timer_alloc_common(null_callback, "boost_callback", false);
|
||||
interleave_boost_timer_end = Timer.timer_alloc_common(end_interleave_boost, "end_interleave_boost", false);
|
||||
interleave_boost_timer = EmuTimer.timer_alloc_common(null_callback, "boost_callback", false);
|
||||
interleave_boost_timer_end = EmuTimer.timer_alloc_common(end_interleave_boost, "end_interleave_boost", false);
|
||||
break;
|
||||
case "CPS1":
|
||||
case "Namco System 1":
|
||||
@ -2372,8 +2371,8 @@ namespace mame
|
||||
case "bublcave11":
|
||||
case "bublcave10":
|
||||
timeslice_period = new Atime(0, Video.screenstate.frame_period / 100);
|
||||
timeslice_timer = Timer.timer_alloc_common(cpu_timeslicecallback, "cpu_timeslicecallback", false);
|
||||
Timer.timer_adjust_periodic(timeslice_timer, timeslice_period, timeslice_period);
|
||||
timeslice_timer = EmuTimer.timer_alloc_common(cpu_timeslicecallback, "cpu_timeslicecallback", false);
|
||||
EmuTimer.timer_adjust_periodic(timeslice_timer, timeslice_period, timeslice_period);
|
||||
break;
|
||||
case "opwolf":
|
||||
case "opwolfa":
|
||||
@ -2382,15 +2381,15 @@ namespace mame
|
||||
case "opwolfb":
|
||||
case "opwolfp":
|
||||
timeslice_period = new Atime(0, Video.screenstate.frame_period / 10);
|
||||
timeslice_timer = Timer.timer_alloc_common(cpu_timeslicecallback, "cpu_timeslicecallback", false);
|
||||
Timer.timer_adjust_periodic(timeslice_timer, timeslice_period, timeslice_period);
|
||||
timeslice_timer = EmuTimer.timer_alloc_common(cpu_timeslicecallback, "cpu_timeslicecallback", false);
|
||||
EmuTimer.timer_adjust_periodic(timeslice_timer, timeslice_period, timeslice_period);
|
||||
break;
|
||||
}
|
||||
break;
|
||||
case "Taito B":
|
||||
timeslice_period = new Atime(0, Video.screenstate.frame_period / 10);
|
||||
timeslice_timer = Timer.timer_alloc_common(cpu_timeslicecallback, "cpu_timeslicecallback", false);
|
||||
Timer.timer_adjust_periodic(timeslice_timer, timeslice_period, timeslice_period);
|
||||
timeslice_timer = EmuTimer.timer_alloc_common(cpu_timeslicecallback, "cpu_timeslicecallback", false);
|
||||
EmuTimer.timer_adjust_periodic(timeslice_timer, timeslice_period, timeslice_period);
|
||||
break;
|
||||
case "Capcom":
|
||||
switch (Machine.sName)
|
||||
@ -2415,8 +2414,8 @@ namespace mame
|
||||
case "sfan":
|
||||
case "sfp":
|
||||
timedint_period = new Atime(0, (long)(1e18 / 8000));
|
||||
timedint_timer = Timer.timer_alloc_common(Generic.irq_2_0_line_hold, "irq_2_0_line_hold", false);
|
||||
Timer.timer_adjust_periodic(timedint_timer, timedint_period, timedint_period);
|
||||
timedint_timer = EmuTimer.timer_alloc_common(Generic.irq_2_0_line_hold, "irq_2_0_line_hold", false);
|
||||
EmuTimer.timer_adjust_periodic(timedint_timer, timedint_period, timedint_period);
|
||||
break;
|
||||
}
|
||||
break;
|
||||
@ -2424,8 +2423,8 @@ namespace mame
|
||||
}
|
||||
public static void cpuexec_timeslice()
|
||||
{
|
||||
Atime target = Timer.lt[0].expire;
|
||||
Atime tbase = Timer.global_basetime;
|
||||
Atime target = EmuTimer.lt[0].expire;
|
||||
Atime tbase = EmuTimer.global_basetime;
|
||||
int ran;
|
||||
Atime at;
|
||||
int i, j;
|
||||
@ -2471,19 +2470,19 @@ namespace mame
|
||||
cpu[icpu].suspend = cpu[icpu].nextsuspend;
|
||||
cpu[icpu].eatcycles = cpu[icpu].nexteatcycles;
|
||||
}
|
||||
Timer.timer_set_global_time(target);
|
||||
if (Timer.global_basetime.attoseconds == 0 && Machine.FORM.cheatmotion.lockState == cheatMotion.LockState.LOCK_SECOND)
|
||||
EmuTimer.timer_set_global_time(target);
|
||||
if (EmuTimer.global_basetime.attoseconds == 0 && Machine.mainMotion.cheatmotion.lockState == CheatMotion.LockState.LOCK_SECOND)
|
||||
{
|
||||
Machine.FORM.cheatmotion.ApplyCheat();
|
||||
Machine.mainMotion.cheatmotion.ApplyCheat();
|
||||
}
|
||||
}
|
||||
public static void cpu_boost_interleave(Atime timeslice_time, Atime boost_duration)
|
||||
{
|
||||
if (Attotime.attotime_compare(timeslice_time, perfect_interleave) < 0)
|
||||
timeslice_time = perfect_interleave;
|
||||
Timer.timer_adjust_periodic(interleave_boost_timer, timeslice_time, timeslice_time);
|
||||
if (!Timer.timer_enabled(interleave_boost_timer_end) || Attotime.attotime_compare(Timer.timer_timeleft(interleave_boost_timer_end), boost_duration) < 0)
|
||||
Timer.timer_adjust_periodic(interleave_boost_timer_end, boost_duration, Attotime.ATTOTIME_NEVER);
|
||||
EmuTimer.timer_adjust_periodic(interleave_boost_timer, timeslice_time, timeslice_time);
|
||||
if (!EmuTimer.timer_enabled(interleave_boost_timer_end) || Attotime.attotime_compare(EmuTimer.timer_timeleft(interleave_boost_timer_end), boost_duration) < 0)
|
||||
EmuTimer.timer_adjust_periodic(interleave_boost_timer_end, boost_duration, Attotime.ATTOTIME_NEVER);
|
||||
}
|
||||
public static void activecpu_abort_timeslice(int cpunum)
|
||||
{
|
||||
@ -2564,7 +2563,7 @@ namespace mame
|
||||
case "CPS2":
|
||||
iloops = 0;
|
||||
CPS.cps2_interrupt();
|
||||
Timer.timer_adjust_periodic(Cpuexec.cpu[0].partial_frame_timer, Cpuexec.cpu[0].partial_frame_period, Attotime.ATTOTIME_NEVER);
|
||||
EmuTimer.timer_adjust_periodic(Cpuexec.cpu[0].partial_frame_timer, Cpuexec.cpu[0].partial_frame_period, Attotime.ATTOTIME_NEVER);
|
||||
break;
|
||||
case "Data East":
|
||||
Generic.nmi_line_pulse0();
|
||||
@ -2573,7 +2572,7 @@ namespace mame
|
||||
iloops = 0;
|
||||
vblank_interrupt();
|
||||
Tehkan.pbaction_interrupt();
|
||||
Timer.timer_adjust_periodic(Cpuexec.cpu[1].partial_frame_timer, Cpuexec.cpu[1].partial_frame_period, Attotime.ATTOTIME_NEVER);
|
||||
EmuTimer.timer_adjust_periodic(Cpuexec.cpu[1].partial_frame_timer, Cpuexec.cpu[1].partial_frame_period, Attotime.ATTOTIME_NEVER);
|
||||
break;
|
||||
case "Neo Geo":
|
||||
break;
|
||||
@ -2581,8 +2580,8 @@ namespace mame
|
||||
iloops = 0;
|
||||
iloops2 = 0;
|
||||
Generic.irq_1_0_line_hold();
|
||||
Timer.timer_adjust_periodic(Cpuexec.cpu[0].partial_frame_timer, Cpuexec.cpu[0].partial_frame_period, Attotime.ATTOTIME_NEVER);
|
||||
Timer.timer_adjust_periodic(Cpuexec.cpu[1].partial_frame_timer, Cpuexec.cpu[1].partial_frame_period, Attotime.ATTOTIME_NEVER);
|
||||
EmuTimer.timer_adjust_periodic(Cpuexec.cpu[0].partial_frame_timer, Cpuexec.cpu[0].partial_frame_period, Attotime.ATTOTIME_NEVER);
|
||||
EmuTimer.timer_adjust_periodic(Cpuexec.cpu[1].partial_frame_timer, Cpuexec.cpu[1].partial_frame_period, Attotime.ATTOTIME_NEVER);
|
||||
break;
|
||||
case "Namco System 1":
|
||||
for (int cpunum = 0; cpunum < ncpu; cpunum++)
|
||||
@ -2606,7 +2605,7 @@ namespace mame
|
||||
case "drgnwrldv40k":
|
||||
iloops = 0;
|
||||
IGS011.lhb2_interrupt();
|
||||
Timer.timer_adjust_periodic(Cpuexec.cpu[0].partial_frame_timer, Cpuexec.cpu[0].partial_frame_period, Attotime.ATTOTIME_NEVER);
|
||||
EmuTimer.timer_adjust_periodic(Cpuexec.cpu[0].partial_frame_timer, Cpuexec.cpu[0].partial_frame_period, Attotime.ATTOTIME_NEVER);
|
||||
break;
|
||||
case "lhb":
|
||||
case "lhbv33c":
|
||||
@ -2614,7 +2613,7 @@ namespace mame
|
||||
case "ryukobou":
|
||||
iloops = 0;
|
||||
IGS011.lhb_interrupt();
|
||||
Timer.timer_adjust_periodic(Cpuexec.cpu[0].partial_frame_timer, Cpuexec.cpu[0].partial_frame_period, Attotime.ATTOTIME_NEVER);
|
||||
EmuTimer.timer_adjust_periodic(Cpuexec.cpu[0].partial_frame_timer, Cpuexec.cpu[0].partial_frame_period, Attotime.ATTOTIME_NEVER);
|
||||
break;
|
||||
}
|
||||
break;
|
||||
@ -2624,7 +2623,7 @@ namespace mame
|
||||
case "M72":
|
||||
iloops = 0;
|
||||
vblank_interrupt();
|
||||
Timer.timer_adjust_periodic(Cpuexec.cpu[1].partial_frame_timer, Cpuexec.cpu[1].partial_frame_period, Attotime.ATTOTIME_NEVER);
|
||||
EmuTimer.timer_adjust_periodic(Cpuexec.cpu[1].partial_frame_timer, Cpuexec.cpu[1].partial_frame_period, Attotime.ATTOTIME_NEVER);
|
||||
break;
|
||||
case "M92":
|
||||
break;
|
||||
@ -2677,7 +2676,7 @@ namespace mame
|
||||
}
|
||||
iloops = 0;
|
||||
vblank_interrupt();
|
||||
Timer.timer_adjust_periodic(Cpuexec.cpu[3].partial_frame_timer, Cpuexec.cpu[3].partial_frame_period, Attotime.ATTOTIME_NEVER);
|
||||
EmuTimer.timer_adjust_periodic(Cpuexec.cpu[3].partial_frame_timer, Cpuexec.cpu[3].partial_frame_period, Attotime.ATTOTIME_NEVER);
|
||||
break;
|
||||
case "opwolf":
|
||||
case "opwolfa":
|
||||
@ -2714,7 +2713,7 @@ namespace mame
|
||||
case "cuebrick":
|
||||
iloops = 0;
|
||||
vblank_interrupt();
|
||||
Timer.timer_adjust_periodic(Cpuexec.cpu[0].partial_frame_timer, Cpuexec.cpu[0].partial_frame_period, Attotime.ATTOTIME_NEVER);
|
||||
EmuTimer.timer_adjust_periodic(Cpuexec.cpu[0].partial_frame_timer, Cpuexec.cpu[0].partial_frame_period, Attotime.ATTOTIME_NEVER);
|
||||
break;
|
||||
default:
|
||||
vblank_interrupt();
|
||||
@ -2741,7 +2740,7 @@ namespace mame
|
||||
}
|
||||
iloops = 0;
|
||||
vblank_interrupt();
|
||||
Timer.timer_adjust_periodic(Cpuexec.cpu[1].partial_frame_timer, Cpuexec.cpu[1].partial_frame_period, Attotime.ATTOTIME_NEVER);
|
||||
EmuTimer.timer_adjust_periodic(Cpuexec.cpu[1].partial_frame_timer, Cpuexec.cpu[1].partial_frame_period, Attotime.ATTOTIME_NEVER);
|
||||
break;
|
||||
case "sf":
|
||||
case "sfua":
|
||||
@ -2772,7 +2771,7 @@ namespace mame
|
||||
vblank_interrupt();
|
||||
if (iloops > 1)
|
||||
{
|
||||
Timer.timer_adjust_periodic(Cpuexec.cpu[0].partial_frame_timer, Cpuexec.cpu[0].partial_frame_period, Attotime.ATTOTIME_NEVER);
|
||||
EmuTimer.timer_adjust_periodic(Cpuexec.cpu[0].partial_frame_timer, Cpuexec.cpu[0].partial_frame_period, Attotime.ATTOTIME_NEVER);
|
||||
}
|
||||
break;
|
||||
case "Tehkan":
|
||||
@ -2784,7 +2783,7 @@ namespace mame
|
||||
Tehkan.pbaction_interrupt();
|
||||
if (iloops > 1)
|
||||
{
|
||||
Timer.timer_adjust_periodic(Cpuexec.cpu[1].partial_frame_timer, Cpuexec.cpu[1].partial_frame_period, Attotime.ATTOTIME_NEVER);
|
||||
EmuTimer.timer_adjust_periodic(Cpuexec.cpu[1].partial_frame_timer, Cpuexec.cpu[1].partial_frame_period, Attotime.ATTOTIME_NEVER);
|
||||
}
|
||||
break;
|
||||
case "SunA8":
|
||||
@ -2796,7 +2795,7 @@ namespace mame
|
||||
SunA8.hardhea2_interrupt();
|
||||
if (iloops > 1)
|
||||
{
|
||||
Timer.timer_adjust_periodic(Cpuexec.cpu[0].partial_frame_timer, Cpuexec.cpu[0].partial_frame_period, Attotime.ATTOTIME_NEVER);
|
||||
EmuTimer.timer_adjust_periodic(Cpuexec.cpu[0].partial_frame_timer, Cpuexec.cpu[0].partial_frame_period, Attotime.ATTOTIME_NEVER);
|
||||
}
|
||||
break;
|
||||
case "M72":
|
||||
@ -2808,7 +2807,7 @@ namespace mame
|
||||
vblank_interrupt();
|
||||
if (iloops > 1)
|
||||
{
|
||||
Timer.timer_adjust_periodic(Cpuexec.cpu[1].partial_frame_timer, Cpuexec.cpu[1].partial_frame_period, Attotime.ATTOTIME_NEVER);
|
||||
EmuTimer.timer_adjust_periodic(Cpuexec.cpu[1].partial_frame_timer, Cpuexec.cpu[1].partial_frame_period, Attotime.ATTOTIME_NEVER);
|
||||
}
|
||||
break;
|
||||
case "Taito":
|
||||
@ -2823,7 +2822,7 @@ namespace mame
|
||||
vblank_interrupt();
|
||||
if (iloops > 1)
|
||||
{
|
||||
Timer.timer_adjust_periodic(Cpuexec.cpu[3].partial_frame_timer, Cpuexec.cpu[3].partial_frame_period, Attotime.ATTOTIME_NEVER);
|
||||
EmuTimer.timer_adjust_periodic(Cpuexec.cpu[3].partial_frame_timer, Cpuexec.cpu[3].partial_frame_period, Attotime.ATTOTIME_NEVER);
|
||||
}
|
||||
break;
|
||||
}
|
||||
@ -2850,7 +2849,7 @@ namespace mame
|
||||
vblank_interrupt();
|
||||
if (iloops > 1)
|
||||
{
|
||||
Timer.timer_adjust_periodic(Cpuexec.cpu[1].partial_frame_timer, Cpuexec.cpu[1].partial_frame_period, Attotime.ATTOTIME_NEVER);
|
||||
EmuTimer.timer_adjust_periodic(Cpuexec.cpu[1].partial_frame_timer, Cpuexec.cpu[1].partial_frame_period, Attotime.ATTOTIME_NEVER);
|
||||
}
|
||||
break;
|
||||
}
|
||||
@ -2863,7 +2862,7 @@ namespace mame
|
||||
}
|
||||
public static void end_interleave_boost()
|
||||
{
|
||||
Timer.timer_adjust_periodic(interleave_boost_timer, Attotime.ATTOTIME_NEVER, Attotime.ATTOTIME_NEVER);
|
||||
EmuTimer.timer_adjust_periodic(interleave_boost_timer, Attotime.ATTOTIME_NEVER, Attotime.ATTOTIME_NEVER);
|
||||
}
|
||||
public static void compute_perfect_interleave()
|
||||
{
|
||||
|
@ -3,7 +3,7 @@ using System.Collections.Generic;
|
||||
using System.IO;
|
||||
using System.Runtime.InteropServices;
|
||||
|
||||
namespace mame
|
||||
namespace MAME.Core
|
||||
{
|
||||
[StructLayout(LayoutKind.Explicit)]
|
||||
[Serializable()]
|
||||
@ -134,7 +134,7 @@ namespace mame
|
||||
public static void cpunum_set_input_line(int cpunum, int line, LineState state)
|
||||
{
|
||||
int vector = (line >= 0 && line < 35) ? interrupt_vector[cpunum, line] : 0xff;
|
||||
lirq.Add(new irq(cpunum, line, state, vector, Timer.get_current_time()));
|
||||
lirq.Add(new irq(cpunum, line, state, vector, EmuTimer.get_current_time()));
|
||||
Cpuexec.cpu[cpunum].cpunum_set_input_line_and_vector(cpunum, line, state, vector);
|
||||
}
|
||||
public static void cpunum_set_input_line_vector(int cpunum, int line, int vector)
|
||||
@ -149,8 +149,8 @@ namespace mame
|
||||
{
|
||||
if (line >= 0 && line < 35)
|
||||
{
|
||||
lirq.Add(new irq(cpunum, line, state, vector, Timer.get_current_time()));
|
||||
Timer.timer_set_internal(Cpuint.cpunum_empty_event_queue, "cpunum_empty_event_queue");
|
||||
lirq.Add(new irq(cpunum, line, state, vector, EmuTimer.get_current_time()));
|
||||
EmuTimer.timer_set_internal(Cpuint.cpunum_empty_event_queue, "cpunum_empty_event_queue");
|
||||
}
|
||||
}
|
||||
public static void cpunum_empty_event_queue()
|
||||
@ -162,7 +162,7 @@ namespace mame
|
||||
}
|
||||
foreach (irq irq1 in lirq)
|
||||
{
|
||||
if (Attotime.attotime_compare(irq1.time, Timer.global_basetime) <= 0)
|
||||
if (Attotime.attotime_compare(irq1.time, EmuTimer.global_basetime) <= 0)
|
||||
{
|
||||
input_line_state[irq1.cpunum, irq1.line] = (byte)irq1.state;
|
||||
input_line_vector[irq1.cpunum, irq1.line] = irq1.vector;
|
||||
|
@ -1,7 +1,4 @@
|
||||
using Bitmap = MAME.Core.AxiBitmap.AxiBitmap;
|
||||
using Color = MAME.Core.AxiBitmap.AxiColor;
|
||||
|
||||
namespace mame
|
||||
namespace MAME.Core
|
||||
{
|
||||
public class Crosshair
|
||||
{
|
||||
@ -9,7 +6,6 @@ namespace mame
|
||||
{
|
||||
public bool[] used;
|
||||
public bool[] visible;
|
||||
public Bitmap[] bitmap;
|
||||
/*bitmap_t * bitmap[MAX_PLAYERS];
|
||||
render_texture * texture[MAX_PLAYERS];
|
||||
const device_config *screen[MAX_PLAYERS];*/
|
||||
@ -86,7 +82,6 @@ namespace mame
|
||||
{
|
||||
global.used = new bool[8];
|
||||
global.visible = new bool[8];
|
||||
global.bitmap = new Bitmap[8];
|
||||
global.x = new int[8];
|
||||
global.y = new int[8];
|
||||
switch (Machine.sName)
|
||||
@ -99,7 +94,6 @@ namespace mame
|
||||
case "opwolfp":
|
||||
global.used[0] = true;
|
||||
global.visible[0] = true;
|
||||
create_bitmap(0);
|
||||
Video.drawcrosshair = Video.drawcrosshair_opwolf;
|
||||
break;
|
||||
default:
|
||||
@ -107,30 +101,6 @@ namespace mame
|
||||
break;
|
||||
}
|
||||
}
|
||||
public static void create_bitmap(int player)
|
||||
{
|
||||
global.bitmap[player] = new Bitmap(100, 100);
|
||||
int x, y;
|
||||
uint color = crosshair_colors[player];
|
||||
for (y = 0; y < 100; y++)
|
||||
{
|
||||
for (x = 0; x < 100; x++)
|
||||
{
|
||||
global.bitmap[player].SetPixel(x, y, Color.FromArgb(0xffffff));
|
||||
}
|
||||
}
|
||||
for (y = 0; y < 50; y++)
|
||||
{
|
||||
for (x = 0; x < 100; x++)
|
||||
{
|
||||
if (((crosshair_raw_top[y * (107 / 8) + x / 8] << (x % 8)) & 0x80) != 0)
|
||||
{
|
||||
global.bitmap[player].SetPixel(x, y, Color.FromArgb(unchecked((int)(0xff000000 | color))));
|
||||
global.bitmap[player].SetPixel(x, 99 - y, Color.FromArgb(unchecked((int)(0xff000000 | color))));
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
public static void animate_opwolf()
|
||||
{
|
||||
int player;
|
||||
|
@ -1,4 +1,4 @@
|
||||
namespace mame
|
||||
namespace MAME.Core
|
||||
{
|
||||
public partial class Drawgfx
|
||||
{
|
||||
|
@ -1,6 +1,6 @@
|
||||
using System.IO;
|
||||
|
||||
namespace mame
|
||||
namespace MAME.Core
|
||||
{
|
||||
/*public enum eeprom_command
|
||||
{
|
||||
|
@ -3,9 +3,9 @@ using System;
|
||||
using System.Collections.Generic;
|
||||
using System.IO;
|
||||
|
||||
namespace mame
|
||||
namespace MAME.Core
|
||||
{
|
||||
public class Timer
|
||||
public class EmuTimer
|
||||
{
|
||||
public static List<emu_timer> lt;
|
||||
private static List<emu_timer2> lt2;
|
@ -1,7 +1,7 @@
|
||||
using cpu.m68000;
|
||||
using System;
|
||||
|
||||
namespace mame
|
||||
namespace MAME.Core
|
||||
{
|
||||
public class Generic
|
||||
{
|
||||
@ -157,7 +157,7 @@ namespace mame
|
||||
if (enabled == 0)
|
||||
{
|
||||
objcpunum = cpunum;
|
||||
Timer.timer_set_internal(clear_all_lines, "clear_all_lines");
|
||||
EmuTimer.timer_set_internal(clear_all_lines, "clear_all_lines");
|
||||
}
|
||||
}
|
||||
public static void interrupt_enable_w(byte data)
|
||||
|
@ -1,6 +1,6 @@
|
||||
using MAME.Core.run_interface;
|
||||
using MAME.Core;
|
||||
|
||||
namespace mame
|
||||
namespace MAME.Core
|
||||
{
|
||||
public class analog_field_state
|
||||
{
|
||||
@ -564,7 +564,7 @@ namespace mame
|
||||
value = analog.accum;
|
||||
if (analog.interpolate && portdata.last_delta_nsec != 0)
|
||||
{
|
||||
nsec_since_last = Attotime.attotime_to_attoseconds(Attotime.attotime_sub(Timer.get_current_time(), portdata.last_frame_time)) / Attotime.ATTOSECONDS_PER_NANOSECOND;
|
||||
nsec_since_last = Attotime.attotime_to_attoseconds(Attotime.attotime_sub(EmuTimer.get_current_time(), portdata.last_frame_time)) / Attotime.ATTOSECONDS_PER_NANOSECOND;
|
||||
value = (int)(analog.previous + ((long)(analog.accum - analog.previous) * nsec_since_last / portdata.last_delta_nsec));
|
||||
}
|
||||
result = (uint)apply_analog_settings(value, analog);
|
||||
@ -600,7 +600,7 @@ namespace mame
|
||||
}
|
||||
private static void frame_update()
|
||||
{
|
||||
Atime curtime = Timer.get_current_time();
|
||||
Atime curtime = EmuTimer.get_current_time();
|
||||
portdata.last_delta_nsec = Attotime.attotime_to_attoseconds(Attotime.attotime_sub(curtime, portdata.last_frame_time)) / Attotime.ATTOSECONDS_PER_NANOSECOND;
|
||||
portdata.last_frame_time = curtime;
|
||||
if (Mame.playState != Mame.PlayState.PLAY_REPLAYRUNNING)
|
||||
@ -643,13 +643,13 @@ namespace mame
|
||||
int value2;
|
||||
value2 = apply_analog_min_max(analog, analog.accum);
|
||||
analog.previous = analog.accum = value2;
|
||||
if (Keyboard.IsPressed(Key.K))
|
||||
if (Keyboard.IsPressed(MotionKey.P1_BTN_2))//if (Keyboard.IsPressed(Corekey.K))
|
||||
{
|
||||
keypressed = true;
|
||||
delta -= analog.delta * 0x200;
|
||||
analog.lastdigital = 1;
|
||||
}
|
||||
if (Keyboard.IsPressed(Key.L))
|
||||
if (Keyboard.IsPressed(MotionKey.P1_UNKNOW_E))//if (Keyboard.IsPressed(Corekey.L))
|
||||
{
|
||||
keypressed = true;
|
||||
delta += analog.delta * 0x200;
|
||||
@ -678,13 +678,13 @@ namespace mame
|
||||
int value2;
|
||||
value2 = apply_analog_min_max(analog, analog.accum);
|
||||
analog.previous = analog.accum = value2;
|
||||
if (Keyboard.IsPressed(Key.NumPad2))
|
||||
if (Keyboard.IsPressed(MotionKey.P2_BTN_2))//if (Keyboard.IsPressed(Corekey.NumPad2))
|
||||
{
|
||||
keypressed = true;
|
||||
delta -= analog.delta * 0x200;
|
||||
analog.lastdigital = 1;
|
||||
}
|
||||
if (Keyboard.IsPressed(Key.NumPad3))
|
||||
if (Keyboard.IsPressed(MotionKey.P2_UNKNOW_E))//if (Keyboard.IsPressed(Corekey.NumPad3))
|
||||
{
|
||||
keypressed = true;
|
||||
delta += analog.delta * 0x200;
|
||||
@ -701,13 +701,13 @@ namespace mame
|
||||
int value2;
|
||||
value2 = apply_analog_min_max(analog, analog.accum);
|
||||
analog.previous = analog.accum = value2;
|
||||
if (Keyboard.IsPressed(Key.U))
|
||||
if (Keyboard.IsPressed(MotionKey.P1_BTN_3))//if (Keyboard.IsPressed(MotionKey.P1_BTN_3))//if (Keyboard.IsPressed(Corekey.U))
|
||||
{
|
||||
keypressed = true;
|
||||
delta -= analog_p0.delta * 0x200;
|
||||
analog.lastdigital = 1;
|
||||
}
|
||||
if (Keyboard.IsPressed(Key.I))
|
||||
if (Keyboard.IsPressed(MotionKey.P1_BTN_4))//if (Keyboard.IsPressed(Corekey.I))
|
||||
{
|
||||
keypressed = true;
|
||||
delta += analog_p0.delta * 0x200;
|
||||
@ -724,13 +724,13 @@ namespace mame
|
||||
int value2;
|
||||
value2 = apply_analog_min_max(analog, analog.accum);
|
||||
analog.previous = analog.accum = value2;
|
||||
if (Keyboard.IsPressed(Key.NumPad4))
|
||||
if (Keyboard.IsPressed(MotionKey.P2_BTN_3))//if (Keyboard.IsPressed(Corekey.NumPad4))
|
||||
{
|
||||
keypressed = true;
|
||||
delta -= analog.delta * 0x200;
|
||||
analog.lastdigital = 1;
|
||||
}
|
||||
if (Keyboard.IsPressed(Key.NumPad5))
|
||||
if (Keyboard.IsPressed(MotionKey.P2_BTN_4))//if (Keyboard.IsPressed(MotionKey.P2_BTN_4))//if (Keyboard.IsPressed(Corekey.NumPad5))
|
||||
{
|
||||
keypressed = true;
|
||||
delta += analog.delta * 0x200;
|
||||
@ -747,13 +747,13 @@ namespace mame
|
||||
int value2;
|
||||
value2 = apply_analog_min_max(analog, analog.accum);
|
||||
analog.previous = analog.accum = value2;
|
||||
if (Keyboard.IsPressed(Key.A))
|
||||
if (Keyboard.IsPressed(MotionKey.P1_LEFT))//if (Keyboard.IsPressed(Corekey.A))
|
||||
{
|
||||
keypressed = true;
|
||||
delta -= analog.delta * 0x200;
|
||||
analog.lastdigital = 1;
|
||||
}
|
||||
if (Keyboard.IsPressed(Key.D))
|
||||
if (Keyboard.IsPressed(MotionKey.P1_RIGHT))//if (Keyboard.IsPressed(Corekey.D))
|
||||
{
|
||||
keypressed = true;
|
||||
delta += analog.delta * 0x200;
|
||||
@ -770,13 +770,13 @@ namespace mame
|
||||
int value2;
|
||||
value2 = apply_analog_min_max(analog, analog.accum);
|
||||
analog.previous = analog.accum = value2;
|
||||
if (Keyboard.IsPressed(Key.S))
|
||||
if (Keyboard.IsPressed(MotionKey.P1_DOWN))//if (Keyboard.IsPressed(Corekey.S))
|
||||
{
|
||||
keypressed = true;
|
||||
delta -= analog.delta * 0x200;
|
||||
analog.lastdigital = 1;
|
||||
}
|
||||
if (Keyboard.IsPressed(Key.W))
|
||||
if (Keyboard.IsPressed(MotionKey.P1_UP))//if (Keyboard.IsPressed(Corekey.W))
|
||||
{
|
||||
keypressed = true;
|
||||
delta += analog.delta * 0x200;
|
||||
@ -793,13 +793,13 @@ namespace mame
|
||||
int value2;
|
||||
value2 = apply_analog_min_max(analog, analog.accum);
|
||||
analog.previous = analog.accum = value2;
|
||||
if (Keyboard.IsPressed(Key.A))
|
||||
if (Keyboard.IsPressed(MotionKey.P1_LEFT))//if (Keyboard.IsPressed(Corekey.A))
|
||||
{
|
||||
keypressed = true;
|
||||
delta -= analog.delta * 0x200;
|
||||
analog.lastdigital = 1;
|
||||
}
|
||||
if (Keyboard.IsPressed(Key.D))
|
||||
if (Keyboard.IsPressed(MotionKey.P1_RIGHT))//if (Keyboard.IsPressed(Corekey.D))
|
||||
{
|
||||
keypressed = true;
|
||||
delta += analog.delta * 0x200;
|
||||
@ -816,13 +816,13 @@ namespace mame
|
||||
int value2;
|
||||
value2 = apply_analog_min_max(analog, analog.accum);
|
||||
analog.previous = analog.accum = value2;
|
||||
if (Keyboard.IsPressed(Key.Left))
|
||||
if (Keyboard.IsPressed(MotionKey.P2_LEFT))//if (Keyboard.IsPressed(Corekey.Left))
|
||||
{
|
||||
keypressed = true;
|
||||
delta -= analog.delta * 0x200;
|
||||
analog.lastdigital = 1;
|
||||
}
|
||||
if (Keyboard.IsPressed(Key.Right))
|
||||
if (Keyboard.IsPressed(MotionKey.P2_RIGHT))//if (Keyboard.IsPressed(Corekey.Right))
|
||||
{
|
||||
keypressed = true;
|
||||
delta += analog.delta * 0x200;
|
||||
@ -847,13 +847,13 @@ namespace mame
|
||||
delta = rawvalue;
|
||||
analog.lastdigital = 0;
|
||||
}
|
||||
if (Keyboard.IsPressed(Key.A))
|
||||
if (Keyboard.IsPressed(MotionKey.P1_LEFT))//if (Keyboard.IsPressed(Corekey.A))
|
||||
{
|
||||
keypressed = true;
|
||||
delta -= analog.delta * 0x200;
|
||||
analog.lastdigital = 1;
|
||||
}
|
||||
if (Keyboard.IsPressed(Key.D))
|
||||
if (Keyboard.IsPressed(MotionKey.P1_RIGHT))//if (Keyboard.IsPressed(Corekey.D))
|
||||
{
|
||||
keypressed = true;
|
||||
delta += analog.delta * 0x200;
|
||||
@ -892,13 +892,13 @@ namespace mame
|
||||
delta = rawvalue;
|
||||
analog.lastdigital = 0;
|
||||
}
|
||||
if (Keyboard.IsPressed(Key.W))
|
||||
if (Keyboard.IsPressed(MotionKey.P1_UP))//if (Keyboard.IsPressed(Corekey.W))
|
||||
{
|
||||
keypressed = true;
|
||||
delta -= analog.delta * 0x200;
|
||||
analog.lastdigital = 1;
|
||||
}
|
||||
if (Keyboard.IsPressed(Key.S))
|
||||
if (Keyboard.IsPressed(MotionKey.P1_DOWN))//if (Keyboard.IsPressed(Corekey.S))
|
||||
{
|
||||
keypressed = true;
|
||||
delta += analog.delta * 0x200;
|
||||
|
@ -1,23 +1,23 @@
|
||||
using MAME.Core.run_interface;
|
||||
using MAME.Core;
|
||||
using System.Collections.Generic;
|
||||
|
||||
namespace mame
|
||||
namespace MAME.Core
|
||||
{
|
||||
public partial class Inptport
|
||||
{
|
||||
private static List<KeyStruct> lks;
|
||||
public static List<Key> lk;
|
||||
public static List<Corekey> lk;
|
||||
public class KeyStruct
|
||||
{
|
||||
public Key key;
|
||||
public Corekey key;
|
||||
public char c;
|
||||
public KeyStruct(Key _key, char _c)
|
||||
public KeyStruct(Corekey _key, char _c)
|
||||
{
|
||||
key = _key;
|
||||
c = _c;
|
||||
}
|
||||
}
|
||||
public static char getcharbykey(Key key1)
|
||||
public static char getcharbykey(Corekey key1)
|
||||
{
|
||||
char c1 = ' ';
|
||||
foreach (KeyStruct ks in lks)
|
||||
@ -32,80 +32,80 @@ namespace mame
|
||||
}
|
||||
public static void input_init()
|
||||
{
|
||||
lk = new List<Key>();
|
||||
lk.Add(Key.D1);
|
||||
lk.Add(Key.D2);
|
||||
lk.Add(Key.D3);
|
||||
lk.Add(Key.D4);
|
||||
lk.Add(Key.D5);
|
||||
lk.Add(Key.D6);
|
||||
lk.Add(Key.D7);
|
||||
lk.Add(Key.D8);
|
||||
lk.Add(Key.D9);
|
||||
lk.Add(Key.D0);
|
||||
lk.Add(Key.A);
|
||||
lk.Add(Key.B);
|
||||
lk.Add(Key.C);
|
||||
lk.Add(Key.D);
|
||||
lk.Add(Key.E);
|
||||
lk.Add(Key.F);
|
||||
lk.Add(Key.G);
|
||||
lk.Add(Key.H);
|
||||
lk.Add(Key.I);
|
||||
lk.Add(Key.J);
|
||||
lk.Add(Key.K);
|
||||
lk.Add(Key.L);
|
||||
lk.Add(Key.M);
|
||||
lk.Add(Key.N);
|
||||
lk.Add(Key.O);
|
||||
lk.Add(Key.P);
|
||||
lk.Add(Key.Q);
|
||||
lk.Add(Key.R);
|
||||
lk.Add(Key.S);
|
||||
lk.Add(Key.T);
|
||||
lk.Add(Key.U);
|
||||
lk.Add(Key.V);
|
||||
lk.Add(Key.W);
|
||||
lk.Add(Key.X);
|
||||
lk.Add(Key.Y);
|
||||
lk.Add(Key.Z);
|
||||
lk = new List<Corekey>();
|
||||
lk.Add(Corekey.D1);
|
||||
lk.Add(Corekey.D2);
|
||||
lk.Add(Corekey.D3);
|
||||
lk.Add(Corekey.D4);
|
||||
lk.Add(Corekey.D5);
|
||||
lk.Add(Corekey.D6);
|
||||
lk.Add(Corekey.D7);
|
||||
lk.Add(Corekey.D8);
|
||||
lk.Add(Corekey.D9);
|
||||
lk.Add(Corekey.D0);
|
||||
lk.Add(Corekey.A);
|
||||
lk.Add(Corekey.B);
|
||||
lk.Add(Corekey.C);
|
||||
lk.Add(Corekey.D);
|
||||
lk.Add(Corekey.E);
|
||||
lk.Add(Corekey.F);
|
||||
lk.Add(Corekey.G);
|
||||
lk.Add(Corekey.H);
|
||||
lk.Add(Corekey.I);
|
||||
lk.Add(Corekey.J);
|
||||
lk.Add(Corekey.K);
|
||||
lk.Add(Corekey.L);
|
||||
lk.Add(Corekey.M);
|
||||
lk.Add(Corekey.N);
|
||||
lk.Add(Corekey.O);
|
||||
lk.Add(Corekey.P);
|
||||
lk.Add(Corekey.Q);
|
||||
lk.Add(Corekey.R);
|
||||
lk.Add(Corekey.S);
|
||||
lk.Add(Corekey.T);
|
||||
lk.Add(Corekey.U);
|
||||
lk.Add(Corekey.V);
|
||||
lk.Add(Corekey.W);
|
||||
lk.Add(Corekey.X);
|
||||
lk.Add(Corekey.Y);
|
||||
lk.Add(Corekey.Z);
|
||||
lks = new List<KeyStruct>();
|
||||
lks.Add(new KeyStruct(Key.D1, '1'));
|
||||
lks.Add(new KeyStruct(Key.D2, '2'));
|
||||
lks.Add(new KeyStruct(Key.D3, '3'));
|
||||
lks.Add(new KeyStruct(Key.D4, '4'));
|
||||
lks.Add(new KeyStruct(Key.D5, '5'));
|
||||
lks.Add(new KeyStruct(Key.D6, '6'));
|
||||
lks.Add(new KeyStruct(Key.D7, '7'));
|
||||
lks.Add(new KeyStruct(Key.D8, '8'));
|
||||
lks.Add(new KeyStruct(Key.D9, '9'));
|
||||
lks.Add(new KeyStruct(Key.D0, '0'));
|
||||
lks.Add(new KeyStruct(Key.A, 'a'));
|
||||
lks.Add(new KeyStruct(Key.B, 'b'));
|
||||
lks.Add(new KeyStruct(Key.C, 'c'));
|
||||
lks.Add(new KeyStruct(Key.D, 'd'));
|
||||
lks.Add(new KeyStruct(Key.E, 'e'));
|
||||
lks.Add(new KeyStruct(Key.F, 'f'));
|
||||
lks.Add(new KeyStruct(Key.G, 'g'));
|
||||
lks.Add(new KeyStruct(Key.H, 'h'));
|
||||
lks.Add(new KeyStruct(Key.I, 'i'));
|
||||
lks.Add(new KeyStruct(Key.J, 'j'));
|
||||
lks.Add(new KeyStruct(Key.K, 'k'));
|
||||
lks.Add(new KeyStruct(Key.L, 'l'));
|
||||
lks.Add(new KeyStruct(Key.M, 'm'));
|
||||
lks.Add(new KeyStruct(Key.N, 'n'));
|
||||
lks.Add(new KeyStruct(Key.O, 'o'));
|
||||
lks.Add(new KeyStruct(Key.P, 'p'));
|
||||
lks.Add(new KeyStruct(Key.Q, 'q'));
|
||||
lks.Add(new KeyStruct(Key.R, 'r'));
|
||||
lks.Add(new KeyStruct(Key.S, 's'));
|
||||
lks.Add(new KeyStruct(Key.T, 't'));
|
||||
lks.Add(new KeyStruct(Key.U, 'u'));
|
||||
lks.Add(new KeyStruct(Key.V, 'v'));
|
||||
lks.Add(new KeyStruct(Key.W, 'w'));
|
||||
lks.Add(new KeyStruct(Key.X, 'x'));
|
||||
lks.Add(new KeyStruct(Key.Y, 'y'));
|
||||
lks.Add(new KeyStruct(Key.Z, 'z'));
|
||||
lks.Add(new KeyStruct(Corekey.D1, '1'));
|
||||
lks.Add(new KeyStruct(Corekey.D2, '2'));
|
||||
lks.Add(new KeyStruct(Corekey.D3, '3'));
|
||||
lks.Add(new KeyStruct(Corekey.D4, '4'));
|
||||
lks.Add(new KeyStruct(Corekey.D5, '5'));
|
||||
lks.Add(new KeyStruct(Corekey.D6, '6'));
|
||||
lks.Add(new KeyStruct(Corekey.D7, '7'));
|
||||
lks.Add(new KeyStruct(Corekey.D8, '8'));
|
||||
lks.Add(new KeyStruct(Corekey.D9, '9'));
|
||||
lks.Add(new KeyStruct(Corekey.D0, '0'));
|
||||
lks.Add(new KeyStruct(Corekey.A, 'a'));
|
||||
lks.Add(new KeyStruct(Corekey.B, 'b'));
|
||||
lks.Add(new KeyStruct(Corekey.C, 'c'));
|
||||
lks.Add(new KeyStruct(Corekey.D, 'd'));
|
||||
lks.Add(new KeyStruct(Corekey.E, 'e'));
|
||||
lks.Add(new KeyStruct(Corekey.F, 'f'));
|
||||
lks.Add(new KeyStruct(Corekey.G, 'g'));
|
||||
lks.Add(new KeyStruct(Corekey.H, 'h'));
|
||||
lks.Add(new KeyStruct(Corekey.I, 'i'));
|
||||
lks.Add(new KeyStruct(Corekey.J, 'j'));
|
||||
lks.Add(new KeyStruct(Corekey.K, 'k'));
|
||||
lks.Add(new KeyStruct(Corekey.L, 'l'));
|
||||
lks.Add(new KeyStruct(Corekey.M, 'm'));
|
||||
lks.Add(new KeyStruct(Corekey.N, 'n'));
|
||||
lks.Add(new KeyStruct(Corekey.O, 'o'));
|
||||
lks.Add(new KeyStruct(Corekey.P, 'p'));
|
||||
lks.Add(new KeyStruct(Corekey.Q, 'q'));
|
||||
lks.Add(new KeyStruct(Corekey.R, 'r'));
|
||||
lks.Add(new KeyStruct(Corekey.S, 's'));
|
||||
lks.Add(new KeyStruct(Corekey.T, 't'));
|
||||
lks.Add(new KeyStruct(Corekey.U, 'u'));
|
||||
lks.Add(new KeyStruct(Corekey.V, 'v'));
|
||||
lks.Add(new KeyStruct(Corekey.W, 'w'));
|
||||
lks.Add(new KeyStruct(Corekey.X, 'x'));
|
||||
lks.Add(new KeyStruct(Corekey.Y, 'y'));
|
||||
lks.Add(new KeyStruct(Corekey.Z, 'z'));
|
||||
}
|
||||
}
|
||||
}
|
||||
|
@ -1,7 +1,8 @@
|
||||
using MAME.Core.Common;
|
||||
using MAME.Core.run_interface;
|
||||
using MAME.Core;
|
||||
using System;
|
||||
using System.Collections.Generic;
|
||||
|
||||
namespace mame
|
||||
namespace MAME.Core
|
||||
{
|
||||
public class Keyboard
|
||||
{
|
||||
@ -9,52 +10,101 @@ namespace mame
|
||||
|
||||
static IKeyboard mKeyboard;
|
||||
|
||||
public static void InitializeInput(mainMotion form1, IKeyboard ikb)
|
||||
//const int CheckMaxEnumIdx = 33;
|
||||
|
||||
class KeyState
|
||||
{
|
||||
public bool IsPressed;
|
||||
public bool IsTriggered;
|
||||
public bool WasPressed;
|
||||
};
|
||||
private static Dictionary<MotionKey, KeyState> m_KeyStates = new Dictionary<MotionKey, KeyState>();
|
||||
|
||||
static MotionKey[] mKeyName;
|
||||
public static void InitializeInput(IKeyboard ikb)
|
||||
{
|
||||
mKeyboard = ikb;
|
||||
List<MotionKey> temp = new List<MotionKey>();
|
||||
foreach (MotionKey mkey in Enum.GetValues(typeof(MotionKey)))
|
||||
{
|
||||
//if (mkey > MotionKey.FinalKey)
|
||||
// break;
|
||||
m_KeyStates[mkey] = new KeyState();
|
||||
temp.Add(mkey);
|
||||
}
|
||||
mKeyName = temp.ToArray();
|
||||
}
|
||||
|
||||
public static bool IsPressed(Key key)
|
||||
public static bool IsPressed(MotionKey key)
|
||||
{
|
||||
return mKeyboard.IsPressed(key);
|
||||
return m_KeyStates[key].IsPressed;
|
||||
}
|
||||
public static bool IsTriggered(Key key)
|
||||
public static bool IsTriggered(MotionKey key)
|
||||
{
|
||||
return mKeyboard.IsTriggered(key);
|
||||
return m_KeyStates[key].IsTriggered;
|
||||
}
|
||||
|
||||
public static void Update()
|
||||
{
|
||||
//TODO
|
||||
/*for (int i = 0; i < 256; i++)
|
||||
for (byte i = 0; i < mKeyName.Length; i++)
|
||||
{
|
||||
m_KeyStates[i].IsPressed = false;
|
||||
m_KeyStates[mKeyName[i]].IsPressed = false;
|
||||
}
|
||||
foreach (Key key in dIDevice.GetPressedKeys())
|
||||
foreach (MotionKey key in mKeyboard.GetPressedKeys())
|
||||
{
|
||||
m_KeyStates[(int)key].IsPressed = true;
|
||||
m_KeyStates[key].IsPressed = true;
|
||||
}
|
||||
for (int i = 0; i < 256; i++)
|
||||
for (int i = 0; i < mKeyName.Length; i++)
|
||||
{
|
||||
if (m_KeyStates[i].IsPressed)
|
||||
MotionKey key = mKeyName[i];
|
||||
if (m_KeyStates[key].IsPressed)
|
||||
{
|
||||
if (m_KeyStates[i].WasPressed)
|
||||
if (m_KeyStates[key].WasPressed)
|
||||
{
|
||||
m_KeyStates[i].IsTriggered = false;
|
||||
m_KeyStates[key].IsTriggered = false;
|
||||
}
|
||||
else
|
||||
{
|
||||
m_KeyStates[i].WasPressed = true;
|
||||
m_KeyStates[i].IsTriggered = true;
|
||||
m_KeyStates[key].WasPressed = true;
|
||||
m_KeyStates[key].IsTriggered = true;
|
||||
}
|
||||
}
|
||||
else
|
||||
{
|
||||
m_KeyStates[i].WasPressed = false;
|
||||
m_KeyStates[i].IsTriggered = false;
|
||||
m_KeyStates[key].WasPressed = false;
|
||||
m_KeyStates[key].IsTriggered = false;
|
||||
}
|
||||
}
|
||||
*/
|
||||
//byte finalIndex = CheckMaxEnumIdx;
|
||||
//for (byte i = 0; i < finalIndex; i++)
|
||||
//{
|
||||
// m_KeyStates[i].IsPressed = false;
|
||||
//}
|
||||
//foreach (MotionKey key in mKeyboard.GetPressedKeys())
|
||||
//{
|
||||
// m_KeyStates[(int)key].IsPressed = true;
|
||||
//}
|
||||
//for (int i = 0; i < finalIndex; i++)
|
||||
//{
|
||||
// if (m_KeyStates[i].IsPressed)
|
||||
// {
|
||||
// if (m_KeyStates[i].WasPressed)
|
||||
// {
|
||||
// m_KeyStates[i].IsTriggered = false;
|
||||
// }
|
||||
// else
|
||||
// {
|
||||
// m_KeyStates[i].WasPressed = true;
|
||||
// m_KeyStates[i].IsTriggered = true;
|
||||
// }
|
||||
// }
|
||||
// else
|
||||
// {
|
||||
// m_KeyStates[i].WasPressed = false;
|
||||
// m_KeyStates[i].IsTriggered = false;
|
||||
// }
|
||||
//}
|
||||
|
||||
}
|
||||
}
|
||||
}
|
@ -1,14 +1,13 @@
|
||||
using MAME.Core.Common;
|
||||
using System.Collections.Generic;
|
||||
using System.Collections.Generic;
|
||||
using System.IO;
|
||||
|
||||
namespace mame
|
||||
namespace MAME.Core
|
||||
{
|
||||
public class Machine
|
||||
{
|
||||
public static string sName, sParent, sBoard, sDirection, sDescription, sManufacturer;
|
||||
public static List<string> lsParents;
|
||||
public static mainMotion FORM;
|
||||
public static MameMainMotion mainMotion;
|
||||
public static RomInfo rom;
|
||||
public static bool bRom;
|
||||
public delegate void machine_delegate();
|
||||
@ -264,7 +263,7 @@ namespace mame
|
||||
public static byte[] GetNeogeoRom(string sFile)
|
||||
{
|
||||
byte[] bb1;
|
||||
string path = System.IO.Path.Combine(Mame.RomRoot + "/" + "roms/neogeo/", sFile);
|
||||
string path = System.IO.Path.Combine(Mame.RomRoot + "/neogeo/", sFile);
|
||||
if (File.Exists(path))
|
||||
{
|
||||
EmuLogger.Log($"Had File => {path}");
|
||||
@ -288,7 +287,7 @@ namespace mame
|
||||
int n1;
|
||||
foreach (string s1 in lsParents)
|
||||
{
|
||||
string path = System.IO.Path.Combine(Mame.RomRoot + "/" + "roms/" + s1 + "/", sFile);
|
||||
string path = System.IO.Path.Combine(Mame.RomRoot + "/" + s1 + "/", sFile);
|
||||
if (File.Exists(path))
|
||||
{
|
||||
EmuLogger.Log($"Had File => {path}");
|
||||
|
@ -1,9 +1,7 @@
|
||||
using MAME.Core.Common;
|
||||
using MAME.Core.run_interface;
|
||||
using MAME.Core;
|
||||
using System.IO;
|
||||
using System.Threading;
|
||||
|
||||
namespace mame
|
||||
namespace MAME.Core
|
||||
{
|
||||
public class Mame
|
||||
{
|
||||
@ -23,7 +21,7 @@ namespace mame
|
||||
public static PlayState playState;
|
||||
public static bool is_foreground;
|
||||
public static bool paused, exit_pending;
|
||||
public static Timer.emu_timer soft_reset_timer;
|
||||
public static EmuTimer.emu_timer soft_reset_timer;
|
||||
public static BinaryReader brRecord = null;
|
||||
public static BinaryWriter bwRecord = null;
|
||||
public static bool bPP = true;
|
||||
@ -47,7 +45,9 @@ namespace mame
|
||||
public static void mame_execute()
|
||||
{
|
||||
soft_reset();
|
||||
mame_pause(true);
|
||||
//mame_pause(true);
|
||||
//开始不暂停
|
||||
mame_pause(false);
|
||||
while (!exit_pending)
|
||||
{
|
||||
if (!paused)
|
||||
@ -83,9 +83,11 @@ namespace mame
|
||||
handlestate();
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
public static void mame_schedule_soft_reset()
|
||||
{
|
||||
Timer.timer_adjust_periodic(soft_reset_timer, Attotime.ATTOTIME_ZERO, Attotime.ATTOTIME_NEVER);
|
||||
EmuTimer.timer_adjust_periodic(soft_reset_timer, Attotime.ATTOTIME_ZERO, Attotime.ATTOTIME_NEVER);
|
||||
mame_pause(false);
|
||||
if (Cpuexec.activecpu >= 0)
|
||||
{
|
||||
@ -128,14 +130,14 @@ namespace mame
|
||||
handle_replay();
|
||||
}
|
||||
}
|
||||
public static void init_machine(mainMotion form)
|
||||
public static void init_machine()
|
||||
{
|
||||
Inptport.input_init();
|
||||
Palette.palette_init();
|
||||
Generic.generic_machine_init();
|
||||
Timer.timer_init();
|
||||
soft_reset_timer = Timer.timer_alloc_common(soft_reset, "soft_reset", false);
|
||||
Window.osd_init(form);
|
||||
EmuTimer.timer_init();
|
||||
soft_reset_timer = EmuTimer.timer_alloc_common(soft_reset, "soft_reset", false);
|
||||
Window.osd_init();
|
||||
Inptport.input_port_init();
|
||||
Cpuexec.cpuexec_init();
|
||||
Watchdog.watchdog_init();
|
||||
@ -171,7 +173,7 @@ namespace mame
|
||||
Watchdog.watchdog_internal_reset();
|
||||
Sound.sound_reset();
|
||||
playState = PlayState.PLAY_RUNNING;
|
||||
Timer.timer_set_global_time(Timer.get_current_time());
|
||||
EmuTimer.timer_set_global_time(EmuTimer.get_current_time());
|
||||
}
|
||||
private static void handle_save()
|
||||
{
|
||||
@ -181,7 +183,7 @@ namespace mame
|
||||
{
|
||||
Video.sDrawText = "Select position to save to";
|
||||
Video.popup_text_end = Wintime.osd_ticks() + Wintime.ticks_per_second * 1000;
|
||||
if (Keyboard.IsTriggered(Key.Escape))
|
||||
if (Keyboard.IsTriggered(MotionKey.Escape))
|
||||
{
|
||||
Video.sDrawText = "Save cancelled";
|
||||
Video.popup_text_end = Wintime.osd_ticks() + Wintime.ticks_per_second * 2;
|
||||
@ -190,30 +192,6 @@ namespace mame
|
||||
Motion.motion_handler_callback = Motion.handler_ingame;
|
||||
return;
|
||||
}
|
||||
char file;
|
||||
foreach (Key key1 in Inptport.lk)
|
||||
{
|
||||
if (Keyboard.IsTriggered(key1))
|
||||
{
|
||||
file = Inptport.getcharbykey(key1);
|
||||
if (!Directory.Exists("sta\\" + Machine.sName))
|
||||
{
|
||||
Directory.CreateDirectory("sta\\" + Machine.sName);
|
||||
}
|
||||
FileStream fs1 = new FileStream("sta\\" + Machine.sName + "\\" + file + ".sta", FileMode.Create);
|
||||
BinaryWriter bw1 = new BinaryWriter(fs1);
|
||||
State.savestate_callback(bw1);
|
||||
bw1.Close();
|
||||
fs1.Close();
|
||||
Video.sDrawText = "Save to position " + file;
|
||||
Video.popup_text_end = Wintime.osd_ticks() + Wintime.ticks_per_second * 2;
|
||||
playState = PlayState.PLAY_RUNNING;
|
||||
Motion.motion_handler_callback = Motion.handler_ingame;
|
||||
Thread.Sleep(500);
|
||||
mame_pause(false);
|
||||
return;
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
private static void handle_load()
|
||||
@ -224,7 +202,7 @@ namespace mame
|
||||
{
|
||||
Video.sDrawText = "Select position to load from";
|
||||
Video.popup_text_end = Wintime.osd_ticks() + Wintime.ticks_per_second * 1000;
|
||||
if (Keyboard.IsTriggered(Key.Escape))
|
||||
if (Keyboard.IsTriggered(MotionKey.Escape))
|
||||
{
|
||||
Video.sDrawText = "Load cancelled";
|
||||
Video.popup_text_end = Wintime.osd_ticks() + Wintime.ticks_per_second * 2;
|
||||
@ -233,43 +211,6 @@ namespace mame
|
||||
Motion.motion_handler_callback = Motion.handler_ingame;
|
||||
return;
|
||||
}
|
||||
char file;
|
||||
foreach (Key key1 in Inptport.lk)
|
||||
{
|
||||
if (Keyboard.IsTriggered(key1))
|
||||
{
|
||||
file = Inptport.getcharbykey(key1);
|
||||
if (!File.Exists("sta\\" + Machine.sName + "\\" + file + ".sta"))
|
||||
{
|
||||
Video.sDrawText = "Load fail";
|
||||
Video.popup_text_end = Wintime.osd_ticks() + Wintime.ticks_per_second * 2;
|
||||
playState = PlayState.PLAY_RUNNING;
|
||||
Thread.Sleep(500);
|
||||
mame_pause(false);
|
||||
Motion.motion_handler_callback = Motion.handler_ingame;
|
||||
return;
|
||||
}
|
||||
FileStream fs1 = new FileStream("sta\\" + Machine.sName + "\\" + file + ".sta", FileMode.Open);
|
||||
BinaryReader br1 = new BinaryReader(fs1);
|
||||
State.loadstate_callback(br1);
|
||||
br1.Close();
|
||||
fs1.Close();
|
||||
postload();
|
||||
Video.sDrawText = "Load from position " + file;
|
||||
Video.popup_text_end = Wintime.osd_ticks() + Wintime.ticks_per_second * 2;
|
||||
/*FileStream fs2 = new FileStream(@"\VS2008\compare1\compare1\bin\Debug\sta1\" + Machine.sName + "\\" + file + ".sta", FileMode.Create);
|
||||
BinaryWriter bw1 = new BinaryWriter(fs2);
|
||||
State.savestate_callback(bw1);
|
||||
bw1.Close();
|
||||
fs2.Close();
|
||||
return;*/
|
||||
playState = PlayState.PLAY_RUNNING;
|
||||
Motion.motion_handler_callback = Motion.handler_ingame;
|
||||
Thread.Sleep(500);
|
||||
mame_pause(false);
|
||||
return;
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
private static void handle_record()
|
||||
@ -282,7 +223,7 @@ namespace mame
|
||||
{
|
||||
Video.sDrawText = "Select position to record to";
|
||||
Video.popup_text_end = Wintime.osd_ticks() + Wintime.ticks_per_second * 1000;
|
||||
if (Keyboard.IsTriggered(Key.Escape))
|
||||
if (Keyboard.IsTriggered(MotionKey.Escape))
|
||||
{
|
||||
Video.sDrawText = "Record cancelled";
|
||||
Video.popup_text_end = Wintime.osd_ticks() + Wintime.ticks_per_second * 2;
|
||||
@ -291,39 +232,6 @@ namespace mame
|
||||
Motion.motion_handler_callback = Motion.handler_ingame;
|
||||
return;
|
||||
}
|
||||
char file;
|
||||
foreach (Key key1 in Inptport.lk)
|
||||
{
|
||||
if (Keyboard.IsTriggered(key1))
|
||||
{
|
||||
file = Inptport.getcharbykey(key1);
|
||||
if (!Directory.Exists("inp\\" + Machine.sName))
|
||||
{
|
||||
Directory.CreateDirectory("inp\\" + Machine.sName);
|
||||
}
|
||||
FileStream fs1 = new FileStream("inp\\" + Machine.sName + "\\" + file + ".sta", FileMode.Create);
|
||||
BinaryWriter bw1 = new BinaryWriter(fs1);
|
||||
State.savestate_callback(bw1);
|
||||
bw1.Close();
|
||||
fs1.Close();
|
||||
if (bwRecord != null)
|
||||
{
|
||||
bwRecord.Close();
|
||||
bwRecord = null;
|
||||
}
|
||||
FileStream fs2 = new FileStream("inp\\" + Machine.sName + "\\" + file + ".inp", FileMode.Create);
|
||||
bwRecord = new BinaryWriter(fs2);
|
||||
Memory.memory_reset2();
|
||||
Inptport.record_port_callback();
|
||||
Video.sDrawText = "Record to position " + file;
|
||||
Video.popup_text_end = Wintime.osd_ticks() + Wintime.ticks_per_second * 2;
|
||||
playState = PlayState.PLAY_RECORDRUNNING;
|
||||
Motion.motion_handler_callback = Motion.handler_ingame;
|
||||
Thread.Sleep(500);
|
||||
mame_pause(false);
|
||||
return;
|
||||
}
|
||||
}
|
||||
}
|
||||
else if (playState == PlayState.PLAY_RECORDEND)
|
||||
{
|
||||
@ -345,7 +253,7 @@ namespace mame
|
||||
{
|
||||
Video.sDrawText = "Select position to replay from";
|
||||
Video.popup_text_end = Wintime.osd_ticks() + Wintime.ticks_per_second * 1000;
|
||||
if (Keyboard.IsTriggered(Key.Escape))
|
||||
if (Keyboard.IsTriggered(MotionKey.Escape))
|
||||
{
|
||||
Video.sDrawText = "Replay cancelled";
|
||||
Video.popup_text_end = Wintime.osd_ticks() + Wintime.ticks_per_second * 2;
|
||||
@ -354,63 +262,6 @@ namespace mame
|
||||
Motion.motion_handler_callback = Motion.handler_ingame;
|
||||
return;
|
||||
}
|
||||
char file;
|
||||
foreach (Key key1 in Inptport.lk)
|
||||
{
|
||||
if (Keyboard.IsTriggered(key1))
|
||||
{
|
||||
file = Inptport.getcharbykey(key1);
|
||||
if (!File.Exists("inp\\" + Machine.sName + "\\" + file + ".sta") || !File.Exists("inp\\" + Machine.sName + "\\" + file + ".inp"))
|
||||
{
|
||||
Video.sDrawText = "Replay fail";
|
||||
Video.popup_text_end = Wintime.osd_ticks() + Wintime.ticks_per_second * 2;
|
||||
playState = PlayState.PLAY_RUNNING;
|
||||
Thread.Sleep(500);
|
||||
mame_pause(false);
|
||||
Motion.motion_handler_callback = Motion.handler_ingame;
|
||||
return;
|
||||
}
|
||||
if (bwRecord != null)
|
||||
{
|
||||
bwRecord.Close();
|
||||
bwRecord = null;
|
||||
}
|
||||
if (fsRecord != null)
|
||||
{
|
||||
fsRecord.Close();
|
||||
fsRecord = null;
|
||||
}
|
||||
if (brRecord != null)
|
||||
{
|
||||
brRecord.Close();
|
||||
brRecord = null;
|
||||
}
|
||||
FileStream fs1 = new FileStream("inp\\" + Machine.sName + "\\" + file + ".sta", FileMode.Open);
|
||||
BinaryReader br1 = new BinaryReader(fs1);
|
||||
State.loadstate_callback(br1);
|
||||
br1.Close();
|
||||
fs1.Close();
|
||||
postload();
|
||||
/*FileStream fs2 = new FileStream(@"\VS2008\compare1\compare1\bin\Debug\inp1\" + Machine.sName + "\\" + file + ".sta", FileMode.Create);
|
||||
BinaryWriter bw1 = new BinaryWriter(fs2);
|
||||
State.savestate_callback(bw1);
|
||||
bw1.Close();
|
||||
fs2.Close();
|
||||
return;*/
|
||||
fsRecord = new FileStream("inp\\" + Machine.sName + "\\" + file + ".inp", FileMode.Open);
|
||||
brRecord = new BinaryReader(fsRecord);
|
||||
Memory.memory_reset();
|
||||
Inptport.bReplayRead = true;
|
||||
Inptport.replay_port_callback();
|
||||
Video.sDrawText = "Replay from position " + file;
|
||||
Video.popup_text_end = Wintime.osd_ticks() + Wintime.ticks_per_second * 2;
|
||||
playState = PlayState.PLAY_REPLAYRUNNING;
|
||||
Motion.motion_handler_callback = Motion.handler_ingame;
|
||||
Thread.Sleep(500);
|
||||
mame_pause(false);
|
||||
return;
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
if (playState == PlayState.PLAY_REPLAYEND)
|
||||
|
@ -1,4 +1,4 @@
|
||||
namespace mame
|
||||
namespace MAME.Core
|
||||
{
|
||||
public class Memory
|
||||
{
|
||||
|
@ -1,7 +1,6 @@
|
||||
using MAME.Core.Common;
|
||||
using MAME.Core.run_interface;
|
||||
using MAME.Core;
|
||||
|
||||
namespace mame
|
||||
namespace MAME.Core
|
||||
{
|
||||
/// <summary>
|
||||
/// 原依赖Form的内容
|
||||
@ -12,54 +11,142 @@ namespace mame
|
||||
public delegate void motion_delegate();
|
||||
public static motion_delegate motion_handler_callback, motion_update_callback;
|
||||
public static bool single_step;
|
||||
//public static mainMotion mainmotion;
|
||||
public static void init()
|
||||
{
|
||||
//mainmotion = motion;
|
||||
}
|
||||
public static void ui_update_and_render()
|
||||
{
|
||||
motion_update_callback();
|
||||
motion_handler_callback();
|
||||
}
|
||||
public static void ui_updateC()
|
||||
{
|
||||
//不再填充完整画布
|
||||
//{
|
||||
// int i;
|
||||
// int red, green, blue;
|
||||
// if (single_step || Mame.paused)
|
||||
// {
|
||||
// byte bright = 0xa7;
|
||||
// for (i = 0; i < Video.fullwidth * Video.fullheight; i++)
|
||||
// {
|
||||
// red = (int)(((Palette.entry_color[Video.bitmapbase[Video.curbitmap][i]] & 0xff0000) >> 16) * bright / 0xff);
|
||||
// green = (int)(((Palette.entry_color[Video.bitmapbase[Video.curbitmap][i]] & 0xff00) >> 8) * bright / 0xff);
|
||||
// blue = (int)((Palette.entry_color[Video.bitmapbase[Video.curbitmap][i]] & 0xff) * bright / 0xff);
|
||||
// Video.bitmapcolor[i] = (int)Palette.make_argb(0xff, red, green, blue);
|
||||
// }
|
||||
// }
|
||||
// else
|
||||
// {
|
||||
// for (i = 0; i < Video.fullwidth * Video.fullheight; i++)
|
||||
// {
|
||||
// Video.bitmapcolor[i] = (int)Palette.entry_color[Video.bitmapbase[Video.curbitmap][i]];
|
||||
// }
|
||||
// }
|
||||
//}
|
||||
|
||||
{
|
||||
int i;
|
||||
int target_i = 0;
|
||||
int x, y;
|
||||
int red, green, blue;
|
||||
|
||||
int startX = Video.offsetx;
|
||||
int endX = Video.offsetx + Video.width;
|
||||
int startY = Video.offsety;
|
||||
int endY = Video.offsety + Video.height;
|
||||
|
||||
if (single_step || Mame.paused)
|
||||
{
|
||||
byte bright = 0xa7;
|
||||
for (i = 0; i < Video.fullwidth * Video.fullheight; i++)
|
||||
for (y = startY; y < endY; y++)
|
||||
{
|
||||
for (x = startX; x < endX; x++, target_i++)
|
||||
{
|
||||
i = (y * Video.fullwidth) + x;
|
||||
red = (int)(((Palette.entry_color[Video.bitmapbase[Video.curbitmap][i]] & 0xff0000) >> 16) * bright / 0xff);
|
||||
green = (int)(((Palette.entry_color[Video.bitmapbase[Video.curbitmap][i]] & 0xff00) >> 8) * bright / 0xff);
|
||||
blue = (int)((Palette.entry_color[Video.bitmapbase[Video.curbitmap][i]] & 0xff) * bright / 0xff);
|
||||
Video.bitmapcolor[i] = (int)Palette.make_argb(0xff, red, green, blue);
|
||||
Video.bitmapcolorRect[target_i] = (int)Palette.make_argb(0xff, red, green, blue);
|
||||
}
|
||||
}
|
||||
}
|
||||
else
|
||||
{
|
||||
for (i = 0; i < Video.fullwidth * Video.fullheight; i++)
|
||||
|
||||
for (y = startY; y < endY; y++)
|
||||
{
|
||||
Video.bitmapcolor[i] = (int)Palette.entry_color[Video.bitmapbase[Video.curbitmap][i]];
|
||||
for (x = startX; x < endX; x++, target_i++)
|
||||
{
|
||||
i = (y * Video.fullwidth) + x;
|
||||
Video.bitmapcolorRect[target_i] = (int)Palette.entry_color[Video.bitmapbase[Video.curbitmap][i]];
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
public static void ui_updateTehkan()
|
||||
{
|
||||
//不再填充完整画布
|
||||
//{
|
||||
// int i;
|
||||
// int red, green, blue;
|
||||
// if (single_step || Mame.paused)
|
||||
// {
|
||||
// byte bright = 0xa7;
|
||||
// for (i = 0; i < Video.fullwidth * Video.fullheight; i++)
|
||||
// {
|
||||
// if (Video.bitmapbase[Video.curbitmap][i] < 0x100)
|
||||
// {
|
||||
// red = (int)(((Palette.entry_color[Video.bitmapbase[Video.curbitmap][i]] & 0xff0000) >> 16) * bright / 0xff);
|
||||
// green = (int)(((Palette.entry_color[Video.bitmapbase[Video.curbitmap][i]] & 0xff00) >> 8) * bright / 0xff);
|
||||
// blue = (int)((Palette.entry_color[Video.bitmapbase[Video.curbitmap][i]] & 0xff) * bright / 0xff);
|
||||
// Video.bitmapcolor[i] = (int)Palette.make_argb(0xff, red, green, blue);
|
||||
// }
|
||||
// else
|
||||
// {
|
||||
// int i1 = 1;
|
||||
// }
|
||||
// }
|
||||
// }
|
||||
// else
|
||||
// {
|
||||
// for (i = 0; i < Video.fullwidth * Video.fullheight; i++)
|
||||
// {
|
||||
// if (Video.bitmapbase[Video.curbitmap][i] < 0x100)
|
||||
// {
|
||||
// Video.bitmapcolor[i] = (int)Palette.entry_color[Video.bitmapbase[Video.curbitmap][i]];
|
||||
// }
|
||||
// else
|
||||
// {
|
||||
// Video.bitmapcolor[i] = (int)Palette.entry_color[0];
|
||||
// }
|
||||
// }
|
||||
// }
|
||||
//}
|
||||
|
||||
{
|
||||
int i;
|
||||
int target_i = 0;
|
||||
int x, y;
|
||||
int red, green, blue;
|
||||
|
||||
int startX = Video.offsetx;
|
||||
int endX = Video.offsetx + Video.width;
|
||||
int startY = Video.offsety;
|
||||
int endY = Video.offsety + Video.height;
|
||||
|
||||
if (single_step || Mame.paused)
|
||||
{
|
||||
byte bright = 0xa7;
|
||||
for (i = 0; i < Video.fullwidth * Video.fullheight; i++)
|
||||
for (y = startY; y < endY; y++)
|
||||
{
|
||||
for (x = startX; x < endX; x++, target_i++)
|
||||
{
|
||||
i = y * Video.fullwidth + x;
|
||||
if (Video.bitmapbase[Video.curbitmap][i] < 0x100)
|
||||
{
|
||||
red = (int)(((Palette.entry_color[Video.bitmapbase[Video.curbitmap][i]] & 0xff0000) >> 16) * bright / 0xff);
|
||||
green = (int)(((Palette.entry_color[Video.bitmapbase[Video.curbitmap][i]] & 0xff00) >> 8) * bright / 0xff);
|
||||
blue = (int)((Palette.entry_color[Video.bitmapbase[Video.curbitmap][i]] & 0xff) * bright / 0xff);
|
||||
Video.bitmapcolor[i] = (int)Palette.make_argb(0xff, red, green, blue);
|
||||
Video.bitmapcolorRect[target_i] = (int)Palette.make_argb(0xff, red, green, blue);
|
||||
}
|
||||
else
|
||||
{
|
||||
@ -67,124 +154,287 @@ namespace mame
|
||||
}
|
||||
}
|
||||
}
|
||||
else
|
||||
{
|
||||
for (i = 0; i < Video.fullwidth * Video.fullheight; i++)
|
||||
{
|
||||
if (Video.bitmapbase[Video.curbitmap][i] < 0x100)
|
||||
{
|
||||
Video.bitmapcolor[i] = (int)Palette.entry_color[Video.bitmapbase[Video.curbitmap][i]];
|
||||
}
|
||||
else
|
||||
{
|
||||
Video.bitmapcolor[i] = (int)Palette.entry_color[0];
|
||||
for (y = startY; y < endY; y++)
|
||||
{
|
||||
for (x = startX; x < endX; x++, target_i++)
|
||||
{
|
||||
i = y * Video.fullwidth + x;
|
||||
if (Video.bitmapbase[Video.curbitmap][i] < 0x100)
|
||||
{
|
||||
Video.bitmapcolorRect[target_i] = (int)Palette.entry_color[Video.bitmapbase[Video.curbitmap][i]];
|
||||
}
|
||||
else
|
||||
{
|
||||
Video.bitmapcolorRect[target_i] = (int)Palette.entry_color[0];
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
public static void ui_updateN()
|
||||
{
|
||||
//不再填充完整画布
|
||||
//{
|
||||
// int i;
|
||||
// int red, green, blue;
|
||||
// if (single_step || Mame.paused)
|
||||
// {
|
||||
// byte bright = 0xa7;
|
||||
// for (i = 0; i < Video.fullwidth * Video.fullheight; i++)
|
||||
// {
|
||||
// red = ((Video.bitmapbaseN[Video.curbitmap][i] & 0xff0000) >> 16) * bright / 0xff;
|
||||
// green = ((Video.bitmapbaseN[Video.curbitmap][i] & 0xff00) >> 8) * bright / 0xff;
|
||||
// blue = (Video.bitmapbaseN[Video.curbitmap][i] & 0xff) * bright / 0xff;
|
||||
// Video.bitmapcolor[i] = (int)Palette.make_argb(0xff, red, green, blue);
|
||||
// }
|
||||
// }
|
||||
// else
|
||||
// {
|
||||
// for (i = 0; i < Video.fullwidth * Video.fullheight; i++)
|
||||
// {
|
||||
// Video.bitmapcolor[i] = (int)(0xff000000 | (uint)Video.bitmapbaseN[Video.curbitmap][i]);
|
||||
// }
|
||||
// }
|
||||
//}
|
||||
|
||||
{
|
||||
int i;
|
||||
int target_i = 0;
|
||||
int x, y;
|
||||
int red, green, blue;
|
||||
|
||||
int startX = Video.offsetx;
|
||||
int endX = Video.offsetx + Video.width;
|
||||
int startY = Video.offsety;
|
||||
int endY = Video.offsety + Video.height;
|
||||
if (single_step || Mame.paused)
|
||||
{
|
||||
byte bright = 0xa7;
|
||||
for (i = 0; i < Video.fullwidth * Video.fullheight; i++)
|
||||
for (y = startY; y < endY; y++)
|
||||
{
|
||||
for (x = startX; x < endX; x++, target_i++)
|
||||
{
|
||||
i = y * Video.fullwidth + x;
|
||||
red = ((Video.bitmapbaseN[Video.curbitmap][i] & 0xff0000) >> 16) * bright / 0xff;
|
||||
green = ((Video.bitmapbaseN[Video.curbitmap][i] & 0xff00) >> 8) * bright / 0xff;
|
||||
blue = (Video.bitmapbaseN[Video.curbitmap][i] & 0xff) * bright / 0xff;
|
||||
Video.bitmapcolor[i] = (int)Palette.make_argb(0xff, red, green, blue);
|
||||
Video.bitmapcolorRect[target_i] = (int)Palette.make_argb(0xff, red, green, blue);
|
||||
}
|
||||
}
|
||||
}
|
||||
else
|
||||
{
|
||||
for (i = 0; i < Video.fullwidth * Video.fullheight; i++)
|
||||
for (y = startY; y < endY; y++)
|
||||
{
|
||||
Video.bitmapcolor[i] = (int)(0xff000000 | (uint)Video.bitmapbaseN[Video.curbitmap][i]);
|
||||
for (x = startX; x < endX; x++, target_i++)
|
||||
{
|
||||
i = y * Video.fullwidth + x;
|
||||
Video.bitmapcolorRect[target_i] = (int)(0xff000000 | (uint)Video.bitmapbaseN[Video.curbitmap][i]);
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
public static void ui_updateNa()
|
||||
{
|
||||
//不再填充完整画布
|
||||
//{
|
||||
// int i;
|
||||
// int red, green, blue;
|
||||
// if (single_step || Mame.paused)
|
||||
// {
|
||||
// byte bright = 0xa7;
|
||||
// for (i = 0; i < Video.fullwidth * Video.fullheight; i++)
|
||||
// {
|
||||
// red = (int)(((Palette.entry_color[Video.bitmapbase[Video.curbitmap][i]] & 0xff0000) >> 16) * bright / 0xff);
|
||||
// green = (int)(((Palette.entry_color[Video.bitmapbase[Video.curbitmap][i]] & 0xff00) >> 8) * bright / 0xff);
|
||||
// blue = (int)((Palette.entry_color[Video.bitmapbase[Video.curbitmap][i]] & 0xff) * bright / 0xff);
|
||||
// Video.bitmapcolor[i] = (int)Palette.make_argb(0xff, red, green, blue);
|
||||
// }
|
||||
// }
|
||||
// else
|
||||
// {
|
||||
// for (i = 0; i < Video.fullwidth * Video.fullheight; i++)
|
||||
// {
|
||||
// Video.bitmapcolor[i] = (int)Palette.entry_color[Video.bitmapbase[Video.curbitmap][i]];
|
||||
// }
|
||||
// }
|
||||
//}
|
||||
|
||||
{
|
||||
int i;
|
||||
int target_i = 0;
|
||||
int x, y;
|
||||
int red, green, blue;
|
||||
|
||||
int startX = Video.offsetx;
|
||||
int endX = Video.offsetx + Video.width;
|
||||
int startY = Video.offsety;
|
||||
int endY = Video.offsety + Video.height;
|
||||
if (single_step || Mame.paused)
|
||||
{
|
||||
byte bright = 0xa7;
|
||||
for (i = 0; i < Video.fullwidth * Video.fullheight; i++)
|
||||
for (y = startY; y < endY; y++)
|
||||
{
|
||||
for (x = startX; x < endX; x++, target_i++)
|
||||
{
|
||||
i = y * Video.fullwidth + x;
|
||||
red = (int)(((Palette.entry_color[Video.bitmapbase[Video.curbitmap][i]] & 0xff0000) >> 16) * bright / 0xff);
|
||||
green = (int)(((Palette.entry_color[Video.bitmapbase[Video.curbitmap][i]] & 0xff00) >> 8) * bright / 0xff);
|
||||
blue = (int)((Palette.entry_color[Video.bitmapbase[Video.curbitmap][i]] & 0xff) * bright / 0xff);
|
||||
Video.bitmapcolor[i] = (int)Palette.make_argb(0xff, red, green, blue);
|
||||
Video.bitmapcolorRect[target_i] = (int)Palette.make_argb(0xff, red, green, blue);
|
||||
}
|
||||
}
|
||||
}
|
||||
else
|
||||
{
|
||||
for (i = 0; i < Video.fullwidth * Video.fullheight; i++)
|
||||
for (y = startY; y < endY; y++)
|
||||
{
|
||||
Video.bitmapcolor[i] = (int)Palette.entry_color[Video.bitmapbase[Video.curbitmap][i]];
|
||||
for (x = startX; x < endX; x++, target_i++)
|
||||
{
|
||||
i = y * Video.fullwidth + x;
|
||||
Video.bitmapcolorRect[target_i] = (int)Palette.entry_color[Video.bitmapbase[Video.curbitmap][i]];
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
public static void ui_updateIGS011()
|
||||
{
|
||||
//不再填充完整画布
|
||||
//{
|
||||
// int i;
|
||||
// int red, green, blue;
|
||||
// if (single_step || Mame.paused)
|
||||
// {
|
||||
// byte bright = 0xa7;
|
||||
// for (i = 0; i < Video.fullwidth * Video.fullheight; i++)
|
||||
// {
|
||||
// red = (int)(((Palette.entry_color[Video.bitmapbase[Video.curbitmap][i]] & 0xff0000) >> 16) * bright / 0xff);
|
||||
// green = (int)(((Palette.entry_color[Video.bitmapbase[Video.curbitmap][i]] & 0xff00) >> 8) * bright / 0xff);
|
||||
// blue = (int)((Palette.entry_color[Video.bitmapbase[Video.curbitmap][i]] & 0xff) * bright / 0xff);
|
||||
// Video.bitmapcolor[i] = (int)Palette.make_argb(0xff, red, green, blue);
|
||||
// }
|
||||
// }
|
||||
// else
|
||||
// {
|
||||
// for (i = 0; i < Video.fullwidth * Video.fullheight; i++)
|
||||
// {
|
||||
// Video.bitmapcolor[i] = (int)Palette.entry_color[Video.bitmapbase[Video.curbitmap][i]];
|
||||
// }
|
||||
// }
|
||||
//}
|
||||
|
||||
{
|
||||
int i;
|
||||
int target_i = 0;
|
||||
int x, y;
|
||||
int red, green, blue;
|
||||
|
||||
int startX = Video.offsetx;
|
||||
int endX = Video.offsetx + Video.width;
|
||||
int startY = Video.offsety;
|
||||
int endY = Video.offsety + Video.height;
|
||||
|
||||
if (single_step || Mame.paused)
|
||||
{
|
||||
byte bright = 0xa7;
|
||||
for (i = 0; i < Video.fullwidth * Video.fullheight; i++)
|
||||
for (y = startY; y < endY; y++)
|
||||
{
|
||||
for (x = startX; x < endX; x++, target_i++)
|
||||
{
|
||||
i = y * Video.fullwidth + x;
|
||||
red = (int)(((Palette.entry_color[Video.bitmapbase[Video.curbitmap][i]] & 0xff0000) >> 16) * bright / 0xff);
|
||||
green = (int)(((Palette.entry_color[Video.bitmapbase[Video.curbitmap][i]] & 0xff00) >> 8) * bright / 0xff);
|
||||
blue = (int)((Palette.entry_color[Video.bitmapbase[Video.curbitmap][i]] & 0xff) * bright / 0xff);
|
||||
Video.bitmapcolor[i] = (int)Palette.make_argb(0xff, red, green, blue);
|
||||
Video.bitmapcolorRect[target_i] = (int)Palette.make_argb(0xff, red, green, blue);
|
||||
}
|
||||
}
|
||||
}
|
||||
else
|
||||
{
|
||||
for (i = 0; i < Video.fullwidth * Video.fullheight; i++)
|
||||
for (y = startY; y < endY; y++)
|
||||
{
|
||||
Video.bitmapcolor[i] = (int)Palette.entry_color[Video.bitmapbase[Video.curbitmap][i]];
|
||||
for (x = startX; x < endX; x++, target_i++)
|
||||
{
|
||||
i = y * Video.fullwidth + x;
|
||||
Video.bitmapcolorRect[target_i] = (int)Palette.entry_color[Video.bitmapbase[Video.curbitmap][i]];
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
public static void ui_updatePGM()
|
||||
{
|
||||
//不再填充完整画布
|
||||
//{
|
||||
// int i;
|
||||
// int red, green, blue;
|
||||
// if (single_step || Mame.paused)
|
||||
// {
|
||||
// byte bright = 0xa7;
|
||||
// for (i = 0; i < Video.fullwidth * Video.fullheight; i++)
|
||||
// {
|
||||
// red = (int)(((Palette.entry_color[Video.bitmapbase[Video.curbitmap][i]] & 0xff0000) >> 16) * bright / 0xff);
|
||||
// green = (int)(((Palette.entry_color[Video.bitmapbase[Video.curbitmap][i]] & 0xff00) >> 8) * bright / 0xff);
|
||||
// blue = (int)((Palette.entry_color[Video.bitmapbase[Video.curbitmap][i]] & 0xff) * bright / 0xff);
|
||||
// Video.bitmapcolor[i] = (int)Palette.make_argb(0xff, red, green, blue);
|
||||
// }
|
||||
// }
|
||||
// else
|
||||
// {
|
||||
// for (i = 0; i < Video.fullwidth * Video.fullheight; i++)
|
||||
// {
|
||||
// Video.bitmapcolor[i] = (int)Palette.entry_color[Video.bitmapbase[Video.curbitmap][i]];
|
||||
// }
|
||||
// }
|
||||
//}
|
||||
|
||||
{
|
||||
int i;
|
||||
int target_i = 0;
|
||||
int x, y;
|
||||
int red, green, blue;
|
||||
|
||||
int startX = Video.offsetx;
|
||||
int endX = Video.offsetx + Video.width;
|
||||
int startY = Video.offsety;
|
||||
int endY = Video.offsety + Video.height;
|
||||
|
||||
if (single_step || Mame.paused)
|
||||
{
|
||||
byte bright = 0xa7;
|
||||
for (i = 0; i < Video.fullwidth * Video.fullheight; i++)
|
||||
for (y = startY; y < endY; y++)
|
||||
{
|
||||
for (x = startX; x < endX; x++, target_i++)
|
||||
{
|
||||
i = y * Video.fullwidth + x;
|
||||
red = (int)(((Palette.entry_color[Video.bitmapbase[Video.curbitmap][i]] & 0xff0000) >> 16) * bright / 0xff);
|
||||
green = (int)(((Palette.entry_color[Video.bitmapbase[Video.curbitmap][i]] & 0xff00) >> 8) * bright / 0xff);
|
||||
blue = (int)((Palette.entry_color[Video.bitmapbase[Video.curbitmap][i]] & 0xff) * bright / 0xff);
|
||||
Video.bitmapcolor[i] = (int)Palette.make_argb(0xff, red, green, blue);
|
||||
Video.bitmapcolorRect[target_i] = (int)Palette.make_argb(0xff, red, green, blue);
|
||||
}
|
||||
}
|
||||
}
|
||||
else
|
||||
{
|
||||
for (i = 0; i < Video.fullwidth * Video.fullheight; i++)
|
||||
for (y = startY; y < endY; y++)
|
||||
{
|
||||
Video.bitmapcolor[i] = (int)Palette.entry_color[Video.bitmapbase[Video.curbitmap][i]];
|
||||
for (x = startX; x < endX; x++, target_i++)
|
||||
{
|
||||
i = y * Video.fullwidth + x;
|
||||
Video.bitmapcolorRect[target_i] = (int)Palette.entry_color[Video.bitmapbase[Video.curbitmap][i]];
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
public static void handler_ingame()
|
||||
{
|
||||
//Mame.handle2 = GetForegroundWindow();
|
||||
//if (Mame.handle1 == Mame.handle2)
|
||||
//{
|
||||
// Mame.is_foreground = true;
|
||||
//}
|
||||
//else
|
||||
//{
|
||||
// Mame.is_foreground = false;
|
||||
//}
|
||||
Mame.is_foreground = true;
|
||||
bool is_paused = Mame.mame_is_paused();
|
||||
if (single_step)
|
||||
@ -194,15 +444,15 @@ namespace mame
|
||||
}
|
||||
if (Mame.is_foreground)
|
||||
{
|
||||
if (Keyboard.IsPressed(Key.F3))
|
||||
if (Keyboard.IsPressed(MotionKey.F3))
|
||||
{
|
||||
cpurun();
|
||||
Mame.playState = Mame.PlayState.PLAY_RESET;
|
||||
}
|
||||
if (Keyboard.IsTriggered(Key.F7))
|
||||
if (Keyboard.IsTriggered(MotionKey.F7))
|
||||
{
|
||||
cpurun();
|
||||
if (Keyboard.IsPressed(Key.LeftShift) || Keyboard.IsPressed(Key.RightShift))
|
||||
if (Keyboard.IsPressed(MotionKey.LeftShift) || Keyboard.IsPressed(MotionKey.RightShift))
|
||||
{
|
||||
Mame.playState = Mame.PlayState.PLAY_SAVE;
|
||||
}
|
||||
@ -212,10 +462,10 @@ namespace mame
|
||||
}
|
||||
return;
|
||||
}
|
||||
if (Keyboard.IsTriggered(Key.F8))
|
||||
if (Keyboard.IsTriggered(MotionKey.F8))
|
||||
{
|
||||
cpurun();
|
||||
if (Keyboard.IsPressed(Key.LeftShift) || Keyboard.IsPressed(Key.RightShift))
|
||||
if (Keyboard.IsPressed(MotionKey.LeftShift) || Keyboard.IsPressed(MotionKey.RightShift))
|
||||
{
|
||||
if (Mame.playState == Mame.PlayState.PLAY_RECORDRUNNING)
|
||||
{
|
||||
@ -232,9 +482,9 @@ namespace mame
|
||||
}
|
||||
return;
|
||||
}
|
||||
if (Keyboard.IsTriggered(Key.P))
|
||||
if (Keyboard.IsTriggered(MotionKey.EMU_PAUSED))
|
||||
{
|
||||
if (is_paused && (Keyboard.IsPressed(Key.LeftShift) || Keyboard.IsPressed(Key.RightShift)))
|
||||
if (is_paused && (Keyboard.IsPressed(MotionKey.LeftShift) || Keyboard.IsPressed(MotionKey.RightShift)))
|
||||
{
|
||||
single_step = true;
|
||||
Mame.mame_pause(false);
|
||||
@ -244,7 +494,7 @@ namespace mame
|
||||
Mame.mame_pause(!Mame.mame_is_paused());
|
||||
}
|
||||
}
|
||||
if (Keyboard.IsTriggered(Key.F10))
|
||||
if (Keyboard.IsTriggered(MotionKey.F10))
|
||||
{
|
||||
Keyboard.bF10 = true;
|
||||
bool b1 = Video.global_throttle;
|
||||
@ -254,10 +504,10 @@ namespace mame
|
||||
}
|
||||
public static void cpurun()
|
||||
{
|
||||
m68000Motion.m68000State = m68000Motion.M68000State.M68000_RUN;
|
||||
Machine.FORM.m68000motion.mTx_tsslStatus = "run";
|
||||
z80Motion.z80State = z80Motion.Z80AState.Z80A_RUN;
|
||||
Machine.FORM.z80motion.mTx_tsslStatus = "run";
|
||||
M68000Motion.m68000State = M68000Motion.M68000State.M68000_RUN;
|
||||
Machine.mainMotion.m68000motion.mTx_tsslStatus = "run";
|
||||
Z80Motion.z80State = Z80Motion.Z80AState.Z80A_RUN;
|
||||
Machine.mainMotion.z80motion.mTx_tsslStatus = "run";
|
||||
}
|
||||
private static double ui_get_line_height()
|
||||
{
|
||||
|
@ -1,14 +1,13 @@
|
||||
using MAME.Core.Common;
|
||||
using MAME.Core.run_interface;
|
||||
using MAME.Core;
|
||||
|
||||
namespace mame
|
||||
namespace MAME.Core
|
||||
{
|
||||
public class Mouse
|
||||
{
|
||||
public static int deltaX, deltaY, oldX, oldY;
|
||||
public static byte[] buttons;
|
||||
static IMouse iMouse;
|
||||
public static void InitialMouse(mainMotion form1, IMouse im)
|
||||
public static void InitialMouse(IMouse im)
|
||||
{
|
||||
iMouse = im;
|
||||
}
|
||||
@ -16,12 +15,13 @@ namespace mame
|
||||
public static void Update()
|
||||
{
|
||||
int X, Y;
|
||||
iMouse.MouseXY(out X, out Y);
|
||||
iMouse.MouseXY(out X, out Y, out byte[] MouseButtons);
|
||||
deltaX = X - oldX;
|
||||
deltaY = Y - oldY;
|
||||
oldX = X;
|
||||
oldY = Y;
|
||||
//TODO
|
||||
buttons = MouseButtons;
|
||||
|
||||
//MouseState mouseState = mouseDevice.CurrentMouseState;
|
||||
//deltaX = mouseState.X - oldX;
|
||||
//deltaY = mouseState.Y - oldY;
|
||||
|
@ -1,7 +1,7 @@
|
||||
using MAME.Core.AxiBitmap;
|
||||
using Color = MAME.Core.AxiBitmap.AxiColor;
|
||||
|
||||
namespace mame
|
||||
namespace MAME.Core
|
||||
{
|
||||
public class Palette
|
||||
{
|
||||
@ -20,19 +20,22 @@ namespace mame
|
||||
case "CPS-1":
|
||||
case "CPS-1(QSound)":
|
||||
case "CPS2":
|
||||
trans_color = Color.Magenta;
|
||||
//trans_color = Color.Magenta;
|
||||
trans_color = Color.Black;
|
||||
trans_uint = (uint)trans_color.ToArgb();
|
||||
numcolors = 0xc00;
|
||||
palette_set_callback = palette_entry_set_color1;
|
||||
break;
|
||||
case "Data East":
|
||||
trans_color = Color.Magenta;
|
||||
//trans_color = Color.Magenta;
|
||||
trans_color = Color.Black;
|
||||
trans_uint = (uint)trans_color.ToArgb();
|
||||
numcolors = 0x200;
|
||||
palette_set_callback = palette_entry_set_color2;
|
||||
break;
|
||||
case "Tehkan":
|
||||
trans_color = Color.Magenta;
|
||||
//trans_color = Color.Magenta;
|
||||
trans_color = Color.Black;
|
||||
trans_uint = (uint)trans_color.ToArgb();
|
||||
numcolors = 0x100;
|
||||
palette_set_callback = palette_entry_set_color2;
|
||||
@ -56,7 +59,8 @@ namespace mame
|
||||
palette_set_callback = palette_entry_set_color1;
|
||||
break;
|
||||
case "PGM":
|
||||
trans_color = Color.Magenta;
|
||||
//trans_color = Color.Magenta;
|
||||
trans_color = Color.Black;
|
||||
trans_uint = (uint)trans_color.ToArgb();
|
||||
numcolors = 0x901;
|
||||
palette_set_callback = palette_entry_set_color2;
|
||||
@ -98,7 +102,8 @@ namespace mame
|
||||
case "boblcave":
|
||||
case "bublcave11":
|
||||
case "bublcave10":
|
||||
trans_color = Color.Magenta;
|
||||
//trans_color = Color.Magenta;
|
||||
trans_color = Color.Black;
|
||||
numcolors = 0x100;
|
||||
break;
|
||||
case "opwolf":
|
||||
@ -115,7 +120,8 @@ namespace mame
|
||||
palette_set_callback = palette_entry_set_color2;
|
||||
break;
|
||||
case "Taito B":
|
||||
trans_color = Color.Magenta;
|
||||
//trans_color = Color.Magenta;
|
||||
trans_color = Color.Black;
|
||||
trans_uint = (uint)trans_color.ToArgb();
|
||||
numcolors = 0x1000;
|
||||
palette_set_callback = palette_entry_set_color3;
|
||||
|
@ -1,6 +1,6 @@
|
||||
using System.IO;
|
||||
|
||||
namespace mame
|
||||
namespace MAME.Core
|
||||
{
|
||||
public class Pd4900a
|
||||
{
|
||||
|
@ -1,10 +1,11 @@
|
||||
using System.Collections.Generic;
|
||||
|
||||
namespace mame
|
||||
namespace MAME.Core
|
||||
{
|
||||
public class RomInfo
|
||||
{
|
||||
public static List<RomInfo> romList;
|
||||
public static Dictionary<string, RomInfo> dictName2Rom;
|
||||
public static RomInfo Rom;
|
||||
public string Name, Board;
|
||||
public string Parent;
|
||||
|
@ -1,6 +1,6 @@
|
||||
using System.IO;
|
||||
|
||||
namespace mame
|
||||
namespace MAME.Core
|
||||
{
|
||||
public class State
|
||||
{
|
||||
|
@ -1,7 +1,7 @@
|
||||
using System;
|
||||
using System.Collections.Generic;
|
||||
|
||||
namespace mame
|
||||
namespace MAME.Core
|
||||
{
|
||||
enum trans_t
|
||||
{
|
||||
|
@ -1,9 +1,9 @@
|
||||
using MAME.Core.run_interface;
|
||||
using MAME.Core;
|
||||
using System;
|
||||
using System.IO;
|
||||
using Bitmap = MAME.Core.AxiBitmap.AxiBitmap;
|
||||
using System.Runtime.InteropServices;
|
||||
|
||||
namespace mame
|
||||
namespace MAME.Core
|
||||
{
|
||||
public struct screen_state
|
||||
{
|
||||
@ -27,8 +27,8 @@ namespace mame
|
||||
public static screen_state screenstate;
|
||||
public static int video_attributes;
|
||||
private static int PAUSED_REFRESH_RATE = 30, VIDEO_UPDATE_AFTER_VBLANK = 4;
|
||||
public static Timer.emu_timer vblank_begin_timer, vblank_end_timer;
|
||||
public static Timer.emu_timer scanline0_timer, scanline_timer;
|
||||
public static EmuTimer.emu_timer vblank_begin_timer, vblank_end_timer;
|
||||
public static EmuTimer.emu_timer scanline0_timer, scanline_timer;
|
||||
private static Atime throttle_emutime, throttle_realtime, speed_last_emutime, overall_emutime;
|
||||
private static long throttle_last_ticks;
|
||||
private static long average_oversleep;
|
||||
@ -38,12 +38,22 @@ namespace mame
|
||||
private static int[] popcount;
|
||||
public static ushort[][] bitmapbase;
|
||||
public static int[][] bitmapbaseN;
|
||||
public static int[] bitmapcolor;
|
||||
//public static int[] bitmapcolor;
|
||||
|
||||
/** bitmapcolor的指针管理 **/
|
||||
//不再拷贝完整画布
|
||||
//public static int[] bitmapcolor;
|
||||
//static GCHandle bitmapcolor_handle;
|
||||
//public static IntPtr bitmapcolor_Ptr;
|
||||
|
||||
public static int[] bitmapcolorRect;
|
||||
static GCHandle bitmapcolorRect_handle;
|
||||
public static IntPtr bitmapcolorRect_Ptr;
|
||||
/** end **/
|
||||
|
||||
public static int fullwidth, fullheight;
|
||||
public static bool global_throttle;
|
||||
public static int scanline_param;
|
||||
private static Bitmap bitmapGDI;
|
||||
private static Bitmap[] bbmp;
|
||||
public static RECT new_clip;
|
||||
public static int curbitmap;
|
||||
public static string sDrawText;
|
||||
@ -62,7 +72,7 @@ namespace mame
|
||||
|
||||
|
||||
#region 抽象出去
|
||||
static Action<int[]> Act_SubmitVideo;
|
||||
static Action<int[],long> Act_SubmitVideo;
|
||||
|
||||
public static void BindFunc(IVideoPlayer Ivp)
|
||||
{
|
||||
@ -71,9 +81,9 @@ namespace mame
|
||||
Act_SubmitVideo += Ivp.SubmitVideo;
|
||||
}
|
||||
|
||||
static void SubmitVideo(int[] Bitmap)
|
||||
static void SubmitVideo(int[] Bitmap, long frame_number)
|
||||
{
|
||||
Act_SubmitVideo?.Invoke(Bitmap);
|
||||
Act_SubmitVideo.Invoke(Bitmap, frame_number);
|
||||
}
|
||||
#endregion
|
||||
|
||||
@ -109,15 +119,10 @@ namespace mame
|
||||
frame_update_time = new Atime(0, (long)(1e18 / 59.61));//59.61Hz
|
||||
screenstate.vblank_period = 0;
|
||||
video_attributes = 0;
|
||||
bitmapGDI = new Bitmap(Video.fullwidth, Video.fullheight);
|
||||
Motion.motion_update_callback = Motion.ui_updateC;
|
||||
bitmapbase = new ushort[2][];
|
||||
bitmapbase[0] = new ushort[0x200 * 0x200];
|
||||
bitmapbase[1] = new ushort[0x200 * 0x200];
|
||||
bbmp = new Bitmap[3];
|
||||
bbmp[0] = new Bitmap(512, 512);
|
||||
bbmp[1] = new Bitmap(512, 256);
|
||||
bbmp[2] = new Bitmap(384, 224);
|
||||
video_update_callback = CPS.video_update_cps1;
|
||||
video_eof_callback = CPS.video_eof_cps1;
|
||||
break;
|
||||
@ -133,15 +138,10 @@ namespace mame
|
||||
frame_update_time = new Atime(0, (long)(1e18 / 8000000) * 512 * 262);//59.637404580152669Hz
|
||||
screenstate.vblank_period = 0;
|
||||
video_attributes = 0;
|
||||
bitmapGDI = new Bitmap(Video.fullwidth, Video.fullheight);
|
||||
Motion.motion_update_callback = Motion.ui_updateC;
|
||||
bitmapbase = new ushort[2][];
|
||||
bitmapbase[0] = new ushort[0x200 * 0x200];
|
||||
bitmapbase[1] = new ushort[0x200 * 0x200];
|
||||
bbmp = new Bitmap[3];
|
||||
bbmp[0] = new Bitmap(512, 512);
|
||||
bbmp[1] = new Bitmap(512, 256);
|
||||
bbmp[2] = new Bitmap(384, 224);
|
||||
video_update_callback = CPS.video_update_cps1;
|
||||
video_eof_callback = CPS.video_eof_cps1;
|
||||
break;
|
||||
@ -157,13 +157,10 @@ namespace mame
|
||||
frame_update_time = new Atime(0, (long)(1e18 / 60));
|
||||
screenstate.vblank_period = 0;
|
||||
video_attributes = 0;
|
||||
bitmapGDI = new Bitmap(Video.fullwidth, Video.fullheight);
|
||||
Motion.motion_update_callback = Motion.ui_updateC;
|
||||
bitmapbase = new ushort[2][];
|
||||
bitmapbase[0] = new ushort[0x100 * 0x100];
|
||||
bitmapbase[1] = new ushort[0x100 * 0x100];
|
||||
bbmp = new Bitmap[1];
|
||||
bbmp[0] = new Bitmap(256, 256);
|
||||
video_update_callback = Dataeast.video_update_pcktgal;
|
||||
video_eof_callback = Dataeast.video_eof_pcktgal;
|
||||
switch (Machine.sName)
|
||||
@ -190,13 +187,10 @@ namespace mame
|
||||
frame_update_time = new Atime(0, (long)(1e18 / 60));
|
||||
screenstate.vblank_period = 0;
|
||||
video_attributes = 0;
|
||||
bitmapGDI = new Bitmap(Video.fullwidth, Video.fullheight);
|
||||
Motion.motion_update_callback = Motion.ui_updateTehkan;
|
||||
bitmapbase = new ushort[2][];
|
||||
bitmapbase[0] = new ushort[0x100 * 0x100];
|
||||
bitmapbase[1] = new ushort[0x100 * 0x100];
|
||||
bbmp = new Bitmap[1];
|
||||
bbmp[0] = new Bitmap(256, 256);
|
||||
video_update_callback = Tehkan.video_update_pbaction;
|
||||
video_eof_callback = Tehkan.video_eof_pbaction;
|
||||
break;
|
||||
@ -216,8 +210,6 @@ namespace mame
|
||||
bitmapbaseN = new int[2][];
|
||||
bitmapbaseN[0] = new int[384 * 264];
|
||||
bitmapbaseN[1] = new int[384 * 264];
|
||||
bbmp = new Bitmap[1];
|
||||
bbmp[0] = new Bitmap(320, 224);
|
||||
video_update_callback = Neogeo.video_update_neogeo;
|
||||
video_eof_callback = Neogeo.video_eof_neogeo;
|
||||
break;
|
||||
@ -237,8 +229,6 @@ namespace mame
|
||||
bitmapbase = new ushort[2][];
|
||||
bitmapbase[0] = new ushort[0x100 * 0x100];
|
||||
bitmapbase[1] = new ushort[0x100 * 0x100];
|
||||
bbmp = new Bitmap[1];
|
||||
bbmp[0] = new Bitmap(256, 224);
|
||||
video_update_callback = SunA8.video_update_suna8;
|
||||
video_eof_callback = SunA8.video_eof_suna8;
|
||||
break;
|
||||
@ -255,13 +245,9 @@ namespace mame
|
||||
screenstate.vblank_period = 0;
|
||||
video_attributes = 0;
|
||||
Motion.motion_update_callback = Motion.ui_updateNa;
|
||||
bitmapGDI = new Bitmap(Video.fullwidth, Video.fullheight);
|
||||
bitmapbase = new ushort[2][];
|
||||
bitmapbase[0] = new ushort[0x200 * 0x200];
|
||||
bitmapbase[1] = new ushort[0x200 * 0x200];
|
||||
bbmp = new Bitmap[2];
|
||||
bbmp[0] = new Bitmap(512, 512);
|
||||
bbmp[1] = new Bitmap(288, 224);
|
||||
video_update_callback = Namcos1.video_update_namcos1;
|
||||
video_eof_callback = Namcos1.video_eof_namcos1;
|
||||
break;
|
||||
@ -278,12 +264,9 @@ namespace mame
|
||||
screenstate.vblank_period = 0;
|
||||
video_attributes = 0;
|
||||
Motion.motion_update_callback = Motion.ui_updateIGS011;
|
||||
bitmapGDI = new Bitmap(Video.fullwidth, Video.fullheight);
|
||||
bitmapbase = new ushort[2][];
|
||||
bitmapbase[0] = new ushort[0x200 * 0x200];
|
||||
bitmapbase[1] = new ushort[0x200 * 0x200];
|
||||
bbmp = new Bitmap[1];
|
||||
bbmp[0] = new Bitmap(512, 240);
|
||||
video_update_callback = IGS011.video_update_igs011;
|
||||
video_eof_callback = IGS011.video_eof_igs011;
|
||||
break;
|
||||
@ -300,12 +283,9 @@ namespace mame
|
||||
screenstate.vblank_period = 0;
|
||||
video_attributes = 0;
|
||||
Motion.motion_update_callback = Motion.ui_updatePGM;
|
||||
bitmapGDI = new Bitmap(Video.fullwidth, Video.fullheight);
|
||||
bitmapbase = new ushort[2][];
|
||||
bitmapbase[0] = new ushort[0x200 * 0x200];
|
||||
bitmapbase[1] = new ushort[0x200 * 0x200];
|
||||
bbmp = new Bitmap[1];
|
||||
bbmp[0] = new Bitmap(448, 224);
|
||||
video_update_callback = PGM.video_update_pgm;
|
||||
video_eof_callback = PGM.video_eof_pgm;
|
||||
break;
|
||||
@ -325,8 +305,6 @@ namespace mame
|
||||
bitmapbase = new ushort[2][];
|
||||
bitmapbase[0] = new ushort[0x200 * 0x200];//0x11c
|
||||
bitmapbase[1] = new ushort[0x200 * 0x200];//0x11c
|
||||
bbmp = new Bitmap[1];
|
||||
bbmp[0] = new Bitmap(512, 284);
|
||||
video_update_callback = M72.video_update_m72;
|
||||
video_eof_callback = M72.video_eof_m72;
|
||||
break;
|
||||
@ -346,8 +324,6 @@ namespace mame
|
||||
bitmapbase = new ushort[2][];
|
||||
bitmapbase[0] = new ushort[0x200 * 0x200];
|
||||
bitmapbase[1] = new ushort[0x200 * 0x200];
|
||||
bbmp = new Bitmap[1];
|
||||
bbmp[0] = new Bitmap(0x200, 0x100);
|
||||
video_update_callback = M92.video_update_m92;
|
||||
video_eof_callback = M92.video_eof_m92;
|
||||
break;
|
||||
@ -391,8 +367,6 @@ namespace mame
|
||||
bitmapbase = new ushort[2][];
|
||||
bitmapbase[0] = new ushort[0x100 * 0x100];
|
||||
bitmapbase[1] = new ushort[0x100 * 0x100];
|
||||
bbmp = new Bitmap[1];
|
||||
bbmp[0] = new Bitmap(256, 224);
|
||||
video_update_callback = Taito.video_update_bublbobl;
|
||||
video_eof_callback = Taito.video_eof_taito;
|
||||
break;
|
||||
@ -415,8 +389,6 @@ namespace mame
|
||||
bitmapbase = new ushort[2][];
|
||||
bitmapbase[0] = new ushort[0x140 * 0x100];
|
||||
bitmapbase[1] = new ushort[0x140 * 0x100];
|
||||
bbmp = new Bitmap[1];
|
||||
bbmp[0] = new Bitmap(320, 240);
|
||||
video_update_callback = Taito.video_update_opwolf;
|
||||
video_eof_callback = Taito.video_eof_taito;
|
||||
break;
|
||||
@ -438,8 +410,6 @@ namespace mame
|
||||
bitmapbase = new ushort[2][];
|
||||
bitmapbase[0] = new ushort[0x200 * 0x100];
|
||||
bitmapbase[1] = new ushort[0x200 * 0x100];
|
||||
bbmp = new Bitmap[1];
|
||||
bbmp[0] = new Bitmap(320, 224);
|
||||
video_update_callback = Taitob.video_update_taitob;
|
||||
video_eof_callback = Taitob.video_eof_taitob;
|
||||
break;
|
||||
@ -455,8 +425,6 @@ namespace mame
|
||||
bitmapbase = new ushort[2][];
|
||||
bitmapbase[0] = new ushort[0x200 * 0x100];
|
||||
bitmapbase[1] = new ushort[0x200 * 0x100];
|
||||
bbmp = new Bitmap[1];
|
||||
bbmp[0] = new Bitmap(288, 224);
|
||||
video_eof_callback = Konami68000.video_eof;
|
||||
switch (Machine.sName)
|
||||
{
|
||||
@ -607,8 +575,6 @@ namespace mame
|
||||
bitmapbase = new ushort[2][];
|
||||
bitmapbase[0] = new ushort[0x100 * 0x100];
|
||||
bitmapbase[1] = new ushort[0x100 * 0x100];
|
||||
bbmp = new Bitmap[1];
|
||||
bbmp[0] = new Bitmap(256, 224);
|
||||
video_update_callback = Capcom.video_update_gng;
|
||||
video_eof_callback = Capcom.video_eof_gng;
|
||||
break;
|
||||
@ -633,8 +599,6 @@ namespace mame
|
||||
bitmapbase = new ushort[2][];
|
||||
bitmapbase[0] = new ushort[0x200 * 0x100];
|
||||
bitmapbase[1] = new ushort[0x200 * 0x100];
|
||||
bbmp = new Bitmap[1];
|
||||
bbmp[0] = new Bitmap(384, 224);
|
||||
video_update_callback = Capcom.video_update_sf;
|
||||
video_eof_callback = Capcom.video_eof;
|
||||
break;
|
||||
@ -645,13 +609,53 @@ namespace mame
|
||||
screenstate.scantime = screenstate.frame_period / screenstate.height;
|
||||
screenstate.pixeltime = screenstate.frame_period / (screenstate.height * screenstate.width);
|
||||
screenstate.frame_number = 0;
|
||||
bitmapGDI = new Bitmap(Video.fullwidth, Video.fullheight);
|
||||
bitmapcolor = new int[Video.fullwidth * Video.fullheight];
|
||||
vblank_begin_timer = Timer.timer_alloc_common(vblank_begin_callback, "vblank_begin_callback", false);
|
||||
Timer.timer_adjust_periodic(vblank_begin_timer, video_screen_get_time_until_vblank_start(), Attotime.ATTOTIME_NEVER);
|
||||
scanline0_timer = Timer.timer_alloc_common(scanline0_callback, "scanline0_callback", false);
|
||||
Timer.timer_adjust_periodic(scanline0_timer, video_screen_get_time_until_pos(0, 0), Attotime.ATTOTIME_NEVER);
|
||||
vblank_end_timer = Timer.timer_alloc_common(vblank_end_callback, "vblank_end_callback", false);
|
||||
|
||||
|
||||
//bitmapcolor = new int[Video.fullwidth * Video.fullheight];
|
||||
/** bitmapcolor的指针管理 **/
|
||||
//不再拷贝完整画布
|
||||
//if (bitmapcolor != null)
|
||||
//{
|
||||
// // 释放句柄
|
||||
// if (bitmapcolor_handle.IsAllocated)
|
||||
// {
|
||||
// bitmapcolor_handle.Free();
|
||||
// }
|
||||
//}
|
||||
//bitmapcolor = new int[Video.fullwidth * Video.fullheight];
|
||||
//// 固定数组,防止垃圾回收器移动它
|
||||
//bitmapcolor_handle = GCHandle.Alloc(bitmapcolor, GCHandleType.Pinned);
|
||||
//// 获取数组的指针
|
||||
//bitmapcolor_Ptr = bitmapcolor_handle.AddrOfPinnedObject();
|
||||
|
||||
|
||||
|
||||
|
||||
if (bitmapcolorRect != null)
|
||||
{
|
||||
// 释放句柄
|
||||
if (bitmapcolorRect_handle.IsAllocated)
|
||||
{
|
||||
bitmapcolorRect_handle.Free();
|
||||
}
|
||||
}
|
||||
bitmapcolorRect = new int[width * height];
|
||||
// 固定数组,防止垃圾回收器移动它
|
||||
bitmapcolorRect_handle = GCHandle.Alloc(bitmapcolorRect, GCHandleType.Pinned);
|
||||
// 获取数组的指针
|
||||
bitmapcolorRect_Ptr = bitmapcolorRect_handle.AddrOfPinnedObject();
|
||||
|
||||
/** end **/
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
vblank_begin_timer = EmuTimer.timer_alloc_common(vblank_begin_callback, "vblank_begin_callback", false);
|
||||
EmuTimer.timer_adjust_periodic(vblank_begin_timer, video_screen_get_time_until_vblank_start(), Attotime.ATTOTIME_NEVER);
|
||||
scanline0_timer = EmuTimer.timer_alloc_common(scanline0_callback, "scanline0_callback", false);
|
||||
EmuTimer.timer_adjust_periodic(scanline0_timer, video_screen_get_time_until_pos(0, 0), Attotime.ATTOTIME_NEVER);
|
||||
vblank_end_timer = EmuTimer.timer_alloc_common(vblank_end_callback, "vblank_end_callback", false);
|
||||
switch (Machine.sBoard)
|
||||
{
|
||||
case "CPS-1":
|
||||
@ -662,19 +666,19 @@ namespace mame
|
||||
break;
|
||||
case "CPS2":
|
||||
Cpuexec.cpu[0].partial_frame_period = Attotime.attotime_div(Video.frame_update_time, 262);
|
||||
Cpuexec.cpu[0].partial_frame_timer = Timer.timer_alloc_common(Cpuexec.trigger_partial_frame_interrupt, "trigger_partial_frame_interrupt", false);
|
||||
Cpuexec.cpu[0].partial_frame_timer = EmuTimer.timer_alloc_common(Cpuexec.trigger_partial_frame_interrupt, "trigger_partial_frame_interrupt", false);
|
||||
break;
|
||||
case "Tehkan":
|
||||
Cpuexec.cpu[1].partial_frame_period = Attotime.attotime_div(Video.frame_update_time, 2);
|
||||
Cpuexec.cpu[1].partial_frame_timer = Timer.timer_alloc_common(Cpuexec.trigger_partial_frame_interrupt, "trigger_partial_frame_interrupt", false);
|
||||
Cpuexec.cpu[1].partial_frame_timer = EmuTimer.timer_alloc_common(Cpuexec.trigger_partial_frame_interrupt, "trigger_partial_frame_interrupt", false);
|
||||
break;
|
||||
case "Neo Geo":
|
||||
break;
|
||||
case "SunA8":
|
||||
Cpuexec.cpu[0].partial_frame_period = Attotime.attotime_div(Video.frame_update_time, 0x100);
|
||||
Cpuexec.cpu[0].partial_frame_timer = Timer.timer_alloc_common(Cpuexec.trigger_partial_frame_interrupt, "trigger_partial_frame_interrupt", false);
|
||||
Cpuexec.cpu[0].partial_frame_timer = EmuTimer.timer_alloc_common(Cpuexec.trigger_partial_frame_interrupt, "trigger_partial_frame_interrupt", false);
|
||||
Cpuexec.cpu[1].partial_frame_period = Attotime.attotime_div(Video.frame_update_time, 4);
|
||||
Cpuexec.cpu[1].partial_frame_timer = Timer.timer_alloc_common(Cpuexec.trigger2, "trigger2", false);
|
||||
Cpuexec.cpu[1].partial_frame_timer = EmuTimer.timer_alloc_common(Cpuexec.trigger2, "trigger2", false);
|
||||
break;
|
||||
case "IGS011":
|
||||
switch (Machine.sName)
|
||||
@ -689,27 +693,27 @@ namespace mame
|
||||
case "drgnwrldv40k":
|
||||
case "lhb2":
|
||||
Cpuexec.cpu[0].partial_frame_period = Attotime.attotime_div(Video.frame_update_time, 5);
|
||||
Cpuexec.cpu[0].partial_frame_timer = Timer.timer_alloc_common(Cpuexec.trigger_partial_frame_interrupt, "trigger_partial_frame_interrupt", false);
|
||||
Cpuexec.cpu[0].partial_frame_timer = EmuTimer.timer_alloc_common(Cpuexec.trigger_partial_frame_interrupt, "trigger_partial_frame_interrupt", false);
|
||||
break;
|
||||
case "lhb":
|
||||
case "lhbv33c":
|
||||
case "dbc":
|
||||
case "ryukobou":
|
||||
Cpuexec.cpu[0].partial_frame_period = Attotime.attotime_div(Video.frame_update_time, 4);
|
||||
Cpuexec.cpu[0].partial_frame_timer = Timer.timer_alloc_common(Cpuexec.trigger_partial_frame_interrupt, "trigger_partial_frame_interrupt", false);
|
||||
Cpuexec.cpu[0].partial_frame_timer = EmuTimer.timer_alloc_common(Cpuexec.trigger_partial_frame_interrupt, "trigger_partial_frame_interrupt", false);
|
||||
break;
|
||||
}
|
||||
break;
|
||||
case "M72":
|
||||
Cpuexec.cpu[1].partial_frame_period = Attotime.attotime_div(Video.frame_update_time, 128);
|
||||
Cpuexec.cpu[1].partial_frame_timer = Timer.timer_alloc_common(Cpuexec.trigger_partial_frame_interrupt, "trigger_partial_frame_interrupt", false);
|
||||
Cpuexec.cpu[1].partial_frame_timer = EmuTimer.timer_alloc_common(Cpuexec.trigger_partial_frame_interrupt, "trigger_partial_frame_interrupt", false);
|
||||
break;
|
||||
case "Taito":
|
||||
switch (Machine.sName)
|
||||
{
|
||||
case "bub68705":
|
||||
Cpuexec.cpu[3].partial_frame_period = Attotime.attotime_div(Video.frame_update_time, 2);
|
||||
Cpuexec.cpu[3].partial_frame_timer = Timer.timer_alloc_common(Cpuexec.trigger_partial_frame_interrupt, "trigger_partial_frame_interrupt", false);
|
||||
Cpuexec.cpu[3].partial_frame_timer = EmuTimer.timer_alloc_common(Cpuexec.trigger_partial_frame_interrupt, "trigger_partial_frame_interrupt", false);
|
||||
break;
|
||||
}
|
||||
break;
|
||||
@ -718,7 +722,7 @@ namespace mame
|
||||
{
|
||||
case "cuebrick":
|
||||
Cpuexec.cpu[0].partial_frame_period = Attotime.attotime_div(Video.frame_update_time, 10);
|
||||
Cpuexec.cpu[0].partial_frame_timer = Timer.timer_alloc_common(Cpuexec.trigger_partial_frame_interrupt, "trigger_partial_frame_interrupt", false);
|
||||
Cpuexec.cpu[0].partial_frame_timer = EmuTimer.timer_alloc_common(Cpuexec.trigger_partial_frame_interrupt, "trigger_partial_frame_interrupt", false);
|
||||
break;
|
||||
}
|
||||
break;
|
||||
@ -737,7 +741,7 @@ namespace mame
|
||||
case "makaimurg":
|
||||
case "diamond":
|
||||
Cpuexec.cpu[1].partial_frame_period = Attotime.attotime_div(Video.frame_update_time, 4);
|
||||
Cpuexec.cpu[1].partial_frame_timer = Timer.timer_alloc_common(Cpuexec.trigger_partial_frame_interrupt, "trigger_partial_frame_interrupt", false);
|
||||
Cpuexec.cpu[1].partial_frame_timer = EmuTimer.timer_alloc_common(Cpuexec.trigger_partial_frame_interrupt, "trigger_partial_frame_interrupt", false);
|
||||
break;
|
||||
}
|
||||
break;
|
||||
@ -787,7 +791,7 @@ namespace mame
|
||||
}
|
||||
public static int video_screen_get_vpos()
|
||||
{
|
||||
long delta = Attotime.attotime_to_attoseconds(Attotime.attotime_sub(Timer.get_current_time(), screenstate.vblank_start_time));
|
||||
long delta = Attotime.attotime_to_attoseconds(Attotime.attotime_sub(EmuTimer.get_current_time(), screenstate.vblank_start_time));
|
||||
int vpos;
|
||||
delta += screenstate.pixeltime / 2;
|
||||
vpos = (int)(delta / screenstate.scantime);
|
||||
@ -795,11 +799,11 @@ namespace mame
|
||||
}
|
||||
public static bool video_screen_get_vblank()
|
||||
{
|
||||
return (Attotime.attotime_compare(Timer.get_current_time(), screenstate.vblank_end_time) < 0);
|
||||
return (Attotime.attotime_compare(EmuTimer.get_current_time(), screenstate.vblank_end_time) < 0);
|
||||
}
|
||||
public static Atime video_screen_get_time_until_pos(int vpos, int hpos)
|
||||
{
|
||||
long curdelta = Attotime.attotime_to_attoseconds(Attotime.attotime_sub(Timer.get_current_time(), screenstate.vblank_start_time));
|
||||
long curdelta = Attotime.attotime_to_attoseconds(Attotime.attotime_sub(EmuTimer.get_current_time(), screenstate.vblank_start_time));
|
||||
long targetdelta;
|
||||
vpos += screenstate.height - (screenstate.visarea.max_y + 1);
|
||||
vpos %= screenstate.height;
|
||||
@ -817,7 +821,7 @@ namespace mame
|
||||
public static Atime video_screen_get_time_until_vblank_end()
|
||||
{
|
||||
Atime ret;
|
||||
Atime current_time = Timer.get_current_time();
|
||||
Atime current_time = EmuTimer.get_current_time();
|
||||
if (video_screen_get_vblank())
|
||||
{
|
||||
ret = Attotime.attotime_sub(screenstate.vblank_end_time, current_time);
|
||||
@ -838,21 +842,21 @@ namespace mame
|
||||
}
|
||||
public static void vblank_begin_callback()
|
||||
{
|
||||
screenstate.vblank_start_time = Timer.global_basetime;// Timer.get_current_time();
|
||||
screenstate.vblank_start_time = EmuTimer.global_basetime;// Timer.get_current_time();
|
||||
screenstate.vblank_end_time = Attotime.attotime_add_attoseconds(screenstate.vblank_start_time, screenstate.vblank_period);
|
||||
Cpuexec.on_vblank();
|
||||
if ((video_attributes & VIDEO_UPDATE_AFTER_VBLANK) == 0)
|
||||
{
|
||||
video_frame_update();
|
||||
}
|
||||
Timer.timer_adjust_periodic(vblank_begin_timer, video_screen_get_time_until_vblank_start(), Attotime.ATTOTIME_NEVER);
|
||||
EmuTimer.timer_adjust_periodic(vblank_begin_timer, video_screen_get_time_until_vblank_start(), Attotime.ATTOTIME_NEVER);
|
||||
if (screenstate.vblank_period == 0)
|
||||
{
|
||||
vblank_end_callback();
|
||||
}
|
||||
else
|
||||
{
|
||||
Timer.timer_adjust_periodic(vblank_end_timer, video_screen_get_time_until_vblank_end(), Attotime.ATTOTIME_NEVER);
|
||||
EmuTimer.timer_adjust_periodic(vblank_end_timer, video_screen_get_time_until_vblank_end(), Attotime.ATTOTIME_NEVER);
|
||||
}
|
||||
}
|
||||
public static void vblank_end_callback()
|
||||
@ -866,7 +870,7 @@ namespace mame
|
||||
public static void scanline0_callback()
|
||||
{
|
||||
screenstate.last_partial_scan = 0;
|
||||
Timer.timer_adjust_periodic(scanline0_timer, video_screen_get_time_until_pos(0, 0), Attotime.ATTOTIME_NEVER);
|
||||
EmuTimer.timer_adjust_periodic(scanline0_timer, video_screen_get_time_until_pos(0, 0), Attotime.ATTOTIME_NEVER);
|
||||
}
|
||||
public static void scanline_update_callback()
|
||||
{
|
||||
@ -878,11 +882,11 @@ namespace mame
|
||||
scanline = screenstate.visarea.min_y;
|
||||
}
|
||||
scanline_param = scanline;
|
||||
Timer.timer_adjust_periodic(scanline_timer, video_screen_get_time_until_pos(scanline, 0), Attotime.ATTOTIME_NEVER);
|
||||
EmuTimer.timer_adjust_periodic(scanline_timer, video_screen_get_time_until_pos(scanline, 0), Attotime.ATTOTIME_NEVER);
|
||||
}
|
||||
public static void video_frame_update()
|
||||
{
|
||||
Atime current_time = Timer.global_basetime;
|
||||
Atime current_time = EmuTimer.global_basetime;
|
||||
if (!Mame.paused)
|
||||
{
|
||||
finish_screen_updates();
|
||||
@ -891,9 +895,9 @@ namespace mame
|
||||
Mouse.Update();
|
||||
Inptport.frame_update_callback();
|
||||
Motion.ui_update_and_render();
|
||||
if (Machine.FORM.cheatmotion.lockState == MAME.Core.Common.cheatMotion.LockState.LOCK_FRAME)
|
||||
if (Machine.mainMotion.cheatmotion.lockState == CheatMotion.LockState.LOCK_FRAME)
|
||||
{
|
||||
Machine.FORM.cheatmotion.ApplyCheat();
|
||||
Machine.mainMotion.cheatmotion.ApplyCheat();
|
||||
}
|
||||
GDIDraw();
|
||||
if (effective_throttle())
|
||||
|
@ -1,10 +1,8 @@
|
||||
using MAME.Core.AxiBitmap;
|
||||
using System;
|
||||
using Bitmap = MAME.Core.AxiBitmap.AxiBitmap;
|
||||
using Color = MAME.Core.AxiBitmap.AxiColor;
|
||||
using Rectangle = MAME.Core.AxiBitmap.Rectangle;
|
||||
|
||||
namespace mame
|
||||
namespace MAME.Core
|
||||
{
|
||||
partial class Video
|
||||
{
|
||||
@ -34,17 +32,6 @@ namespace mame
|
||||
// return bm2;
|
||||
//}
|
||||
|
||||
public static Bitmap drawcrosshair_opwolf(Bitmap bm1)
|
||||
{
|
||||
Bitmap bm2 = bm1;
|
||||
bm2.DrawImage(
|
||||
MultiplyAlpha(Crosshair.global.bitmap[0], (float)Crosshair.global.fade / 0xff),
|
||||
new Rectangle(Crosshair.global.x[0] - 10,
|
||||
Crosshair.global.y[0] - 10, 20, 20),
|
||||
new Rectangle(0, 0, 100, 100));
|
||||
return bm2;
|
||||
}
|
||||
|
||||
public static int[] drawcrosshair_opwolf(int[] bm1)
|
||||
{
|
||||
int[] bm2 = bm1;
|
||||
@ -67,33 +54,6 @@ namespace mame
|
||||
return result;
|
||||
}*/
|
||||
|
||||
/// <summary>
|
||||
///
|
||||
/// </summary>
|
||||
/// <param name="bitmap"></param>
|
||||
/// <param name="factor"></param>
|
||||
/// <returns></returns>
|
||||
public static Bitmap MultiplyAlpha(Bitmap bitmap, float factor)
|
||||
{
|
||||
Bitmap result = new Bitmap(bitmap.Width, bitmap.Height);
|
||||
for (int y = 0; y < bitmap.Height; y++)
|
||||
{
|
||||
for (int x = 0; x < bitmap.Width; x++)
|
||||
{
|
||||
Color originalColor = bitmap.GetPixel(x, y);
|
||||
byte newAlpha = (byte)Math.Min(255, (int)(originalColor.a * factor));
|
||||
Color newColor = new Color
|
||||
{
|
||||
r = originalColor.r,
|
||||
g = originalColor.g,
|
||||
b = originalColor.b,
|
||||
a = newAlpha
|
||||
};
|
||||
result.SetPixel(x, y, newColor);
|
||||
}
|
||||
}
|
||||
return result;
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
///
|
||||
@ -129,27 +89,27 @@ namespace mame
|
||||
// bitmapGDI.UnlockBits(bitmapData);
|
||||
// if (Wintime.osd_ticks() < popup_text_end)
|
||||
// {
|
||||
// Machine.FORM.tsslStatus = sDrawText;
|
||||
// Machine.mainMotion.tsslStatus = sDrawText;
|
||||
// }
|
||||
// else
|
||||
// {
|
||||
// popup_text_end = 0;
|
||||
// if (Mame.paused)
|
||||
// {
|
||||
// Machine.FORM.tsslStatus = "pause";
|
||||
// Machine.mainMotion.tsslStatus = "pause";
|
||||
// }
|
||||
// else
|
||||
// {
|
||||
// switch (Mame.playState)
|
||||
// {
|
||||
// case Mame.PlayState.PLAY_RECORDRUNNING:
|
||||
// Machine.FORM.tsslStatus = "record";
|
||||
// Machine.mainMotion.tsslStatus = "record";
|
||||
// break;
|
||||
// case Mame.PlayState.PLAY_REPLAYRUNNING:
|
||||
// Machine.FORM.tsslStatus = "replay";
|
||||
// Machine.mainMotion.tsslStatus = "replay";
|
||||
// break;
|
||||
// default:
|
||||
// Machine.FORM.tsslStatus = "run";
|
||||
// Machine.mainMotion.tsslStatus = "run";
|
||||
// break;
|
||||
// }
|
||||
// }
|
||||
@ -170,7 +130,7 @@ namespace mame
|
||||
// bbmp[iMode].RotateFlip(RotateFlipType.Rotate270FlipNone);
|
||||
// break;
|
||||
// }
|
||||
// //Machine.FORM.pictureBox1.Image = bbmp[iMode];
|
||||
// //Machine.mainMotion.pictureBox1.Image = bbmp[iMode];
|
||||
// SubmitVideo(bbmp[iMode]);
|
||||
// }
|
||||
// catch
|
||||
@ -184,25 +144,29 @@ namespace mame
|
||||
{
|
||||
try
|
||||
{
|
||||
int[] TempData = AxiBitmapEx.CloneIntColorArr(Video.bitmapcolor, Video.fullwidth, Video.fullheight, new Rectangle(offsetx, offsety, width, height));
|
||||
drawcrosshair(TempData);
|
||||
//TODO
|
||||
//int[] TempData = AxiBitmapEx.CloneIntColorArr(Video.bitmapcolor, Video.fullwidth, Video.fullheight, new Rectangle(offsetx, offsety, width, height));
|
||||
//drawcrosshair(TempData);
|
||||
//bbmp[iMode] = drawcrosshair(bitmapGDI.Clone(new Rectangle(offsetx, offsety, width, height)));
|
||||
switch (Machine.sDirection)
|
||||
{
|
||||
case "":
|
||||
break;
|
||||
case "90":
|
||||
bbmp[iMode].RotateFlip(RotateFlipType.Rotate90FlipNone);
|
||||
break;
|
||||
case "180":
|
||||
bbmp[iMode].RotateFlip(RotateFlipType.Rotate180FlipNone);
|
||||
break;
|
||||
case "270":
|
||||
bbmp[iMode].RotateFlip(RotateFlipType.Rotate270FlipNone);
|
||||
break;
|
||||
}
|
||||
//Machine.FORM.pictureBox1.Image = bbmp[iMode];
|
||||
SubmitVideo(Video.bitmapcolor);
|
||||
//switch (Machine.sDirection)
|
||||
//{
|
||||
// case "":
|
||||
// break;
|
||||
// case "90":
|
||||
// bbmp[iMode].RotateFlip(RotateFlipType.Rotate90FlipNone);
|
||||
// break;
|
||||
// case "180":
|
||||
// bbmp[iMode].RotateFlip(RotateFlipType.Rotate180FlipNone);
|
||||
// break;
|
||||
// case "270":
|
||||
// bbmp[iMode].RotateFlip(RotateFlipType.Rotate270FlipNone);
|
||||
// break;
|
||||
//}
|
||||
//Machine.mainMotion.pictureBox1.Image = bbmp[iMode];
|
||||
|
||||
//AxiBitmapEx.CloneIntColorArr(Video.bitmapcolor,Video.bitmapcolorRect, Video.fullwidth, Video.fullheight, new Rectangle(offsetx, offsety, width, height));
|
||||
SubmitVideo(Video.bitmapcolorRect, Video.screenstate.frame_number);
|
||||
//SubmitVideo(Video.bitmapcolor);
|
||||
}
|
||||
catch (Exception ex)
|
||||
{
|
||||
@ -210,37 +174,6 @@ namespace mame
|
||||
}
|
||||
}
|
||||
|
||||
public static void CopyDataFrom(AxiBitmap destBitmap, byte[] sourceData, int sourceStride)
|
||||
{
|
||||
int pixelCount = destBitmap.Width * destBitmap.Height;
|
||||
if (sourceData.Length < pixelCount * 4) // 假设每个AxiColor是4字节
|
||||
throw new ArgumentException("Source data is too small.");
|
||||
|
||||
// 注意:这里我们假设sourceStride是源数据的每行字节数,它可能包含额外的填充字节
|
||||
// 以确保每行的开始都是4的倍数。但是,对于紧密打包的AxiColor数组,我们可以忽略它。
|
||||
|
||||
for (int y = 0; y < destBitmap.Height; y++)
|
||||
{
|
||||
int sourceOffset = y * sourceStride; // 但对于紧密打包的AxiColor,这将是 y * (destBitmap.Width * 4)
|
||||
// 然而,由于我们知道sourceData是直接对应于AxiColor的,我们可以简化为:
|
||||
sourceOffset = y * destBitmap.Width * 4; // 假设没有行填充
|
||||
|
||||
for (int x = 0; x < destBitmap.Width; x++)
|
||||
{
|
||||
int index = y * destBitmap.Width + x;
|
||||
int sourceIndex = sourceOffset + x * 4;
|
||||
|
||||
byte r = sourceData[sourceIndex];
|
||||
byte g = sourceData[sourceIndex + 1];
|
||||
byte b = sourceData[sourceIndex + 2];
|
||||
byte a = sourceData[sourceIndex + 3];
|
||||
|
||||
destBitmap.mData[index] = new AxiColor { r = r, g = g, b = b, a = a };
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
|
||||
}
|
||||
}
|
@ -1,13 +1,13 @@
|
||||
namespace mame
|
||||
namespace MAME.Core
|
||||
{
|
||||
public class Watchdog
|
||||
{
|
||||
public static bool watchdog_enabled;
|
||||
public static Timer.emu_timer watchdog_timer;
|
||||
public static EmuTimer.emu_timer watchdog_timer;
|
||||
public static Atime watchdog_time;
|
||||
public static void watchdog_init()
|
||||
{
|
||||
watchdog_timer = Timer.timer_alloc_common(watchdog_callback, "watchdog_callback", false);
|
||||
watchdog_timer = EmuTimer.timer_alloc_common(watchdog_callback, "watchdog_callback", false);
|
||||
switch (Machine.sBoard)
|
||||
{
|
||||
case "CPS-1":
|
||||
@ -45,15 +45,15 @@
|
||||
{
|
||||
if (!watchdog_enabled)
|
||||
{
|
||||
Timer.timer_adjust_periodic(watchdog_timer, Attotime.ATTOTIME_NEVER, Attotime.ATTOTIME_NEVER);
|
||||
EmuTimer.timer_adjust_periodic(watchdog_timer, Attotime.ATTOTIME_NEVER, Attotime.ATTOTIME_NEVER);
|
||||
}
|
||||
else if (Attotime.attotime_compare(watchdog_time, Attotime.ATTOTIME_ZERO) != 0)
|
||||
{
|
||||
Timer.timer_adjust_periodic(watchdog_timer, watchdog_time, Attotime.ATTOTIME_NEVER);
|
||||
EmuTimer.timer_adjust_periodic(watchdog_timer, watchdog_time, Attotime.ATTOTIME_NEVER);
|
||||
}
|
||||
else
|
||||
{
|
||||
Timer.timer_adjust_periodic(watchdog_timer, new Atime(3, 0), Attotime.ATTOTIME_NEVER);
|
||||
EmuTimer.timer_adjust_periodic(watchdog_timer, new Atime(3, 0), Attotime.ATTOTIME_NEVER);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
@ -1,10 +1,8 @@
|
||||
using MAME.Core.Common;
|
||||
|
||||
namespace mame
|
||||
namespace MAME.Core
|
||||
{
|
||||
public class Window
|
||||
{
|
||||
private static mainMotion _myParentForm;
|
||||
private static MameMainMotion _myParentForm;
|
||||
//[DllImport("kernel32.dll ")]
|
||||
//private static extern uint GetTickCount();
|
||||
|
||||
@ -47,9 +45,8 @@ namespace mame
|
||||
}
|
||||
winwindow_process_events(true);
|
||||
}
|
||||
public static void osd_init(mainMotion form)
|
||||
public static void osd_init()
|
||||
{
|
||||
_myParentForm = form;
|
||||
wininput_init();
|
||||
}
|
||||
public static void wininput_init()
|
||||
|
@ -1,7 +1,7 @@
|
||||
using System.Diagnostics;
|
||||
using System.Threading;
|
||||
|
||||
namespace mame
|
||||
namespace MAME.Core
|
||||
{
|
||||
public class Wintime
|
||||
{
|
||||
|
@ -1,6 +1,6 @@
|
||||
using cpu.m68000;
|
||||
|
||||
namespace mame
|
||||
namespace MAME.Core
|
||||
{
|
||||
public partial class Capcom
|
||||
{
|
||||
|
@ -1,4 +1,4 @@
|
||||
namespace mame
|
||||
namespace MAME.Core
|
||||
{
|
||||
public partial class Drawgfx
|
||||
{
|
||||
|
@ -1,12 +0,0 @@
|
||||
|
||||
namespace mame
|
||||
{
|
||||
public partial class Capcom
|
||||
{
|
||||
public static bool bBg, bFg, bTx, bSprite;
|
||||
public static void GDIInit()
|
||||
{
|
||||
|
||||
}
|
||||
}
|
||||
}
|
@ -1,4 +1,4 @@
|
||||
namespace mame
|
||||
namespace MAME.Core
|
||||
{
|
||||
public partial class Capcom
|
||||
{
|
||||
|
@ -1,12 +1,12 @@
|
||||
using MAME.Core.run_interface;
|
||||
using MAME.Core;
|
||||
|
||||
namespace mame
|
||||
namespace MAME.Core
|
||||
{
|
||||
public partial class Capcom
|
||||
{
|
||||
public static void loop_inputports_gng()
|
||||
{
|
||||
if (Keyboard.IsPressed(Key.D5))
|
||||
if (Keyboard.IsPressed(MotionKey.P1_INSERT_COIN))//if (Keyboard.IsPressed(Corekey.D5))
|
||||
{
|
||||
bytes &= unchecked((byte)~0x40);
|
||||
}
|
||||
@ -14,7 +14,7 @@ namespace mame
|
||||
{
|
||||
bytes |= 0x40;
|
||||
}
|
||||
if (Keyboard.IsPressed(Key.D6))
|
||||
if (Keyboard.IsPressed(MotionKey.P2_INSERT_COIN))//if (Keyboard.IsPressed(Corekey.D6))
|
||||
{
|
||||
bytes &= unchecked((byte)~0x80);
|
||||
}
|
||||
@ -22,7 +22,7 @@ namespace mame
|
||||
{
|
||||
bytes |= 0x80;
|
||||
}
|
||||
if (Keyboard.IsPressed(Key.D1))
|
||||
if (Keyboard.IsPressed(MotionKey.P1_GAMESTART))//if (Keyboard.IsPressed(Corekey.D1))
|
||||
{
|
||||
bytes &= unchecked((byte)~0x01);
|
||||
}
|
||||
@ -30,7 +30,7 @@ namespace mame
|
||||
{
|
||||
bytes |= 0x01;
|
||||
}
|
||||
if (Keyboard.IsPressed(Key.D2))
|
||||
if (Keyboard.IsPressed(MotionKey.P2_GAMESTART))//if (Keyboard.IsPressed(Corekey.D2))
|
||||
{
|
||||
bytes &= unchecked((byte)~0x02);
|
||||
}
|
||||
@ -38,7 +38,7 @@ namespace mame
|
||||
{
|
||||
bytes |= 0x02;
|
||||
}
|
||||
if (Keyboard.IsPressed(Key.D))
|
||||
if (Keyboard.IsPressed(MotionKey.P1_RIGHT))//if (Keyboard.IsPressed(Corekey.D))
|
||||
{
|
||||
byte1 &= unchecked((byte)~0x01);
|
||||
}
|
||||
@ -46,7 +46,7 @@ namespace mame
|
||||
{
|
||||
byte1 |= 0x01;
|
||||
}
|
||||
if (Keyboard.IsPressed(Key.A))
|
||||
if (Keyboard.IsPressed(MotionKey.P1_LEFT))//if (Keyboard.IsPressed(Corekey.A))
|
||||
{
|
||||
byte1 &= unchecked((byte)~0x02);
|
||||
}
|
||||
@ -54,7 +54,7 @@ namespace mame
|
||||
{
|
||||
byte1 |= 0x02;
|
||||
}
|
||||
if (Keyboard.IsPressed(Key.S))
|
||||
if (Keyboard.IsPressed(MotionKey.P1_DOWN))//if (Keyboard.IsPressed(Corekey.S))
|
||||
{
|
||||
byte1 &= unchecked((byte)~0x04);
|
||||
}
|
||||
@ -62,7 +62,7 @@ namespace mame
|
||||
{
|
||||
byte1 |= 0x04;
|
||||
}
|
||||
if (Keyboard.IsPressed(Key.W))
|
||||
if (Keyboard.IsPressed(MotionKey.P1_UP))//if (Keyboard.IsPressed(Corekey.W))
|
||||
{
|
||||
byte1 &= unchecked((byte)~0x08);
|
||||
}
|
||||
@ -70,7 +70,7 @@ namespace mame
|
||||
{
|
||||
byte1 |= 0x08;
|
||||
}
|
||||
if (Keyboard.IsPressed(Key.J))
|
||||
if (Keyboard.IsPressed(MotionKey.P1_BTN_1))//if (Keyboard.IsPressed(Corekey.J))
|
||||
{
|
||||
byte1 &= unchecked((byte)~0x10);
|
||||
}
|
||||
@ -78,7 +78,7 @@ namespace mame
|
||||
{
|
||||
byte1 |= 0x10;
|
||||
}
|
||||
if (Keyboard.IsPressed(Key.K))
|
||||
if (Keyboard.IsPressed(MotionKey.P1_BTN_2))//if (Keyboard.IsPressed(Corekey.K))
|
||||
{
|
||||
byte1 &= unchecked((byte)~0x20);
|
||||
}
|
||||
@ -86,7 +86,7 @@ namespace mame
|
||||
{
|
||||
byte1 |= 0x20;
|
||||
}
|
||||
if (Keyboard.IsPressed(Key.Right))
|
||||
if (Keyboard.IsPressed(MotionKey.P2_RIGHT))//if (Keyboard.IsPressed(Corekey.Right))
|
||||
{
|
||||
byte2 &= unchecked((byte)~0x01);
|
||||
}
|
||||
@ -94,7 +94,7 @@ namespace mame
|
||||
{
|
||||
byte2 |= 0x01;
|
||||
}
|
||||
if (Keyboard.IsPressed(Key.Left))
|
||||
if (Keyboard.IsPressed(MotionKey.P2_LEFT))//if (Keyboard.IsPressed(Corekey.Left))
|
||||
{
|
||||
byte2 &= unchecked((byte)~0x02);
|
||||
}
|
||||
@ -102,7 +102,7 @@ namespace mame
|
||||
{
|
||||
byte2 |= 0x02;
|
||||
}
|
||||
if (Keyboard.IsPressed(Key.Down))
|
||||
if (Keyboard.IsPressed(MotionKey.P2_DOWN)) //if (Keyboard.IsPressed(Corekey.Down))
|
||||
{
|
||||
byte2 &= unchecked((byte)~0x04);
|
||||
}
|
||||
@ -110,7 +110,7 @@ namespace mame
|
||||
{
|
||||
byte2 |= 0x04;
|
||||
}
|
||||
if (Keyboard.IsPressed(Key.Up))
|
||||
if (Keyboard.IsPressed(MotionKey.P2_UP))//if (Keyboard.IsPressed(Corekey.Up))
|
||||
{
|
||||
byte2 &= unchecked((byte)~0x08);
|
||||
}
|
||||
@ -118,7 +118,7 @@ namespace mame
|
||||
{
|
||||
byte2 |= 0x08;
|
||||
}
|
||||
if (Keyboard.IsPressed(Key.NumPad1))
|
||||
if (Keyboard.IsPressed(MotionKey.P2_BTN_1))//if (Keyboard.IsPressed(Corekey.NumPad1))
|
||||
{
|
||||
byte2 &= unchecked((byte)~0x10);
|
||||
}
|
||||
@ -126,7 +126,7 @@ namespace mame
|
||||
{
|
||||
byte2 |= 0x10;
|
||||
}
|
||||
if (Keyboard.IsPressed(Key.NumPad2))
|
||||
if (Keyboard.IsPressed(MotionKey.P2_BTN_2))//if (Keyboard.IsPressed(Corekey.NumPad2))
|
||||
{
|
||||
byte2 &= unchecked((byte)~0x20);
|
||||
}
|
||||
@ -134,7 +134,7 @@ namespace mame
|
||||
{
|
||||
byte2 |= 0x20;
|
||||
}
|
||||
if (Keyboard.IsPressed(Key.R))
|
||||
if (Keyboard.IsPressed(MotionKey.UNKNOW_R)) //if (Keyboard.IsPressed(Corekey.R))
|
||||
{
|
||||
bytes &= unchecked((byte)~0x20);
|
||||
}
|
||||
@ -145,7 +145,7 @@ namespace mame
|
||||
}
|
||||
public static void loop_inputports_diamond()
|
||||
{
|
||||
if (Keyboard.IsPressed(Key.D5))
|
||||
if (Keyboard.IsPressed(MotionKey.P1_INSERT_COIN))//if (Keyboard.IsPressed(Corekey.D5))
|
||||
{
|
||||
bytes &= unchecked((byte)~0x40);
|
||||
}
|
||||
@ -153,7 +153,7 @@ namespace mame
|
||||
{
|
||||
bytes |= 0x40;
|
||||
}
|
||||
if (Keyboard.IsPressed(Key.D6))
|
||||
if (Keyboard.IsPressed(MotionKey.P2_INSERT_COIN))//if (Keyboard.IsPressed(Corekey.D6))
|
||||
{
|
||||
bytes &= unchecked((byte)~0x80);
|
||||
}
|
||||
@ -161,7 +161,7 @@ namespace mame
|
||||
{
|
||||
bytes |= 0x80;
|
||||
}
|
||||
if (Keyboard.IsPressed(Key.D1))
|
||||
if (Keyboard.IsPressed(MotionKey.P1_GAMESTART))//if (Keyboard.IsPressed(Corekey.D1))
|
||||
{
|
||||
bytes &= unchecked((byte)~0x01);
|
||||
}
|
||||
@ -169,7 +169,7 @@ namespace mame
|
||||
{
|
||||
bytes |= 0x01;
|
||||
}
|
||||
if (Keyboard.IsPressed(Key.D2))
|
||||
if (Keyboard.IsPressed(MotionKey.P2_GAMESTART))//if (Keyboard.IsPressed(Corekey.D2))
|
||||
{
|
||||
bytes &= unchecked((byte)~0x02);
|
||||
}
|
||||
@ -177,7 +177,7 @@ namespace mame
|
||||
{
|
||||
bytes |= 0x02;
|
||||
}
|
||||
if (Keyboard.IsPressed(Key.D))
|
||||
if (Keyboard.IsPressed(MotionKey.P1_RIGHT))//if (Keyboard.IsPressed(Corekey.D))
|
||||
{
|
||||
byte1 &= unchecked((byte)~0x01);
|
||||
}
|
||||
@ -185,7 +185,7 @@ namespace mame
|
||||
{
|
||||
byte1 |= 0x01;
|
||||
}
|
||||
if (Keyboard.IsPressed(Key.A))
|
||||
if (Keyboard.IsPressed(MotionKey.P1_LEFT))//if (Keyboard.IsPressed(Corekey.A))
|
||||
{
|
||||
byte1 &= unchecked((byte)~0x02);
|
||||
}
|
||||
@ -193,7 +193,7 @@ namespace mame
|
||||
{
|
||||
byte1 |= 0x02;
|
||||
}
|
||||
if (Keyboard.IsPressed(Key.S))
|
||||
if (Keyboard.IsPressed(MotionKey.P1_DOWN))//if (Keyboard.IsPressed(Corekey.S))
|
||||
{
|
||||
byte1 &= unchecked((byte)~0x04);
|
||||
}
|
||||
@ -201,7 +201,7 @@ namespace mame
|
||||
{
|
||||
byte1 |= 0x04;
|
||||
}
|
||||
if (Keyboard.IsPressed(Key.W))
|
||||
if (Keyboard.IsPressed(MotionKey.P1_UP))//if (Keyboard.IsPressed(Corekey.W))
|
||||
{
|
||||
byte1 &= unchecked((byte)~0x08);
|
||||
}
|
||||
@ -209,7 +209,7 @@ namespace mame
|
||||
{
|
||||
byte1 |= 0x08;
|
||||
}
|
||||
if (Keyboard.IsPressed(Key.J))
|
||||
if (Keyboard.IsPressed(MotionKey.P1_BTN_1))//if (Keyboard.IsPressed(Corekey.J))
|
||||
{
|
||||
byte1 &= unchecked((byte)~0x10);
|
||||
}
|
||||
@ -220,7 +220,7 @@ namespace mame
|
||||
}
|
||||
public static void loop_inputports_sfus()
|
||||
{
|
||||
if (Keyboard.IsPressed(Key.D5))
|
||||
if (Keyboard.IsPressed(MotionKey.P1_INSERT_COIN))//if (Keyboard.IsPressed(Corekey.D5))
|
||||
{
|
||||
short0 &= ~0x0001;
|
||||
}
|
||||
@ -228,7 +228,7 @@ namespace mame
|
||||
{
|
||||
short0 |= 0x0001;
|
||||
}
|
||||
if (Keyboard.IsPressed(Key.D6))
|
||||
if (Keyboard.IsPressed(MotionKey.P2_INSERT_COIN))//if (Keyboard.IsPressed(Corekey.D6))
|
||||
{
|
||||
short0 &= ~0x0002;
|
||||
}
|
||||
@ -236,7 +236,7 @@ namespace mame
|
||||
{
|
||||
short0 |= 0x0002;
|
||||
}
|
||||
if (Keyboard.IsPressed(Key.D1))
|
||||
if (Keyboard.IsPressed(MotionKey.P1_GAMESTART))//if (Keyboard.IsPressed(Corekey.D1))
|
||||
{
|
||||
shorts &= ~0x0001;
|
||||
}
|
||||
@ -244,7 +244,7 @@ namespace mame
|
||||
{
|
||||
shorts |= 0x0001;
|
||||
}
|
||||
if (Keyboard.IsPressed(Key.D2))
|
||||
if (Keyboard.IsPressed(MotionKey.P2_GAMESTART))//if (Keyboard.IsPressed(Corekey.D2))
|
||||
{
|
||||
shorts &= ~0x0002;
|
||||
}
|
||||
@ -252,7 +252,7 @@ namespace mame
|
||||
{
|
||||
shorts |= 0x0002;
|
||||
}
|
||||
if (Keyboard.IsPressed(Key.D))
|
||||
if (Keyboard.IsPressed(MotionKey.P1_RIGHT))//if (Keyboard.IsPressed(Corekey.D))
|
||||
{
|
||||
short1 &= ~0x0001;
|
||||
}
|
||||
@ -260,7 +260,7 @@ namespace mame
|
||||
{
|
||||
short1 |= 0x0001;
|
||||
}
|
||||
if (Keyboard.IsPressed(Key.A))
|
||||
if (Keyboard.IsPressed(MotionKey.P1_LEFT))//if (Keyboard.IsPressed(Corekey.A))
|
||||
{
|
||||
short1 &= ~0x0002;
|
||||
}
|
||||
@ -268,7 +268,7 @@ namespace mame
|
||||
{
|
||||
short1 |= 0x0002;
|
||||
}
|
||||
if (Keyboard.IsPressed(Key.S))
|
||||
if (Keyboard.IsPressed(MotionKey.P1_DOWN))//if (Keyboard.IsPressed(Corekey.S))
|
||||
{
|
||||
short1 &= ~0x0004;
|
||||
}
|
||||
@ -276,7 +276,7 @@ namespace mame
|
||||
{
|
||||
short1 |= 0x0004;
|
||||
}
|
||||
if (Keyboard.IsPressed(Key.W))
|
||||
if (Keyboard.IsPressed(MotionKey.P1_UP))//if (Keyboard.IsPressed(Corekey.W))
|
||||
{
|
||||
short1 &= ~0x0008;
|
||||
}
|
||||
@ -284,7 +284,7 @@ namespace mame
|
||||
{
|
||||
short1 |= 0x0008;
|
||||
}
|
||||
if (Keyboard.IsPressed(Key.J))
|
||||
if (Keyboard.IsPressed(MotionKey.P1_BTN_1))//if (Keyboard.IsPressed(Corekey.J))
|
||||
{
|
||||
short1 &= ~0x0010;
|
||||
}
|
||||
@ -292,7 +292,7 @@ namespace mame
|
||||
{
|
||||
short1 |= 0x0010;
|
||||
}
|
||||
if (Keyboard.IsPressed(Key.K))
|
||||
if (Keyboard.IsPressed(MotionKey.P1_BTN_2))//if (Keyboard.IsPressed(Corekey.K))
|
||||
{
|
||||
short1 &= ~0x0020;
|
||||
}
|
||||
@ -300,7 +300,7 @@ namespace mame
|
||||
{
|
||||
short1 |= 0x0020;
|
||||
}
|
||||
if (Keyboard.IsPressed(Key.L))
|
||||
if (Keyboard.IsPressed(MotionKey.P1_UNKNOW_E))//if (Keyboard.IsPressed(Corekey.L))
|
||||
{
|
||||
short0 &= ~0x0200;
|
||||
}
|
||||
@ -308,7 +308,7 @@ namespace mame
|
||||
{
|
||||
short0 |= 0x0200;
|
||||
}
|
||||
if (Keyboard.IsPressed(Key.U))
|
||||
if (Keyboard.IsPressed(MotionKey.P1_BTN_3))//if (Keyboard.IsPressed(Corekey.U))
|
||||
{
|
||||
short1 &= ~0x0040;
|
||||
}
|
||||
@ -316,7 +316,7 @@ namespace mame
|
||||
{
|
||||
short1 |= 0x0040;
|
||||
}
|
||||
if (Keyboard.IsPressed(Key.I))
|
||||
if (Keyboard.IsPressed(MotionKey.P1_BTN_4))//if (Keyboard.IsPressed(Corekey.I))
|
||||
{
|
||||
short1 &= ~0x0080;
|
||||
}
|
||||
@ -324,7 +324,7 @@ namespace mame
|
||||
{
|
||||
short1 |= 0x0080;
|
||||
}
|
||||
if (Keyboard.IsPressed(Key.O))
|
||||
if (Keyboard.IsPressed(MotionKey.P1_UNKNOW_E))//if (Keyboard.IsPressed(Corekey.O))
|
||||
{
|
||||
short0 &= ~0x0004;
|
||||
}
|
||||
@ -332,7 +332,7 @@ namespace mame
|
||||
{
|
||||
short0 |= 0x0004;
|
||||
}
|
||||
if (Keyboard.IsPressed(Key.Right))
|
||||
if (Keyboard.IsPressed(MotionKey.P2_RIGHT))//if (Keyboard.IsPressed(Corekey.Right))
|
||||
{
|
||||
short1 &= ~0x0100;
|
||||
}
|
||||
@ -340,7 +340,7 @@ namespace mame
|
||||
{
|
||||
short1 |= 0x0100;
|
||||
}
|
||||
if (Keyboard.IsPressed(Key.Left))
|
||||
if (Keyboard.IsPressed(MotionKey.P2_LEFT))//if (Keyboard.IsPressed(Corekey.Left))
|
||||
{
|
||||
short1 &= ~0x0200;
|
||||
}
|
||||
@ -348,7 +348,7 @@ namespace mame
|
||||
{
|
||||
short1 |= 0x0200;
|
||||
}
|
||||
if (Keyboard.IsPressed(Key.Down))
|
||||
if (Keyboard.IsPressed(MotionKey.P2_DOWN)) //if (Keyboard.IsPressed(Corekey.Down))
|
||||
{
|
||||
short1 &= ~0x0400;
|
||||
}
|
||||
@ -356,7 +356,7 @@ namespace mame
|
||||
{
|
||||
short1 |= 0x0400;
|
||||
}
|
||||
if (Keyboard.IsPressed(Key.Up))
|
||||
if (Keyboard.IsPressed(MotionKey.P2_UP))//if (Keyboard.IsPressed(Corekey.Up))
|
||||
{
|
||||
short1 &= ~0x0800;
|
||||
}
|
||||
@ -364,7 +364,7 @@ namespace mame
|
||||
{
|
||||
short1 |= 0x0800;
|
||||
}
|
||||
if (Keyboard.IsPressed(Key.NumPad1))
|
||||
if (Keyboard.IsPressed(MotionKey.P2_BTN_1))//if (Keyboard.IsPressed(Corekey.NumPad1))
|
||||
{
|
||||
short1 &= ~0x1000;
|
||||
}
|
||||
@ -372,7 +372,7 @@ namespace mame
|
||||
{
|
||||
short1 |= 0x1000;
|
||||
}
|
||||
if (Keyboard.IsPressed(Key.NumPad2))
|
||||
if (Keyboard.IsPressed(MotionKey.P2_BTN_2))//if (Keyboard.IsPressed(Corekey.NumPad2))
|
||||
{
|
||||
short1 &= ~0x2000;
|
||||
}
|
||||
@ -380,7 +380,7 @@ namespace mame
|
||||
{
|
||||
short1 |= 0x2000;
|
||||
}
|
||||
if (Keyboard.IsPressed(Key.NumPad3))
|
||||
if (Keyboard.IsPressed(MotionKey.P2_UNKNOW_E))//if (Keyboard.IsPressed(Corekey.NumPad3))
|
||||
{
|
||||
short0 &= ~0x0400;
|
||||
}
|
||||
@ -388,7 +388,7 @@ namespace mame
|
||||
{
|
||||
short0 |= 0x0400;
|
||||
}
|
||||
if (Keyboard.IsPressed(Key.NumPad4))
|
||||
if (Keyboard.IsPressed(MotionKey.P2_BTN_3))//if (Keyboard.IsPressed(Corekey.NumPad4))
|
||||
{
|
||||
short1 &= ~0x4000;
|
||||
}
|
||||
@ -396,7 +396,7 @@ namespace mame
|
||||
{
|
||||
short1 |= 0x4000;
|
||||
}
|
||||
if (Keyboard.IsPressed(Key.NumPad5))
|
||||
if (Keyboard.IsPressed(MotionKey.P2_BTN_4))//if (Keyboard.IsPressed(Corekey.NumPad5))
|
||||
{
|
||||
short1 &= unchecked((short)~0x8000);
|
||||
}
|
||||
@ -404,7 +404,7 @@ namespace mame
|
||||
{
|
||||
short1 |= unchecked((short)0x8000);
|
||||
}
|
||||
if (Keyboard.IsPressed(Key.NumPad6))
|
||||
if (Keyboard.IsPressed(MotionKey.P2_UNKNOW_F))//if (Keyboard.IsPressed(Corekey.NumPad6))
|
||||
{
|
||||
short0 &= ~0x0100;
|
||||
}
|
||||
@ -412,7 +412,7 @@ namespace mame
|
||||
{
|
||||
short0 |= 0x0100;
|
||||
}
|
||||
if (Keyboard.IsPressed(Key.R))
|
||||
if (Keyboard.IsPressed(MotionKey.UNKNOW_R)) //if (Keyboard.IsPressed(Corekey.R))
|
||||
{
|
||||
shorts &= ~0x0004;
|
||||
}
|
||||
@ -420,7 +420,7 @@ namespace mame
|
||||
{
|
||||
shorts |= 0x0004;
|
||||
}
|
||||
if (Keyboard.IsPressed(Key.T))
|
||||
if (Keyboard.IsPressed(MotionKey.UNKNOW_T)) //if (Keyboard.IsPressed(Corekey.T))
|
||||
{
|
||||
//sbyte0 &= ~0x40;
|
||||
}
|
||||
@ -431,7 +431,7 @@ namespace mame
|
||||
}
|
||||
public static void loop_inputports_sfjp()
|
||||
{
|
||||
if (Keyboard.IsPressed(Key.D5))
|
||||
if (Keyboard.IsPressed(MotionKey.P1_INSERT_COIN))//if (Keyboard.IsPressed(Corekey.D5))
|
||||
{
|
||||
shortc &= ~0x0001;
|
||||
}
|
||||
@ -439,7 +439,7 @@ namespace mame
|
||||
{
|
||||
shortc |= 0x0001;
|
||||
}
|
||||
if (Keyboard.IsPressed(Key.D6))
|
||||
if (Keyboard.IsPressed(MotionKey.P2_INSERT_COIN))//if (Keyboard.IsPressed(Corekey.D6))
|
||||
{
|
||||
shortc &= ~0x0002;
|
||||
}
|
||||
@ -447,7 +447,7 @@ namespace mame
|
||||
{
|
||||
shortc |= 0x0002;
|
||||
}
|
||||
if (Keyboard.IsPressed(Key.D1))
|
||||
if (Keyboard.IsPressed(MotionKey.P1_GAMESTART))//if (Keyboard.IsPressed(Corekey.D1))
|
||||
{
|
||||
shorts &= ~0x0001;
|
||||
}
|
||||
@ -455,7 +455,7 @@ namespace mame
|
||||
{
|
||||
shorts |= 0x0001;
|
||||
}
|
||||
if (Keyboard.IsPressed(Key.D2))
|
||||
if (Keyboard.IsPressed(MotionKey.P2_GAMESTART))//if (Keyboard.IsPressed(Corekey.D2))
|
||||
{
|
||||
shorts &= ~0x0002;
|
||||
}
|
||||
@ -463,7 +463,7 @@ namespace mame
|
||||
{
|
||||
shorts |= 0x0002;
|
||||
}
|
||||
if (Keyboard.IsPressed(Key.D))
|
||||
if (Keyboard.IsPressed(MotionKey.P1_RIGHT))//if (Keyboard.IsPressed(Corekey.D))
|
||||
{
|
||||
short1 &= ~0x0001;
|
||||
}
|
||||
@ -471,7 +471,7 @@ namespace mame
|
||||
{
|
||||
short1 |= 0x0001;
|
||||
}
|
||||
if (Keyboard.IsPressed(Key.A))
|
||||
if (Keyboard.IsPressed(MotionKey.P1_LEFT))//if (Keyboard.IsPressed(Corekey.A))
|
||||
{
|
||||
short1 &= ~0x0002;
|
||||
}
|
||||
@ -479,7 +479,7 @@ namespace mame
|
||||
{
|
||||
short1 |= 0x0002;
|
||||
}
|
||||
if (Keyboard.IsPressed(Key.S))
|
||||
if (Keyboard.IsPressed(MotionKey.P1_DOWN))//if (Keyboard.IsPressed(Corekey.S))
|
||||
{
|
||||
short1 &= ~0x0004;
|
||||
}
|
||||
@ -487,7 +487,7 @@ namespace mame
|
||||
{
|
||||
short1 |= 0x0004;
|
||||
}
|
||||
if (Keyboard.IsPressed(Key.W))
|
||||
if (Keyboard.IsPressed(MotionKey.P1_UP))//if (Keyboard.IsPressed(Corekey.W))
|
||||
{
|
||||
short1 &= ~0x0008;
|
||||
}
|
||||
@ -495,7 +495,7 @@ namespace mame
|
||||
{
|
||||
short1 |= 0x0008;
|
||||
}
|
||||
if (Keyboard.IsPressed(Key.J))
|
||||
if (Keyboard.IsPressed(MotionKey.P1_BTN_1))//if (Keyboard.IsPressed(Corekey.J))
|
||||
{
|
||||
short1 &= ~0x0100;
|
||||
}
|
||||
@ -503,7 +503,7 @@ namespace mame
|
||||
{
|
||||
short1 |= 0x0100;
|
||||
}
|
||||
if (Keyboard.IsPressed(Key.K))
|
||||
if (Keyboard.IsPressed(MotionKey.P1_BTN_2))//if (Keyboard.IsPressed(Corekey.K))
|
||||
{
|
||||
short1 &= ~0x0200;
|
||||
}
|
||||
@ -511,7 +511,7 @@ namespace mame
|
||||
{
|
||||
short1 |= 0x0200;
|
||||
}
|
||||
if (Keyboard.IsPressed(Key.L))
|
||||
if (Keyboard.IsPressed(MotionKey.P1_UNKNOW_E))//if (Keyboard.IsPressed(Corekey.L))
|
||||
{
|
||||
short1 &= ~0x0400;
|
||||
}
|
||||
@ -519,7 +519,7 @@ namespace mame
|
||||
{
|
||||
short1 |= 0x0400;
|
||||
}
|
||||
if (Keyboard.IsPressed(Key.U))
|
||||
if (Keyboard.IsPressed(MotionKey.P1_BTN_3))//if (Keyboard.IsPressed(Corekey.U))
|
||||
{
|
||||
short1 &= ~0x1000;
|
||||
}
|
||||
@ -527,7 +527,7 @@ namespace mame
|
||||
{
|
||||
short1 |= 0x1000;
|
||||
}
|
||||
if (Keyboard.IsPressed(Key.I))
|
||||
if (Keyboard.IsPressed(MotionKey.P1_BTN_4))//if (Keyboard.IsPressed(Corekey.I))
|
||||
{
|
||||
short1 &= ~0x2000;
|
||||
}
|
||||
@ -535,7 +535,7 @@ namespace mame
|
||||
{
|
||||
short1 |= 0x2000;
|
||||
}
|
||||
if (Keyboard.IsPressed(Key.O))
|
||||
if (Keyboard.IsPressed(MotionKey.P1_UNKNOW_E))//if (Keyboard.IsPressed(Corekey.O))
|
||||
{
|
||||
short1 &= ~0x4000;
|
||||
}
|
||||
@ -543,7 +543,7 @@ namespace mame
|
||||
{
|
||||
short1 |= 0x4000;
|
||||
}
|
||||
if (Keyboard.IsPressed(Key.Right))
|
||||
if (Keyboard.IsPressed(MotionKey.P2_RIGHT))//if (Keyboard.IsPressed(Corekey.Right))
|
||||
{
|
||||
short2 &= ~0x0001;
|
||||
}
|
||||
@ -551,7 +551,7 @@ namespace mame
|
||||
{
|
||||
short2 |= 0x0001;
|
||||
}
|
||||
if (Keyboard.IsPressed(Key.Left))
|
||||
if (Keyboard.IsPressed(MotionKey.P2_LEFT))//if (Keyboard.IsPressed(Corekey.Left))
|
||||
{
|
||||
short2 &= ~0x0002;
|
||||
}
|
||||
@ -559,7 +559,7 @@ namespace mame
|
||||
{
|
||||
short2 |= 0x0002;
|
||||
}
|
||||
if (Keyboard.IsPressed(Key.Down))
|
||||
if (Keyboard.IsPressed(MotionKey.P2_DOWN)) //if (Keyboard.IsPressed(Corekey.Down))
|
||||
{
|
||||
short2 &= ~0x0004;
|
||||
}
|
||||
@ -567,7 +567,7 @@ namespace mame
|
||||
{
|
||||
short2 |= 0x0004;
|
||||
}
|
||||
if (Keyboard.IsPressed(Key.Up))
|
||||
if (Keyboard.IsPressed(MotionKey.P2_UP))//if (Keyboard.IsPressed(Corekey.Up))
|
||||
{
|
||||
short2 &= ~0x0008;
|
||||
}
|
||||
@ -575,7 +575,7 @@ namespace mame
|
||||
{
|
||||
short2 |= 0x0008;
|
||||
}
|
||||
if (Keyboard.IsPressed(Key.NumPad1))
|
||||
if (Keyboard.IsPressed(MotionKey.P2_BTN_1))//if (Keyboard.IsPressed(Corekey.NumPad1))
|
||||
{
|
||||
short2 &= ~0x0100;
|
||||
}
|
||||
@ -583,7 +583,7 @@ namespace mame
|
||||
{
|
||||
short2 |= 0x0100;
|
||||
}
|
||||
if (Keyboard.IsPressed(Key.NumPad2))
|
||||
if (Keyboard.IsPressed(MotionKey.P2_BTN_2))//if (Keyboard.IsPressed(Corekey.NumPad2))
|
||||
{
|
||||
short2 &= ~0x0200;
|
||||
}
|
||||
@ -591,7 +591,7 @@ namespace mame
|
||||
{
|
||||
short2 |= 0x0200;
|
||||
}
|
||||
if (Keyboard.IsPressed(Key.NumPad3))
|
||||
if (Keyboard.IsPressed(MotionKey.P2_UNKNOW_E))//if (Keyboard.IsPressed(Corekey.NumPad3))
|
||||
{
|
||||
short2 &= ~0x0400;
|
||||
}
|
||||
@ -599,7 +599,7 @@ namespace mame
|
||||
{
|
||||
short2 |= 0x0400;
|
||||
}
|
||||
if (Keyboard.IsPressed(Key.NumPad4))
|
||||
if (Keyboard.IsPressed(MotionKey.P2_BTN_3))//if (Keyboard.IsPressed(Corekey.NumPad4))
|
||||
{
|
||||
short2 &= ~0x1000;
|
||||
}
|
||||
@ -607,7 +607,7 @@ namespace mame
|
||||
{
|
||||
short2 |= 0x1000;
|
||||
}
|
||||
if (Keyboard.IsPressed(Key.NumPad5))
|
||||
if (Keyboard.IsPressed(MotionKey.P2_BTN_4))//if (Keyboard.IsPressed(Corekey.NumPad5))
|
||||
{
|
||||
short2 &= ~0x2000;
|
||||
}
|
||||
@ -615,7 +615,7 @@ namespace mame
|
||||
{
|
||||
short2 |= 0x2000;
|
||||
}
|
||||
if (Keyboard.IsPressed(Key.NumPad6))
|
||||
if (Keyboard.IsPressed(MotionKey.P2_UNKNOW_F))//if (Keyboard.IsPressed(Corekey.NumPad6))
|
||||
{
|
||||
short2 &= ~0x4000;
|
||||
}
|
||||
@ -623,7 +623,7 @@ namespace mame
|
||||
{
|
||||
short2 |= 0x4000;
|
||||
}
|
||||
if (Keyboard.IsPressed(Key.R))
|
||||
if (Keyboard.IsPressed(MotionKey.UNKNOW_R)) //if (Keyboard.IsPressed(Corekey.R))
|
||||
{
|
||||
shorts &= ~0x0004;
|
||||
}
|
||||
@ -631,7 +631,7 @@ namespace mame
|
||||
{
|
||||
shorts |= 0x0004;
|
||||
}
|
||||
if (Keyboard.IsPressed(Key.T))
|
||||
if (Keyboard.IsPressed(MotionKey.UNKNOW_T)) //if (Keyboard.IsPressed(Corekey.T))
|
||||
{
|
||||
//sbyte0 &= ~0x40;
|
||||
}
|
||||
@ -642,7 +642,7 @@ namespace mame
|
||||
}
|
||||
public static void loop_inputports_sfan()
|
||||
{
|
||||
if (Keyboard.IsPressed(Key.D5))
|
||||
if (Keyboard.IsPressed(MotionKey.P1_INSERT_COIN))//if (Keyboard.IsPressed(Corekey.D5))
|
||||
{
|
||||
shortc &= ~0x0001;
|
||||
}
|
||||
@ -650,7 +650,7 @@ namespace mame
|
||||
{
|
||||
shortc |= 0x0001;
|
||||
}
|
||||
if (Keyboard.IsPressed(Key.D6))
|
||||
if (Keyboard.IsPressed(MotionKey.P2_INSERT_COIN))//if (Keyboard.IsPressed(Corekey.D6))
|
||||
{
|
||||
shortc &= ~0x0002;
|
||||
}
|
||||
@ -658,7 +658,7 @@ namespace mame
|
||||
{
|
||||
shortc |= 0x0002;
|
||||
}
|
||||
if (Keyboard.IsPressed(Key.D1))
|
||||
if (Keyboard.IsPressed(MotionKey.P1_GAMESTART))//if (Keyboard.IsPressed(Corekey.D1))
|
||||
{
|
||||
shorts &= ~0x0001;
|
||||
}
|
||||
@ -666,7 +666,7 @@ namespace mame
|
||||
{
|
||||
shorts |= 0x0001;
|
||||
}
|
||||
if (Keyboard.IsPressed(Key.D2))
|
||||
if (Keyboard.IsPressed(MotionKey.P2_GAMESTART))//if (Keyboard.IsPressed(Corekey.D2))
|
||||
{
|
||||
shorts &= ~0x0002;
|
||||
}
|
||||
@ -674,7 +674,7 @@ namespace mame
|
||||
{
|
||||
shorts |= 0x0002;
|
||||
}
|
||||
if (Keyboard.IsPressed(Key.D))
|
||||
if (Keyboard.IsPressed(MotionKey.P1_RIGHT))//if (Keyboard.IsPressed(Corekey.D))
|
||||
{
|
||||
short0 &= ~0x0001;
|
||||
}
|
||||
@ -682,7 +682,7 @@ namespace mame
|
||||
{
|
||||
short0 |= 0x0001;
|
||||
}
|
||||
if (Keyboard.IsPressed(Key.A))
|
||||
if (Keyboard.IsPressed(MotionKey.P1_LEFT))//if (Keyboard.IsPressed(Corekey.A))
|
||||
{
|
||||
short0 &= ~0x0002;
|
||||
}
|
||||
@ -690,7 +690,7 @@ namespace mame
|
||||
{
|
||||
short0 |= 0x0002;
|
||||
}
|
||||
if (Keyboard.IsPressed(Key.S))
|
||||
if (Keyboard.IsPressed(MotionKey.P1_DOWN))//if (Keyboard.IsPressed(Corekey.S))
|
||||
{
|
||||
short0 &= ~0x0004;
|
||||
}
|
||||
@ -698,7 +698,7 @@ namespace mame
|
||||
{
|
||||
short0 |= 0x0004;
|
||||
}
|
||||
if (Keyboard.IsPressed(Key.W))
|
||||
if (Keyboard.IsPressed(MotionKey.P1_UP))//if (Keyboard.IsPressed(Corekey.W))
|
||||
{
|
||||
short0 &= ~0x0008;
|
||||
}
|
||||
@ -706,7 +706,7 @@ namespace mame
|
||||
{
|
||||
short0 |= 0x0008;
|
||||
}
|
||||
if (Keyboard.IsPressed(Key.J))
|
||||
if (Keyboard.IsPressed(MotionKey.P1_BTN_1))//if (Keyboard.IsPressed(Corekey.J))
|
||||
{
|
||||
sbyte1 |= 0x01;
|
||||
}
|
||||
@ -714,7 +714,7 @@ namespace mame
|
||||
{
|
||||
sbyte1 &= ~0x01;
|
||||
}
|
||||
if (Keyboard.IsPressed(Key.K))
|
||||
if (Keyboard.IsPressed(MotionKey.P1_BTN_2))//if (Keyboard.IsPressed(Corekey.K))
|
||||
{
|
||||
sbyte1 |= 0x02;
|
||||
}
|
||||
@ -722,7 +722,7 @@ namespace mame
|
||||
{
|
||||
sbyte1 &= ~0x02;
|
||||
}
|
||||
if (Keyboard.IsPressed(Key.L))
|
||||
if (Keyboard.IsPressed(MotionKey.P1_UNKNOW_E))//if (Keyboard.IsPressed(Corekey.L))
|
||||
{
|
||||
sbyte1 |= 0x04;
|
||||
}
|
||||
@ -730,7 +730,7 @@ namespace mame
|
||||
{
|
||||
sbyte1 &= ~0x04;
|
||||
}
|
||||
if (Keyboard.IsPressed(Key.U))
|
||||
if (Keyboard.IsPressed(MotionKey.P1_BTN_3))//if (Keyboard.IsPressed(Corekey.U))
|
||||
{
|
||||
sbyte2 |= 0x01;
|
||||
}
|
||||
@ -738,7 +738,7 @@ namespace mame
|
||||
{
|
||||
sbyte2 &= ~0x01;
|
||||
}
|
||||
if (Keyboard.IsPressed(Key.I))
|
||||
if (Keyboard.IsPressed(MotionKey.P1_BTN_4))//if (Keyboard.IsPressed(Corekey.I))
|
||||
{
|
||||
sbyte2 |= 0x02;
|
||||
}
|
||||
@ -746,7 +746,7 @@ namespace mame
|
||||
{
|
||||
sbyte2 &= ~0x02;
|
||||
}
|
||||
if (Keyboard.IsPressed(Key.O))
|
||||
if (Keyboard.IsPressed(MotionKey.P1_UNKNOW_E))//if (Keyboard.IsPressed(Corekey.O))
|
||||
{
|
||||
sbyte2 |= 0x04;
|
||||
}
|
||||
@ -754,7 +754,7 @@ namespace mame
|
||||
{
|
||||
sbyte2 &= ~0x04;
|
||||
}
|
||||
if (Keyboard.IsPressed(Key.Right))
|
||||
if (Keyboard.IsPressed(MotionKey.P2_RIGHT))//if (Keyboard.IsPressed(Corekey.Right))
|
||||
{
|
||||
short0 &= ~0x0100;
|
||||
}
|
||||
@ -762,7 +762,7 @@ namespace mame
|
||||
{
|
||||
short0 |= 0x0100;
|
||||
}
|
||||
if (Keyboard.IsPressed(Key.Left))
|
||||
if (Keyboard.IsPressed(MotionKey.P2_LEFT))//if (Keyboard.IsPressed(Corekey.Left))
|
||||
{
|
||||
short0 &= ~0x0200;
|
||||
}
|
||||
@ -770,7 +770,7 @@ namespace mame
|
||||
{
|
||||
short0 |= 0x0200;
|
||||
}
|
||||
if (Keyboard.IsPressed(Key.Down))
|
||||
if (Keyboard.IsPressed(MotionKey.P2_DOWN)) //if (Keyboard.IsPressed(Corekey.Down))
|
||||
{
|
||||
short0 &= ~0x0400;
|
||||
}
|
||||
@ -778,7 +778,7 @@ namespace mame
|
||||
{
|
||||
short0 |= 0x0400;
|
||||
}
|
||||
if (Keyboard.IsPressed(Key.Up))
|
||||
if (Keyboard.IsPressed(MotionKey.P2_UP))//if (Keyboard.IsPressed(Corekey.Up))
|
||||
{
|
||||
short0 &= ~0x0800;
|
||||
}
|
||||
@ -786,7 +786,7 @@ namespace mame
|
||||
{
|
||||
short0 |= 0x0800;
|
||||
}
|
||||
if (Keyboard.IsPressed(Key.NumPad1))
|
||||
if (Keyboard.IsPressed(MotionKey.P2_BTN_1))//if (Keyboard.IsPressed(Corekey.NumPad1))
|
||||
{
|
||||
sbyte3 |= 0x01;
|
||||
}
|
||||
@ -794,7 +794,7 @@ namespace mame
|
||||
{
|
||||
sbyte3 &= ~0x01;
|
||||
}
|
||||
if (Keyboard.IsPressed(Key.NumPad2))
|
||||
if (Keyboard.IsPressed(MotionKey.P2_BTN_2))//if (Keyboard.IsPressed(Corekey.NumPad2))
|
||||
{
|
||||
sbyte3 |= 0x02;
|
||||
}
|
||||
@ -802,7 +802,7 @@ namespace mame
|
||||
{
|
||||
sbyte3 &= ~0x02;
|
||||
}
|
||||
if (Keyboard.IsPressed(Key.NumPad3))
|
||||
if (Keyboard.IsPressed(MotionKey.P2_UNKNOW_E))//if (Keyboard.IsPressed(Corekey.NumPad3))
|
||||
{
|
||||
sbyte3 |= 0x04;
|
||||
}
|
||||
@ -810,7 +810,7 @@ namespace mame
|
||||
{
|
||||
sbyte3 &= ~0x04;
|
||||
}
|
||||
if (Keyboard.IsPressed(Key.NumPad4))
|
||||
if (Keyboard.IsPressed(MotionKey.P2_BTN_3))//if (Keyboard.IsPressed(Corekey.NumPad4))
|
||||
{
|
||||
sbyte4 |= 0x01;
|
||||
}
|
||||
@ -818,7 +818,7 @@ namespace mame
|
||||
{
|
||||
sbyte4 &= ~0x01;
|
||||
}
|
||||
if (Keyboard.IsPressed(Key.NumPad5))
|
||||
if (Keyboard.IsPressed(MotionKey.P2_BTN_4))//if (Keyboard.IsPressed(Corekey.NumPad5))
|
||||
{
|
||||
sbyte4 &= ~0x02;
|
||||
}
|
||||
@ -826,7 +826,7 @@ namespace mame
|
||||
{
|
||||
sbyte4 |= 0x02;
|
||||
}
|
||||
if (Keyboard.IsPressed(Key.NumPad6))
|
||||
if (Keyboard.IsPressed(MotionKey.P2_UNKNOW_F))//if (Keyboard.IsPressed(Corekey.NumPad6))
|
||||
{
|
||||
sbyte4 |= 0x04;
|
||||
}
|
||||
@ -834,7 +834,7 @@ namespace mame
|
||||
{
|
||||
sbyte4 &= ~0x04;
|
||||
}
|
||||
if (Keyboard.IsPressed(Key.R))
|
||||
if (Keyboard.IsPressed(MotionKey.UNKNOW_R)) //if (Keyboard.IsPressed(Corekey.R))
|
||||
{
|
||||
shorts &= ~0x0004;
|
||||
}
|
||||
@ -842,7 +842,7 @@ namespace mame
|
||||
{
|
||||
shorts |= 0x0004;
|
||||
}
|
||||
if (Keyboard.IsPressed(Key.T))
|
||||
if (Keyboard.IsPressed(MotionKey.UNKNOW_T)) //if (Keyboard.IsPressed(Corekey.T))
|
||||
{
|
||||
//sbyte0 &= ~0x40;
|
||||
}
|
||||
|
@ -1,6 +1,6 @@
|
||||
using cpu.z80;
|
||||
|
||||
namespace mame
|
||||
namespace MAME.Core
|
||||
{
|
||||
public partial class Capcom
|
||||
{
|
||||
|
@ -3,7 +3,7 @@ using cpu.m6809;
|
||||
using cpu.z80;
|
||||
using System.IO;
|
||||
|
||||
namespace mame
|
||||
namespace MAME.Core
|
||||
{
|
||||
public partial class Capcom
|
||||
{
|
||||
@ -30,12 +30,12 @@ namespace mame
|
||||
writer.Write(Memory.audioram, 0, 0x800);
|
||||
Z80A.zz1[0].SaveStateBinary(writer);
|
||||
Cpuint.SaveStateBinary(writer);
|
||||
writer.Write(Timer.global_basetime.seconds);
|
||||
writer.Write(Timer.global_basetime.attoseconds);
|
||||
writer.Write(EmuTimer.global_basetime.seconds);
|
||||
writer.Write(EmuTimer.global_basetime.attoseconds);
|
||||
Video.SaveStateBinary(writer);
|
||||
writer.Write(Sound.last_update_second);
|
||||
Cpuexec.SaveStateBinary(writer);
|
||||
Timer.SaveStateBinary(writer);
|
||||
EmuTimer.SaveStateBinary(writer);
|
||||
AY8910.AA8910[0].SaveStateBinary(writer);
|
||||
AY8910.AA8910[1].SaveStateBinary(writer);
|
||||
YM2203.FF2203[0].SaveStateBinary(writer);
|
||||
@ -76,12 +76,12 @@ namespace mame
|
||||
Memory.audioram = reader.ReadBytes(0x800);
|
||||
Z80A.zz1[0].LoadStateBinary(reader);
|
||||
Cpuint.LoadStateBinary(reader);
|
||||
Timer.global_basetime.seconds = reader.ReadInt32();
|
||||
Timer.global_basetime.attoseconds = reader.ReadInt64();
|
||||
EmuTimer.global_basetime.seconds = reader.ReadInt32();
|
||||
EmuTimer.global_basetime.attoseconds = reader.ReadInt64();
|
||||
Video.LoadStateBinary(reader);
|
||||
Sound.last_update_second = reader.ReadInt32();
|
||||
Cpuexec.LoadStateBinary(reader);
|
||||
Timer.LoadStateBinary(reader);
|
||||
EmuTimer.LoadStateBinary(reader);
|
||||
AY8910.AA8910[0].LoadStateBinary(reader);
|
||||
AY8910.AA8910[1].LoadStateBinary(reader);
|
||||
YM2203.FF2203[0].LoadStateBinary(reader);
|
||||
@ -130,12 +130,12 @@ namespace mame
|
||||
Z80A.zz1[0].SaveStateBinary(writer);
|
||||
Z80A.zz1[1].SaveStateBinary(writer);
|
||||
Cpuint.SaveStateBinary(writer);
|
||||
writer.Write(Timer.global_basetime.seconds);
|
||||
writer.Write(Timer.global_basetime.attoseconds);
|
||||
writer.Write(EmuTimer.global_basetime.seconds);
|
||||
writer.Write(EmuTimer.global_basetime.attoseconds);
|
||||
Video.SaveStateBinary(writer);
|
||||
writer.Write(Sound.last_update_second);
|
||||
Cpuexec.SaveStateBinary(writer);
|
||||
Timer.SaveStateBinary(writer);
|
||||
EmuTimer.SaveStateBinary(writer);
|
||||
YM2151.SaveStateBinary(writer);
|
||||
MSM5205.mm1[0].SaveStateBinary(writer);
|
||||
MSM5205.mm1[1].SaveStateBinary(writer);
|
||||
@ -179,12 +179,12 @@ namespace mame
|
||||
Z80A.zz1[0].LoadStateBinary(reader);
|
||||
Z80A.zz1[1].LoadStateBinary(reader);
|
||||
Cpuint.LoadStateBinary(reader);
|
||||
Timer.global_basetime.seconds = reader.ReadInt32();
|
||||
Timer.global_basetime.attoseconds = reader.ReadInt64();
|
||||
EmuTimer.global_basetime.seconds = reader.ReadInt32();
|
||||
EmuTimer.global_basetime.attoseconds = reader.ReadInt64();
|
||||
Video.LoadStateBinary(reader);
|
||||
Sound.last_update_second = reader.ReadInt32();
|
||||
Cpuexec.LoadStateBinary(reader);
|
||||
Timer.LoadStateBinary(reader);
|
||||
EmuTimer.LoadStateBinary(reader);
|
||||
YM2151.LoadStateBinary(reader);
|
||||
MSM5205.mm1[0].LoadStateBinary(reader);
|
||||
MSM5205.mm1[1].LoadStateBinary(reader);
|
||||
|
@ -1,7 +1,7 @@
|
||||
using System;
|
||||
using System.Collections.Generic;
|
||||
|
||||
namespace mame
|
||||
namespace MAME.Core
|
||||
{
|
||||
public partial class Capcom
|
||||
{
|
||||
|
@ -1,6 +1,6 @@
|
||||
using System;
|
||||
|
||||
namespace mame
|
||||
namespace MAME.Core
|
||||
{
|
||||
public partial class Capcom
|
||||
{
|
||||
|
@ -1,7 +1,7 @@
|
||||
using System;
|
||||
using System.Collections.Generic;
|
||||
|
||||
namespace mame
|
||||
namespace MAME.Core
|
||||
{
|
||||
public partial class CPS
|
||||
{
|
||||
|
@ -1,4 +1,4 @@
|
||||
namespace mame
|
||||
namespace MAME.Core
|
||||
{
|
||||
public partial class Drawgfx
|
||||
{
|
||||
|
@ -1,63 +0,0 @@
|
||||
using Bitmap = MAME.Core.AxiBitmap.AxiBitmap;
|
||||
using Color = MAME.Core.AxiBitmap.AxiColor;
|
||||
|
||||
namespace mame
|
||||
{
|
||||
public partial class CPS
|
||||
{
|
||||
private static string[] sde2;
|
||||
private static int base_cps1_objG;
|
||||
private static int[] maskG;
|
||||
private static int[] mapsizeG;
|
||||
public static Color[] cc1G;
|
||||
public static Color m_ColorG;
|
||||
public static int nColorG, nSpriteG;
|
||||
private static byte[,] flagsmap0G, flagsmap1G, flagsmap2G;
|
||||
private static byte[,] pen_to_flags0G, pen_to_flags1G, pen_to_flags2G;
|
||||
public static byte[,] priority_bitmapG;
|
||||
private static int videocontrolG;
|
||||
public static int scrollx0, scrolly0;
|
||||
public static int scrollx1, scrolly1;
|
||||
public static int scrollx2, scrolly2;
|
||||
public static int scrollxSG, scrollySG;
|
||||
public static int[] iiCutColorG;
|
||||
public static int l0G, l1G, l2G, l3G;
|
||||
public static bool bRender0G, bRender1G, bRender2G, bRender3G;
|
||||
private static bool enable0G, enable1G, enable2G;
|
||||
private static int baseTilemap0G, baseTilemap1G, baseTilemap2G, basePaletteG;
|
||||
public static byte[] bbPaletteG;
|
||||
private static int layercontrolG, scrollrows1G;
|
||||
private static int[] rowscroll1G;
|
||||
public static int[] cps1_scrollxG, cps1_scrollyG;
|
||||
public delegate Bitmap gettileDelegateG();
|
||||
public static gettileDelegateG[] gettileDelegatesG;
|
||||
public delegate void gethighDelegateG();
|
||||
public static gethighDelegateG[] gethighDelegatesG;
|
||||
public static void GDIInit()
|
||||
{
|
||||
maskG = new int[4];
|
||||
mapsizeG = new int[3] { 0x200, 0x400, 0x800 };
|
||||
nColorG = 0xc00;
|
||||
sde2 = new string[] { "," };
|
||||
scrollxSG = 0;
|
||||
scrollySG = 0;
|
||||
bbPaletteG = new byte[nColorG * 2];
|
||||
rowscroll1G = new int[1024];
|
||||
cps1_scrollxG = new int[3];
|
||||
cps1_scrollyG = new int[3];
|
||||
gettileDelegatesG = new gettileDelegateG[]{
|
||||
};
|
||||
gethighDelegatesG = new gethighDelegateG[]{
|
||||
null,
|
||||
};
|
||||
flagsmap0G = new byte[0x200, 0x200];
|
||||
flagsmap1G = new byte[0x400, 0x400];
|
||||
flagsmap2G = new byte[0x800, 0x800];
|
||||
pen_to_flags0G = new byte[4, 16];
|
||||
pen_to_flags1G = new byte[4, 16];
|
||||
pen_to_flags2G = new byte[4, 16];
|
||||
priority_bitmapG = new byte[0x200, 0x200];
|
||||
cc1G = new Color[nColorG];
|
||||
}
|
||||
}
|
||||
}
|
File diff suppressed because it is too large
Load Diff
@ -1,6 +1,6 @@
|
||||
using cpu.z80;
|
||||
|
||||
namespace mame
|
||||
namespace MAME.Core
|
||||
{
|
||||
public partial class CPS
|
||||
{
|
||||
|
@ -1,4 +1,4 @@
|
||||
namespace mame
|
||||
namespace MAME.Core
|
||||
{
|
||||
public partial class CPS
|
||||
{
|
||||
|
@ -2,7 +2,7 @@
|
||||
using cpu.z80;
|
||||
using System.IO;
|
||||
|
||||
namespace mame
|
||||
namespace MAME.Core
|
||||
{
|
||||
public partial class CPS
|
||||
{
|
||||
@ -31,8 +31,8 @@ namespace mame
|
||||
writer.Write(Memory.audioram, 0, 0x800);
|
||||
Z80A.zz1[0].SaveStateBinary(writer);
|
||||
Cpuint.SaveStateBinary(writer);
|
||||
writer.Write(Timer.global_basetime.seconds);
|
||||
writer.Write(Timer.global_basetime.attoseconds);
|
||||
writer.Write(EmuTimer.global_basetime.seconds);
|
||||
writer.Write(EmuTimer.global_basetime.attoseconds);
|
||||
writer.Write(Video.screenstate.frame_number);
|
||||
writer.Write(Sound.last_update_second);
|
||||
for (i = 0; i < 2; i++)
|
||||
@ -44,7 +44,7 @@ namespace mame
|
||||
writer.Write(Cpuexec.cpu[i].localtime.seconds);
|
||||
writer.Write(Cpuexec.cpu[i].localtime.attoseconds);
|
||||
}
|
||||
Timer.SaveStateBinary(writer);
|
||||
EmuTimer.SaveStateBinary(writer);
|
||||
YM2151.SaveStateBinary(writer);
|
||||
OKI6295.SaveStateBinary(writer);
|
||||
for (i = 0; i < 2; i++)
|
||||
@ -101,8 +101,8 @@ namespace mame
|
||||
writer.Write(Memory.audioram, 0, 0x800);
|
||||
Z80A.zz1[0].SaveStateBinary(writer);
|
||||
Cpuint.SaveStateBinary(writer);
|
||||
writer.Write(Timer.global_basetime.seconds);
|
||||
writer.Write(Timer.global_basetime.attoseconds);
|
||||
writer.Write(EmuTimer.global_basetime.seconds);
|
||||
writer.Write(EmuTimer.global_basetime.attoseconds);
|
||||
writer.Write(Video.screenstate.frame_number);
|
||||
writer.Write(Sound.last_update_second);
|
||||
for (i = 0; i < 2; i++)
|
||||
@ -114,7 +114,7 @@ namespace mame
|
||||
writer.Write(Cpuexec.cpu[i].localtime.seconds);
|
||||
writer.Write(Cpuexec.cpu[i].localtime.attoseconds);
|
||||
}
|
||||
Timer.SaveStateBinary(writer);
|
||||
EmuTimer.SaveStateBinary(writer);
|
||||
writer.Write(qsound_sharedram1);
|
||||
writer.Write(qsound_sharedram2);
|
||||
QSound.SaveStateBinary(writer);
|
||||
@ -164,8 +164,8 @@ namespace mame
|
||||
writer.Write(Memory.audioram, 0, 0x800);
|
||||
Z80A.zz1[0].SaveStateBinary(writer);
|
||||
Cpuint.SaveStateBinary(writer);
|
||||
writer.Write(Timer.global_basetime.seconds);
|
||||
writer.Write(Timer.global_basetime.attoseconds);
|
||||
writer.Write(EmuTimer.global_basetime.seconds);
|
||||
writer.Write(EmuTimer.global_basetime.attoseconds);
|
||||
writer.Write(Video.screenstate.frame_number);
|
||||
writer.Write(Sound.last_update_second);
|
||||
for (i = 0; i < 2; i++)
|
||||
@ -177,7 +177,7 @@ namespace mame
|
||||
writer.Write(Cpuexec.cpu[i].localtime.seconds);
|
||||
writer.Write(Cpuexec.cpu[i].localtime.attoseconds);
|
||||
}
|
||||
Timer.SaveStateBinary(writer);
|
||||
EmuTimer.SaveStateBinary(writer);
|
||||
writer.Write(qsound_sharedram1);
|
||||
writer.Write(qsound_sharedram2);
|
||||
QSound.SaveStateBinary(writer);
|
||||
@ -212,8 +212,8 @@ namespace mame
|
||||
Memory.audioram = reader.ReadBytes(0x800);
|
||||
Z80A.zz1[0].LoadStateBinary(reader);
|
||||
Cpuint.LoadStateBinary(reader);
|
||||
Timer.global_basetime.seconds = reader.ReadInt32();
|
||||
Timer.global_basetime.attoseconds = reader.ReadInt64();
|
||||
EmuTimer.global_basetime.seconds = reader.ReadInt32();
|
||||
EmuTimer.global_basetime.attoseconds = reader.ReadInt64();
|
||||
Video.screenstate.frame_number = reader.ReadInt64();
|
||||
Sound.last_update_second = reader.ReadInt32();
|
||||
for (i = 0; i < 2; i++)
|
||||
@ -225,7 +225,7 @@ namespace mame
|
||||
Cpuexec.cpu[i].localtime.seconds = reader.ReadInt32();
|
||||
Cpuexec.cpu[i].localtime.attoseconds = reader.ReadInt64();
|
||||
}
|
||||
Timer.LoadStateBinary(reader);
|
||||
EmuTimer.LoadStateBinary(reader);
|
||||
YM2151.LoadStateBinary(reader);
|
||||
OKI6295.LoadStateBinary(reader);
|
||||
for (i = 0; i < 2; i++)
|
||||
@ -282,8 +282,8 @@ namespace mame
|
||||
Memory.audioram = reader.ReadBytes(0x800);
|
||||
Z80A.zz1[0].LoadStateBinary(reader);
|
||||
Cpuint.LoadStateBinary(reader);
|
||||
Timer.global_basetime.seconds = reader.ReadInt32();
|
||||
Timer.global_basetime.attoseconds = reader.ReadInt64();
|
||||
EmuTimer.global_basetime.seconds = reader.ReadInt32();
|
||||
EmuTimer.global_basetime.attoseconds = reader.ReadInt64();
|
||||
Video.screenstate.frame_number = reader.ReadInt64();
|
||||
Sound.last_update_second = reader.ReadInt32();
|
||||
for (i = 0; i < 2; i++)
|
||||
@ -295,7 +295,7 @@ namespace mame
|
||||
Cpuexec.cpu[i].localtime.seconds = reader.ReadInt32();
|
||||
Cpuexec.cpu[i].localtime.attoseconds = reader.ReadInt64();
|
||||
}
|
||||
Timer.LoadStateBinary(reader);
|
||||
EmuTimer.LoadStateBinary(reader);
|
||||
qsound_sharedram1 = reader.ReadBytes(0x1000);
|
||||
qsound_sharedram2 = reader.ReadBytes(0x1000);
|
||||
QSound.LoadStateBinary(reader);
|
||||
@ -345,8 +345,8 @@ namespace mame
|
||||
Memory.audioram = reader.ReadBytes(0x800);
|
||||
Z80A.zz1[0].LoadStateBinary(reader);
|
||||
Cpuint.LoadStateBinary(reader);
|
||||
Timer.global_basetime.seconds = reader.ReadInt32();
|
||||
Timer.global_basetime.attoseconds = reader.ReadInt64();
|
||||
EmuTimer.global_basetime.seconds = reader.ReadInt32();
|
||||
EmuTimer.global_basetime.attoseconds = reader.ReadInt64();
|
||||
Video.screenstate.frame_number = reader.ReadInt64();
|
||||
Sound.last_update_second = reader.ReadInt32();
|
||||
for (i = 0; i < 2; i++)
|
||||
@ -358,7 +358,7 @@ namespace mame
|
||||
Cpuexec.cpu[i].localtime.seconds = reader.ReadInt32();
|
||||
Cpuexec.cpu[i].localtime.attoseconds = reader.ReadInt64();
|
||||
}
|
||||
Timer.LoadStateBinary(reader);
|
||||
EmuTimer.LoadStateBinary(reader);
|
||||
qsound_sharedram1 = reader.ReadBytes(0x1000);
|
||||
qsound_sharedram2 = reader.ReadBytes(0x1000);
|
||||
QSound.LoadStateBinary(reader);
|
||||
|
@ -1,6 +1,6 @@
|
||||
using System;
|
||||
|
||||
namespace mame
|
||||
namespace MAME.Core
|
||||
{
|
||||
public partial class CPS
|
||||
{
|
||||
|
@ -1,7 +1,7 @@
|
||||
using System;
|
||||
using System.Collections.Generic;
|
||||
|
||||
namespace mame
|
||||
namespace MAME.Core
|
||||
{
|
||||
public partial class CPS
|
||||
{
|
||||
|
@ -1,4 +1,4 @@
|
||||
namespace mame
|
||||
namespace MAME.Core
|
||||
{
|
||||
public partial class Drawgfx
|
||||
{
|
||||
|
@ -1,11 +0,0 @@
|
||||
namespace mame
|
||||
{
|
||||
public partial class Dataeast
|
||||
{
|
||||
public static bool bBg, bFg, bSprite;
|
||||
public static void GDIInit()
|
||||
{
|
||||
|
||||
}
|
||||
}
|
||||
}
|
@ -1,7 +1,7 @@
|
||||
using MAME.Core.run_interface;
|
||||
using MAME.Core;
|
||||
using System.Collections.Generic;
|
||||
|
||||
namespace mame
|
||||
namespace MAME.Core
|
||||
{
|
||||
public partial class Dataeast
|
||||
{
|
||||
@ -19,7 +19,7 @@ namespace mame
|
||||
public static List<fr1> lfr = new List<fr1>();
|
||||
public static void loop_inputports_dataeast_pcktgal()
|
||||
{
|
||||
if (Keyboard.IsPressed(Key.D5))
|
||||
if (Keyboard.IsPressed(MotionKey.P1_INSERT_COIN))//if (Keyboard.IsPressed(Corekey.D5))
|
||||
{
|
||||
byte2 &= unchecked((byte)~0x10);
|
||||
}
|
||||
@ -27,7 +27,7 @@ namespace mame
|
||||
{
|
||||
byte2 |= 0x10;
|
||||
}
|
||||
if (Keyboard.IsPressed(Key.D6))
|
||||
if (Keyboard.IsPressed(MotionKey.P2_INSERT_COIN))//if (Keyboard.IsPressed(Corekey.D6))
|
||||
{
|
||||
byte2 &= unchecked((byte)~0x20);
|
||||
}
|
||||
@ -35,7 +35,7 @@ namespace mame
|
||||
{
|
||||
byte2 |= 0x20;
|
||||
}
|
||||
if (Keyboard.IsPressed(Key.D1))
|
||||
if (Keyboard.IsPressed(MotionKey.P1_GAMESTART))//if (Keyboard.IsPressed(Corekey.D1))
|
||||
{
|
||||
byte1 &= unchecked((byte)~0x10);
|
||||
}
|
||||
@ -43,7 +43,7 @@ namespace mame
|
||||
{
|
||||
byte1 |= 0x10;
|
||||
}
|
||||
if (Keyboard.IsPressed(Key.D2))
|
||||
if (Keyboard.IsPressed(MotionKey.P2_GAMESTART))//if (Keyboard.IsPressed(Corekey.D2))
|
||||
{
|
||||
byte1 &= unchecked((byte)~0x20);
|
||||
}
|
||||
@ -51,7 +51,7 @@ namespace mame
|
||||
{
|
||||
byte1 |= 0x20;
|
||||
}
|
||||
if (Keyboard.IsPressed(Key.D))
|
||||
if (Keyboard.IsPressed(MotionKey.P1_RIGHT))//if (Keyboard.IsPressed(Corekey.D))
|
||||
{
|
||||
byte1 &= unchecked((byte)~0x01);
|
||||
}
|
||||
@ -59,7 +59,7 @@ namespace mame
|
||||
{
|
||||
byte1 |= 0x01;
|
||||
}
|
||||
if (Keyboard.IsPressed(Key.A))
|
||||
if (Keyboard.IsPressed(MotionKey.P1_LEFT))//if (Keyboard.IsPressed(Corekey.A))
|
||||
{
|
||||
byte1 &= unchecked((byte)~0x02);
|
||||
}
|
||||
@ -67,7 +67,7 @@ namespace mame
|
||||
{
|
||||
byte1 |= 0x02;
|
||||
}
|
||||
if (Keyboard.IsPressed(Key.S))
|
||||
if (Keyboard.IsPressed(MotionKey.P1_DOWN))//if (Keyboard.IsPressed(Corekey.S))
|
||||
{
|
||||
byte1 &= unchecked((byte)~0x04);
|
||||
}
|
||||
@ -75,7 +75,7 @@ namespace mame
|
||||
{
|
||||
byte1 |= 0x04;
|
||||
}
|
||||
if (Keyboard.IsPressed(Key.W))
|
||||
if (Keyboard.IsPressed(MotionKey.P1_UP))//if (Keyboard.IsPressed(Corekey.W))
|
||||
{
|
||||
byte1 &= unchecked((byte)~0x08);
|
||||
}
|
||||
@ -83,7 +83,7 @@ namespace mame
|
||||
{
|
||||
byte1 |= 0x08;
|
||||
}
|
||||
if (Keyboard.IsPressed(Key.J))
|
||||
if (Keyboard.IsPressed(MotionKey.P1_BTN_1))//if (Keyboard.IsPressed(Corekey.J))
|
||||
{
|
||||
byte1 &= unchecked((byte)~0x80);
|
||||
}
|
||||
@ -91,7 +91,7 @@ namespace mame
|
||||
{
|
||||
byte1 |= 0x80;
|
||||
}
|
||||
if (Keyboard.IsPressed(Key.K))
|
||||
if (Keyboard.IsPressed(MotionKey.P1_BTN_2))//if (Keyboard.IsPressed(Corekey.K))
|
||||
{
|
||||
byte1 &= unchecked((byte)~0x40);
|
||||
}
|
||||
@ -99,7 +99,7 @@ namespace mame
|
||||
{
|
||||
byte1 |= 0x40;
|
||||
}
|
||||
if (Keyboard.IsPressed(Key.Right))
|
||||
if (Keyboard.IsPressed(MotionKey.P2_RIGHT))//if (Keyboard.IsPressed(Corekey.Right))
|
||||
{
|
||||
byte2 &= unchecked((byte)~0x01);
|
||||
}
|
||||
@ -107,7 +107,7 @@ namespace mame
|
||||
{
|
||||
byte2 |= 0x01;
|
||||
}
|
||||
if (Keyboard.IsPressed(Key.Left))
|
||||
if (Keyboard.IsPressed(MotionKey.P2_LEFT))//if (Keyboard.IsPressed(Corekey.Left))
|
||||
{
|
||||
byte2 &= unchecked((byte)~0x02);
|
||||
}
|
||||
@ -115,7 +115,7 @@ namespace mame
|
||||
{
|
||||
byte2 |= 0x02;
|
||||
}
|
||||
if (Keyboard.IsPressed(Key.Down))
|
||||
if (Keyboard.IsPressed(MotionKey.P2_DOWN)) //if (Keyboard.IsPressed(Corekey.Down))
|
||||
{
|
||||
byte2 &= unchecked((byte)~0x04);
|
||||
}
|
||||
@ -123,7 +123,7 @@ namespace mame
|
||||
{
|
||||
byte2 |= 0x04;
|
||||
}
|
||||
if (Keyboard.IsPressed(Key.Up))
|
||||
if (Keyboard.IsPressed(MotionKey.P2_UP))//if (Keyboard.IsPressed(Corekey.Up))
|
||||
{
|
||||
byte2 &= unchecked((byte)~0x08);
|
||||
}
|
||||
@ -131,7 +131,7 @@ namespace mame
|
||||
{
|
||||
byte2 |= 0x08;
|
||||
}
|
||||
if (Keyboard.IsPressed(Key.NumPad1))
|
||||
if (Keyboard.IsPressed(MotionKey.P2_BTN_1))//if (Keyboard.IsPressed(Corekey.NumPad1))
|
||||
{
|
||||
byte2 &= unchecked((byte)~0x80);
|
||||
}
|
||||
@ -139,7 +139,7 @@ namespace mame
|
||||
{
|
||||
byte2 |= 0x80;
|
||||
}
|
||||
if (Keyboard.IsPressed(Key.NumPad2))
|
||||
if (Keyboard.IsPressed(MotionKey.P2_BTN_2))//if (Keyboard.IsPressed(Corekey.NumPad2))
|
||||
{
|
||||
byte2 &= unchecked((byte)~0x40);
|
||||
}
|
||||
@ -147,7 +147,7 @@ namespace mame
|
||||
{
|
||||
byte2 |= 0x40;
|
||||
}
|
||||
if (Keyboard.IsTriggered(Key.N))
|
||||
if (Keyboard.IsPressed(MotionKey.UNKNOW_N))//if (Keyboard.IsPressed(Corekey.N))
|
||||
{
|
||||
lfr = new List<fr1>();
|
||||
lfr.Add(new fr1((int)(Video.screenstate.frame_number + 1), 0x7f));
|
||||
@ -155,25 +155,26 @@ namespace mame
|
||||
lfr.Add(new fr1((int)(Video.screenstate.frame_number + 2 + i3), 0x7f));
|
||||
lfr.Add(new fr1((int)(Video.screenstate.frame_number + 2 + i3 + 1), 0xff));
|
||||
}
|
||||
if (Keyboard.IsTriggered(Key.U))
|
||||
if (Keyboard.IsPressed(MotionKey.P1_BTN_3))//if (Keyboard.IsPressed(Corekey.U))
|
||||
{
|
||||
lfr = new List<fr1>();
|
||||
lfr.Add(new fr1((int)(Video.screenstate.frame_number + 1), 0xf7));
|
||||
lfr.Add(new fr1((int)(Video.screenstate.frame_number + 2), 0xff));
|
||||
}
|
||||
if (Keyboard.IsTriggered(Key.I))
|
||||
if (Keyboard.IsPressed(MotionKey.P1_BTN_4))//if (Keyboard.IsPressed(Corekey.I))
|
||||
{
|
||||
lfr = new List<fr1>();
|
||||
lfr.Add(new fr1((int)(Video.screenstate.frame_number + 1), 0xfb));
|
||||
lfr.Add(new fr1((int)(Video.screenstate.frame_number + 2), 0xff));
|
||||
}
|
||||
if (Keyboard.IsTriggered(Key.V))
|
||||
|
||||
if (Keyboard.IsPressed(MotionKey.UNKNOW_V))//if (Keyboard.IsPressed(Corekey.V))
|
||||
{
|
||||
lfr = new List<fr1>();
|
||||
lfr.Add(new fr1((int)(Video.screenstate.frame_number + 1), 0xfd));
|
||||
lfr.Add(new fr1((int)(Video.screenstate.frame_number + 2), 0xff));
|
||||
}
|
||||
if (Keyboard.IsTriggered(Key.B))
|
||||
if (Keyboard.IsPressed(MotionKey.UNKNOW_B))//if (Keyboard.IsPressed(Corekey.B))
|
||||
{
|
||||
lfr = new List<fr1>();
|
||||
lfr.Add(new fr1((int)(Video.screenstate.frame_number + 1), 0xfe));
|
||||
|
@ -1,4 +1,4 @@
|
||||
namespace mame
|
||||
namespace MAME.Core
|
||||
{
|
||||
public partial class Dataeast
|
||||
{
|
||||
|
@ -1,4 +1,4 @@
|
||||
namespace mame
|
||||
namespace MAME.Core
|
||||
{
|
||||
public partial class Dataeast
|
||||
{
|
||||
|
@ -1,7 +1,7 @@
|
||||
using cpu.m6502;
|
||||
using System.IO;
|
||||
|
||||
namespace mame
|
||||
namespace MAME.Core
|
||||
{
|
||||
public partial class Dataeast
|
||||
{
|
||||
@ -25,12 +25,12 @@ namespace mame
|
||||
M6502.mm1[0].SaveStateBinary(writer);
|
||||
M6502.mm1[1].SaveStateBinary(writer);
|
||||
Cpuint.SaveStateBinary(writer);
|
||||
writer.Write(Timer.global_basetime.seconds);
|
||||
writer.Write(Timer.global_basetime.attoseconds);
|
||||
writer.Write(EmuTimer.global_basetime.seconds);
|
||||
writer.Write(EmuTimer.global_basetime.attoseconds);
|
||||
Video.SaveStateBinary(writer);
|
||||
writer.Write(Sound.last_update_second);
|
||||
Cpuexec.SaveStateBinary(writer);
|
||||
Timer.SaveStateBinary(writer);
|
||||
EmuTimer.SaveStateBinary(writer);
|
||||
AY8910.AA8910[0].SaveStateBinary(writer);
|
||||
YM2203.FF2203[0].SaveStateBinary(writer);
|
||||
YM3812.SaveStateBinary(writer);
|
||||
@ -68,12 +68,12 @@ namespace mame
|
||||
M6502.mm1[0].LoadStateBinary(reader);
|
||||
M6502.mm1[1].LoadStateBinary(reader);
|
||||
Cpuint.LoadStateBinary(reader);
|
||||
Timer.global_basetime.seconds = reader.ReadInt32();
|
||||
Timer.global_basetime.attoseconds = reader.ReadInt64();
|
||||
EmuTimer.global_basetime.seconds = reader.ReadInt32();
|
||||
EmuTimer.global_basetime.attoseconds = reader.ReadInt64();
|
||||
Video.LoadStateBinary(reader);
|
||||
Sound.last_update_second = reader.ReadInt32();
|
||||
Cpuexec.LoadStateBinary(reader);
|
||||
Timer.LoadStateBinary(reader);
|
||||
EmuTimer.LoadStateBinary(reader);
|
||||
AY8910.AA8910[0].LoadStateBinary(reader);
|
||||
YM2203.FF2203[0].LoadStateBinary(reader);
|
||||
YM3812.LoadStateBinary(reader);
|
||||
|
@ -1,6 +1,6 @@
|
||||
using System;
|
||||
|
||||
namespace mame
|
||||
namespace MAME.Core
|
||||
{
|
||||
public partial class Dataeast
|
||||
{
|
||||
|
@ -1,4 +1,4 @@
|
||||
namespace mame
|
||||
namespace MAME.Core
|
||||
{
|
||||
public partial class Dataeast
|
||||
{
|
||||
|
@ -1,10 +0,0 @@
|
||||
namespace mame
|
||||
{
|
||||
public partial class IGS011
|
||||
{
|
||||
public static void GDIInit()
|
||||
{
|
||||
|
||||
}
|
||||
}
|
||||
}
|
@ -1,4 +1,4 @@
|
||||
namespace mame
|
||||
namespace MAME.Core
|
||||
{
|
||||
public partial class IGS011
|
||||
{
|
||||
|
@ -1,12 +1,12 @@
|
||||
using MAME.Core.run_interface;
|
||||
using MAME.Core;
|
||||
|
||||
namespace mame
|
||||
namespace MAME.Core
|
||||
{
|
||||
public partial class IGS011
|
||||
{
|
||||
public static void loop_inputports_igs011_drgnwrld()
|
||||
{
|
||||
if (Keyboard.IsPressed(Key.D5))
|
||||
if (Keyboard.IsPressed(MotionKey.P1_INSERT_COIN))//if (Keyboard.IsPressed(Corekey.D5))
|
||||
{
|
||||
sbytec &= ~0x01;
|
||||
}
|
||||
@ -14,7 +14,7 @@ namespace mame
|
||||
{
|
||||
sbytec |= 0x01;
|
||||
}
|
||||
if (Keyboard.IsPressed(Key.D6))
|
||||
if (Keyboard.IsPressed(MotionKey.P2_INSERT_COIN))//if (Keyboard.IsPressed(Corekey.D6))
|
||||
{
|
||||
sbytec &= ~0x02;
|
||||
}
|
||||
@ -22,7 +22,7 @@ namespace mame
|
||||
{
|
||||
sbytec |= 0x02;
|
||||
}
|
||||
if (Keyboard.IsPressed(Key.D1))
|
||||
if (Keyboard.IsPressed(MotionKey.P1_GAMESTART))//if (Keyboard.IsPressed(Corekey.D1))
|
||||
{
|
||||
sbyte0 &= ~0x01;
|
||||
}
|
||||
@ -30,7 +30,7 @@ namespace mame
|
||||
{
|
||||
sbyte0 |= 0x01;
|
||||
}
|
||||
if (Keyboard.IsPressed(Key.D2))
|
||||
if (Keyboard.IsPressed(MotionKey.P2_GAMESTART))//if (Keyboard.IsPressed(Corekey.D2))
|
||||
{
|
||||
sbyte2 &= ~0x10;
|
||||
}
|
||||
@ -38,7 +38,8 @@ namespace mame
|
||||
{
|
||||
sbyte2 |= 0x10;
|
||||
}
|
||||
if (Keyboard.IsPressed(Key.D))// || Mouse.deltaX > 0)
|
||||
//if (Keyboard.IsPressed(Corekey.D))// || Mouse.deltaX > 0)
|
||||
if (Keyboard.IsPressed(MotionKey.P1_RIGHT))// || Mouse.deltaX > 0)
|
||||
{
|
||||
sbyte0 &= ~0x10;
|
||||
}
|
||||
@ -46,7 +47,7 @@ namespace mame
|
||||
{
|
||||
sbyte0 |= 0x10;
|
||||
}
|
||||
if (Keyboard.IsPressed(Key.A))// || Mouse.deltaX < 0)
|
||||
if (Keyboard.IsPressed(MotionKey.P1_LEFT))//if (Keyboard.IsPressed(Corekey.A))// || Mouse.deltaX < 0)
|
||||
{
|
||||
sbyte2 &= ~0x02;
|
||||
}
|
||||
@ -54,7 +55,7 @@ namespace mame
|
||||
{
|
||||
sbyte2 |= 0x02;
|
||||
}
|
||||
if (Keyboard.IsPressed(Key.S))// || Mouse.deltaY > 0)
|
||||
if (Keyboard.IsPressed(MotionKey.P1_DOWN))//if (Keyboard.IsPressed(Corekey.S))// || Mouse.deltaY > 0)
|
||||
{
|
||||
sbyte0 &= ~0x04;
|
||||
}
|
||||
@ -62,7 +63,7 @@ namespace mame
|
||||
{
|
||||
sbyte0 |= 0x04;
|
||||
}
|
||||
if (Keyboard.IsPressed(Key.W))// || Mouse.deltaY < 0)
|
||||
if (Keyboard.IsPressed(MotionKey.P1_UP))//if (Keyboard.IsPressed(Corekey.W))// || Mouse.deltaY < 0)
|
||||
{
|
||||
sbyte2 &= ~0x01;
|
||||
}
|
||||
@ -70,7 +71,7 @@ namespace mame
|
||||
{
|
||||
sbyte2 |= 0x01;
|
||||
}
|
||||
if (Keyboard.IsPressed(Key.J))// || Mouse.buttons[0] != 0)
|
||||
if (Keyboard.IsPressed(MotionKey.P1_BTN_1))//if (Keyboard.IsPressed(Corekey.J))// || Mouse.buttons[0] != 0)
|
||||
{
|
||||
sbyte2 &= ~0x04;
|
||||
}
|
||||
@ -78,7 +79,7 @@ namespace mame
|
||||
{
|
||||
sbyte2 |= 0x04;
|
||||
}
|
||||
if (Keyboard.IsPressed(Key.K))// || Mouse.buttons[1] != 0)
|
||||
if (Keyboard.IsPressed(MotionKey.P1_BTN_2))//if (Keyboard.IsPressed(Corekey.K))// || Mouse.buttons[1] != 0)
|
||||
{
|
||||
sbyte0 &= ~0x40;
|
||||
}
|
||||
@ -86,7 +87,7 @@ namespace mame
|
||||
{
|
||||
sbyte0 |= 0x40;
|
||||
}
|
||||
if (Keyboard.IsPressed(Key.L))
|
||||
if (Keyboard.IsPressed(MotionKey.P1_UNKNOW_E))//if (Keyboard.IsPressed(Corekey.L))
|
||||
{
|
||||
sbyte2 &= ~0x08;
|
||||
}
|
||||
@ -94,7 +95,7 @@ namespace mame
|
||||
{
|
||||
sbyte2 |= 0x08;
|
||||
}
|
||||
if (Keyboard.IsPressed(Key.U))
|
||||
if (Keyboard.IsPressed(MotionKey.P1_BTN_3))//if (Keyboard.IsPressed(Corekey.U))
|
||||
{
|
||||
|
||||
}
|
||||
@ -102,7 +103,7 @@ namespace mame
|
||||
{
|
||||
|
||||
}
|
||||
if (Keyboard.IsPressed(Key.I))
|
||||
if (Keyboard.IsPressed(MotionKey.P1_BTN_4))//if (Keyboard.IsPressed(Corekey.I))
|
||||
{
|
||||
|
||||
}
|
||||
@ -110,7 +111,7 @@ namespace mame
|
||||
{
|
||||
|
||||
}
|
||||
if (Keyboard.IsPressed(Key.O))
|
||||
if (Keyboard.IsPressed(MotionKey.P1_UNKNOW_E))//if (Keyboard.IsPressed(Corekey.O))
|
||||
{
|
||||
|
||||
}
|
||||
@ -118,7 +119,7 @@ namespace mame
|
||||
{
|
||||
|
||||
}
|
||||
if (Keyboard.IsPressed(Key.Right))
|
||||
if (Keyboard.IsPressed(MotionKey.P2_RIGHT))//if (Keyboard.IsPressed(Corekey.Right))
|
||||
{
|
||||
sbyte2 &= ~0x40;
|
||||
}
|
||||
@ -126,7 +127,7 @@ namespace mame
|
||||
{
|
||||
sbyte2 |= 0x40;
|
||||
}
|
||||
if (Keyboard.IsPressed(Key.Left))
|
||||
if (Keyboard.IsPressed(MotionKey.P2_LEFT))//if (Keyboard.IsPressed(Corekey.Left))
|
||||
{
|
||||
sbyte1 &= ~0x08;
|
||||
}
|
||||
@ -134,7 +135,7 @@ namespace mame
|
||||
{
|
||||
sbyte1 |= 0x08;
|
||||
}
|
||||
if (Keyboard.IsPressed(Key.Down))
|
||||
if (Keyboard.IsPressed(MotionKey.P2_DOWN)) //if (Keyboard.IsPressed(Corekey.Down))
|
||||
{
|
||||
sbyte2 &= ~0x20;
|
||||
}
|
||||
@ -142,7 +143,7 @@ namespace mame
|
||||
{
|
||||
sbyte2 |= 0x20;
|
||||
}
|
||||
if (Keyboard.IsPressed(Key.Up))
|
||||
if (Keyboard.IsPressed(MotionKey.P2_UP))//if (Keyboard.IsPressed(Corekey.Up))
|
||||
{
|
||||
sbyte1 &= ~0x02;
|
||||
}
|
||||
@ -150,7 +151,7 @@ namespace mame
|
||||
{
|
||||
sbyte1 |= 0x02;
|
||||
}
|
||||
if (Keyboard.IsPressed(Key.NumPad1))
|
||||
if (Keyboard.IsPressed(MotionKey.P2_BTN_1))//if (Keyboard.IsPressed(Corekey.NumPad1))
|
||||
{
|
||||
sbyte1 &= ~0x20;
|
||||
}
|
||||
@ -158,7 +159,7 @@ namespace mame
|
||||
{
|
||||
sbyte1 |= 0x20;
|
||||
}
|
||||
if (Keyboard.IsPressed(Key.NumPad2))
|
||||
if (Keyboard.IsPressed(MotionKey.P2_BTN_2))//if (Keyboard.IsPressed(Corekey.NumPad2))
|
||||
{
|
||||
sbyte2 &= unchecked((sbyte)~0x80);
|
||||
}
|
||||
@ -166,7 +167,7 @@ namespace mame
|
||||
{
|
||||
sbyte2 |= unchecked((sbyte)0x80);
|
||||
}
|
||||
if (Keyboard.IsPressed(Key.NumPad3))
|
||||
if (Keyboard.IsPressed(MotionKey.P2_UNKNOW_E))//if (Keyboard.IsPressed(Corekey.NumPad3))
|
||||
{
|
||||
sbyte1 &= unchecked((sbyte)~0x80);
|
||||
}
|
||||
@ -174,7 +175,7 @@ namespace mame
|
||||
{
|
||||
sbyte1 |= unchecked((sbyte)0x80);
|
||||
}
|
||||
if (Keyboard.IsPressed(Key.NumPad4))
|
||||
if (Keyboard.IsPressed(MotionKey.P2_BTN_3))//if (Keyboard.IsPressed(Corekey.NumPad4))
|
||||
{
|
||||
|
||||
}
|
||||
@ -182,7 +183,7 @@ namespace mame
|
||||
{
|
||||
|
||||
}
|
||||
if (Keyboard.IsPressed(Key.NumPad5))
|
||||
if (Keyboard.IsPressed(MotionKey.P2_BTN_4))//if (Keyboard.IsPressed(Corekey.NumPad5))
|
||||
{
|
||||
|
||||
}
|
||||
@ -190,7 +191,7 @@ namespace mame
|
||||
{
|
||||
|
||||
}
|
||||
if (Keyboard.IsPressed(Key.NumPad6))
|
||||
if (Keyboard.IsPressed(MotionKey.P2_UNKNOW_F))//if (Keyboard.IsPressed(Corekey.NumPad6))
|
||||
{
|
||||
|
||||
}
|
||||
@ -198,7 +199,7 @@ namespace mame
|
||||
{
|
||||
|
||||
}
|
||||
if (Keyboard.IsPressed(Key.R))
|
||||
if (Keyboard.IsPressed(MotionKey.UNKNOW_R)) //if (Keyboard.IsPressed(Corekey.R))
|
||||
{
|
||||
sbytec &= ~0x08;
|
||||
}
|
||||
@ -206,7 +207,7 @@ namespace mame
|
||||
{
|
||||
sbytec |= 0x08;
|
||||
}
|
||||
if (Keyboard.IsPressed(Key.T))
|
||||
if (Keyboard.IsPressed(MotionKey.UNKNOW_T)) //if (Keyboard.IsPressed(Corekey.T))
|
||||
{
|
||||
sbytec &= ~0x10;
|
||||
}
|
||||
@ -217,7 +218,8 @@ namespace mame
|
||||
}
|
||||
public static void loop_inputports_igs011_lhb()
|
||||
{
|
||||
if (Keyboard.IsPressed(Key.D5))
|
||||
/*
|
||||
if (Keyboard.IsPressed(MotionKey.P1_INSERT_COIN))//if (Keyboard.IsPressed(Corekey.D5))
|
||||
{
|
||||
sbytec &= ~0x10;
|
||||
}
|
||||
@ -225,7 +227,7 @@ namespace mame
|
||||
{
|
||||
sbytec |= 0x10;
|
||||
}
|
||||
if (Keyboard.IsPressed(Key.D1))
|
||||
if (Keyboard.IsPressed(MotionKey.P1_GAMESTART))//if (Keyboard.IsPressed(Corekey.D1))
|
||||
{
|
||||
bkey0 &= unchecked((byte)~0x20);
|
||||
}
|
||||
@ -233,7 +235,7 @@ namespace mame
|
||||
{
|
||||
bkey0 |= 0x20;
|
||||
}
|
||||
if (Keyboard.IsPressed(Key.D2))
|
||||
if (Keyboard.IsPressed(MotionKey.P2_GAMESTART))//if (Keyboard.IsPressed(Corekey.D2))
|
||||
{
|
||||
bkey1 &= unchecked((byte)~0x20);
|
||||
}
|
||||
@ -241,7 +243,7 @@ namespace mame
|
||||
{
|
||||
bkey1 |= 0x20;
|
||||
}
|
||||
if (Keyboard.IsPressed(Key.D3))
|
||||
if (Keyboard.IsPressed(Corekey.D3))
|
||||
{
|
||||
bkey4 &= unchecked((byte)~0x10);
|
||||
}
|
||||
@ -249,7 +251,7 @@ namespace mame
|
||||
{
|
||||
bkey4 |= 0x10;
|
||||
}
|
||||
if (Keyboard.IsPressed(Key.D4))
|
||||
if (Keyboard.IsPressed(Corekey.D4))
|
||||
{
|
||||
bkey4 &= unchecked((byte)~0x20);
|
||||
}
|
||||
@ -257,7 +259,7 @@ namespace mame
|
||||
{
|
||||
bkey4 |= 0x20;
|
||||
}
|
||||
if (Keyboard.IsPressed(Key.A))
|
||||
if (Keyboard.IsPressed(MotionKey.P1_LEFT))//if (Keyboard.IsPressed(Corekey.A))
|
||||
{
|
||||
bkey0 &= unchecked((byte)~0x01);
|
||||
}
|
||||
@ -265,7 +267,7 @@ namespace mame
|
||||
{
|
||||
bkey0 |= 0x01;
|
||||
}
|
||||
if (Keyboard.IsPressed(Key.B))
|
||||
if (Keyboard.IsPressed(Corekey.B))
|
||||
{
|
||||
bkey1 &= unchecked((byte)~0x01);
|
||||
}
|
||||
@ -273,7 +275,7 @@ namespace mame
|
||||
{
|
||||
bkey1 |= 0x01;
|
||||
}
|
||||
if (Keyboard.IsPressed(Key.C))
|
||||
if (Keyboard.IsPressed(Corekey.C))
|
||||
{
|
||||
bkey2 &= unchecked((byte)~0x01);
|
||||
}
|
||||
@ -281,7 +283,7 @@ namespace mame
|
||||
{
|
||||
bkey2 |= 0x01;
|
||||
}
|
||||
if (Keyboard.IsPressed(Key.D))
|
||||
if (Keyboard.IsPressed(MotionKey.P1_RIGHT))//if (Keyboard.IsPressed(Corekey.D))
|
||||
{
|
||||
bkey3 &= unchecked((byte)~0x01);
|
||||
}
|
||||
@ -289,7 +291,7 @@ namespace mame
|
||||
{
|
||||
bkey3 |= 0x01;
|
||||
}
|
||||
if (Keyboard.IsPressed(Key.E))
|
||||
if (Keyboard.IsPressed(Corekey.E))
|
||||
{
|
||||
bkey0 &= unchecked((byte)~0x02);
|
||||
}
|
||||
@ -297,7 +299,7 @@ namespace mame
|
||||
{
|
||||
bkey0 |= 0x02;
|
||||
}
|
||||
if (Keyboard.IsPressed(Key.F))
|
||||
if (Keyboard.IsPressed(Corekey.F))
|
||||
{
|
||||
bkey1 &= unchecked((byte)~0x02);
|
||||
}
|
||||
@ -305,7 +307,7 @@ namespace mame
|
||||
{
|
||||
bkey1 |= 0x02;
|
||||
}
|
||||
if (Keyboard.IsPressed(Key.G))
|
||||
if (Keyboard.IsPressed(Corekey.G))
|
||||
{
|
||||
bkey2 &= unchecked((byte)~0x02);
|
||||
}
|
||||
@ -313,7 +315,7 @@ namespace mame
|
||||
{
|
||||
bkey2 |= 0x02;
|
||||
}
|
||||
if (Keyboard.IsPressed(Key.H))
|
||||
if (Keyboard.IsPressed(Corekey.H))
|
||||
{
|
||||
bkey3 &= unchecked((byte)~0x02);
|
||||
}
|
||||
@ -321,7 +323,7 @@ namespace mame
|
||||
{
|
||||
bkey3 |= 0x02;
|
||||
}
|
||||
if (Keyboard.IsPressed(Key.I))
|
||||
if (Keyboard.IsPressed(MotionKey.P1_BTN_4))//if (Keyboard.IsPressed(Corekey.I))
|
||||
{
|
||||
bkey0 &= unchecked((byte)~0x04);
|
||||
}
|
||||
@ -329,7 +331,7 @@ namespace mame
|
||||
{
|
||||
bkey0 |= 0x04;
|
||||
}
|
||||
if (Keyboard.IsPressed(Key.J))
|
||||
if (Keyboard.IsPressed(MotionKey.P1_BTN_1))//if (Keyboard.IsPressed(Corekey.J))
|
||||
{
|
||||
bkey1 &= unchecked((byte)~0x04);
|
||||
}
|
||||
@ -337,7 +339,7 @@ namespace mame
|
||||
{
|
||||
bkey1 |= 0x04;
|
||||
}
|
||||
if (Keyboard.IsPressed(Key.K))
|
||||
if (Keyboard.IsPressed(MotionKey.P1_BTN_2))//if (Keyboard.IsPressed(Corekey.K))
|
||||
{
|
||||
bkey2 &= unchecked((byte)~0x04);
|
||||
}
|
||||
@ -345,7 +347,7 @@ namespace mame
|
||||
{
|
||||
bkey2 |= 0x04;
|
||||
}
|
||||
if (Keyboard.IsPressed(Key.L))
|
||||
if (Keyboard.IsPressed(MotionKey.P1_UNKNOW_E))//if (Keyboard.IsPressed(Corekey.L))
|
||||
{
|
||||
bkey3 &= unchecked((byte)~0x04);
|
||||
}
|
||||
@ -353,7 +355,7 @@ namespace mame
|
||||
{
|
||||
bkey3 |= 0x04;
|
||||
}
|
||||
if (Keyboard.IsPressed(Key.M))
|
||||
if (Keyboard.IsPressed(MotionKey.UNKNOW_M))//if (Keyboard.IsPressed(Corekey.M))
|
||||
{
|
||||
bkey0 &= unchecked((byte)~0x08);
|
||||
}
|
||||
@ -361,7 +363,7 @@ namespace mame
|
||||
{
|
||||
bkey0 |= 0x08;
|
||||
}
|
||||
if (Keyboard.IsPressed(Key.N))
|
||||
if (Keyboard.IsPressed(MotionKey.UNKNOW_N))//if (Keyboard.IsPressed(Corekey.N))
|
||||
{
|
||||
bkey1 &= unchecked((byte)~0x08);
|
||||
}
|
||||
@ -369,7 +371,7 @@ namespace mame
|
||||
{
|
||||
bkey1 |= 0x08;
|
||||
}
|
||||
if (Keyboard.IsPressed(Key.O))
|
||||
if (Keyboard.IsPressed(MotionKey.P1_UNKNOW_E))//if (Keyboard.IsPressed(Corekey.O))
|
||||
{
|
||||
bkey4 &= unchecked((byte)~0x04);
|
||||
}
|
||||
@ -377,7 +379,7 @@ namespace mame
|
||||
{
|
||||
bkey4 |= 0x04;
|
||||
}
|
||||
if (Keyboard.IsPressed(Key.Q))
|
||||
if (Keyboard.IsPressed(MotionKey.UNKNOW_Q))//if (Keyboard.IsPressed(Corekey.Q))
|
||||
{
|
||||
bkey0 &= unchecked((byte)~0x10);
|
||||
}
|
||||
@ -385,7 +387,7 @@ namespace mame
|
||||
{
|
||||
bkey0 |= 0x10;
|
||||
}
|
||||
if (Keyboard.IsPressed(Key.R))
|
||||
if (Keyboard.IsPressed(MotionKey.UNKNOW_R)) //if (Keyboard.IsPressed(Corekey.R))
|
||||
{
|
||||
bkey1 &= unchecked((byte)~0x10);
|
||||
}
|
||||
@ -393,7 +395,7 @@ namespace mame
|
||||
{
|
||||
bkey1 |= 0x10;
|
||||
}
|
||||
if (Keyboard.IsPressed(Key.T))
|
||||
if (Keyboard.IsPressed(MotionKey.UNKNOW_T)) //if (Keyboard.IsPressed(Corekey.T))
|
||||
{
|
||||
bkey2 &= unchecked((byte)~0x08);
|
||||
}
|
||||
@ -401,7 +403,7 @@ namespace mame
|
||||
{
|
||||
bkey2 |= 0x08;
|
||||
}
|
||||
if (Keyboard.IsPressed(Key.U))
|
||||
if (Keyboard.IsPressed(MotionKey.P1_BTN_3))//if (Keyboard.IsPressed(Corekey.U))
|
||||
{
|
||||
bkey4 &= unchecked((byte)~0x02);
|
||||
}
|
||||
@ -409,7 +411,7 @@ namespace mame
|
||||
{
|
||||
bkey4 |= 0x02;
|
||||
}
|
||||
if (Keyboard.IsPressed(Key.W))
|
||||
if (Keyboard.IsPressed(MotionKey.P1_UP))//if (Keyboard.IsPressed(Corekey.W))
|
||||
{
|
||||
bkey3 &= unchecked((byte)~0x08);
|
||||
}
|
||||
@ -417,7 +419,7 @@ namespace mame
|
||||
{
|
||||
bkey3 |= 0x08;
|
||||
}
|
||||
if (Keyboard.IsPressed(Key.Y))
|
||||
if (Keyboard.IsPressed(Corekey.Y))
|
||||
{
|
||||
bkey4 &= unchecked((byte)~0x01);
|
||||
}
|
||||
@ -425,7 +427,7 @@ namespace mame
|
||||
{
|
||||
bkey4 |= 0x01;
|
||||
}
|
||||
if (Keyboard.IsPressed(Key.Z))
|
||||
if (Keyboard.IsPressed(Corekey.Z))
|
||||
{
|
||||
bkey2 &= unchecked((byte)~0x10);
|
||||
}
|
||||
@ -433,10 +435,12 @@ namespace mame
|
||||
{
|
||||
bkey2 |= 0x10;
|
||||
}
|
||||
*/
|
||||
}
|
||||
public static void loop_inputports_igs011_lhb2()
|
||||
{
|
||||
if (Keyboard.IsPressed(Key.D5))
|
||||
/*
|
||||
if (Keyboard.IsPressed(MotionKey.P1_INSERT_COIN))//if (Keyboard.IsPressed(Corekey.D5))
|
||||
{
|
||||
sbytec &= ~0x10;
|
||||
}
|
||||
@ -444,7 +448,7 @@ namespace mame
|
||||
{
|
||||
sbytec |= 0x10;
|
||||
}
|
||||
if (Keyboard.IsPressed(Key.D1))
|
||||
if (Keyboard.IsPressed(MotionKey.P1_GAMESTART))//if (Keyboard.IsPressed(Corekey.D1))
|
||||
{
|
||||
bkey0 &= unchecked((byte)~0x20);
|
||||
}
|
||||
@ -452,7 +456,7 @@ namespace mame
|
||||
{
|
||||
bkey0 |= 0x20;
|
||||
}
|
||||
if (Keyboard.IsPressed(Key.D2))
|
||||
if (Keyboard.IsPressed(MotionKey.P2_GAMESTART))//if (Keyboard.IsPressed(Corekey.D2))
|
||||
{
|
||||
bkey1 &= unchecked((byte)~0x20);
|
||||
}
|
||||
@ -460,7 +464,7 @@ namespace mame
|
||||
{
|
||||
bkey1 |= 0x20;
|
||||
}
|
||||
if (Keyboard.IsPressed(Key.A))
|
||||
if (Keyboard.IsPressed(MotionKey.P1_LEFT))//if (Keyboard.IsPressed(Corekey.A))
|
||||
{
|
||||
bkey0 &= unchecked((byte)~0x01);
|
||||
}
|
||||
@ -468,7 +472,7 @@ namespace mame
|
||||
{
|
||||
bkey0 |= 0x01;
|
||||
}
|
||||
if (Keyboard.IsPressed(Key.B))
|
||||
if (Keyboard.IsPressed(Corekey.B))
|
||||
{
|
||||
bkey1 &= unchecked((byte)~0x01);
|
||||
}
|
||||
@ -476,7 +480,7 @@ namespace mame
|
||||
{
|
||||
bkey1 |= 0x01;
|
||||
}
|
||||
if (Keyboard.IsPressed(Key.C))
|
||||
if (Keyboard.IsPressed(Corekey.C))
|
||||
{
|
||||
bkey2 &= unchecked((byte)~0x01);
|
||||
}
|
||||
@ -484,7 +488,7 @@ namespace mame
|
||||
{
|
||||
bkey2 |= 0x01;
|
||||
}
|
||||
if (Keyboard.IsPressed(Key.D))
|
||||
if (Keyboard.IsPressed(MotionKey.P1_RIGHT))//if (Keyboard.IsPressed(Corekey.D))
|
||||
{
|
||||
bkey3 &= unchecked((byte)~0x01);
|
||||
}
|
||||
@ -492,7 +496,7 @@ namespace mame
|
||||
{
|
||||
bkey3 |= 0x01;
|
||||
}
|
||||
if (Keyboard.IsPressed(Key.E))
|
||||
if (Keyboard.IsPressed(Corekey.E))
|
||||
{
|
||||
bkey0 &= unchecked((byte)~0x02);
|
||||
}
|
||||
@ -500,7 +504,7 @@ namespace mame
|
||||
{
|
||||
bkey0 |= 0x02;
|
||||
}
|
||||
if (Keyboard.IsPressed(Key.F))
|
||||
if (Keyboard.IsPressed(Corekey.F))
|
||||
{
|
||||
bkey1 &= unchecked((byte)~0x02);
|
||||
}
|
||||
@ -508,7 +512,7 @@ namespace mame
|
||||
{
|
||||
bkey1 |= 0x02;
|
||||
}
|
||||
if (Keyboard.IsPressed(Key.G))
|
||||
if (Keyboard.IsPressed(Corekey.G))
|
||||
{
|
||||
bkey2 &= unchecked((byte)~0x02);
|
||||
}
|
||||
@ -516,7 +520,7 @@ namespace mame
|
||||
{
|
||||
bkey2 |= 0x02;
|
||||
}
|
||||
if (Keyboard.IsPressed(Key.H))
|
||||
if (Keyboard.IsPressed(Corekey.H))
|
||||
{
|
||||
bkey3 &= unchecked((byte)~0x02);
|
||||
}
|
||||
@ -524,7 +528,7 @@ namespace mame
|
||||
{
|
||||
bkey3 |= 0x02;
|
||||
}
|
||||
if (Keyboard.IsPressed(Key.I))
|
||||
if (Keyboard.IsPressed(MotionKey.P1_BTN_4))//if (Keyboard.IsPressed(Corekey.I))
|
||||
{
|
||||
bkey0 &= unchecked((byte)~0x04);
|
||||
}
|
||||
@ -532,7 +536,7 @@ namespace mame
|
||||
{
|
||||
bkey0 |= 0x04;
|
||||
}
|
||||
if (Keyboard.IsPressed(Key.J))
|
||||
if (Keyboard.IsPressed(MotionKey.P1_BTN_1))//if (Keyboard.IsPressed(Corekey.J))
|
||||
{
|
||||
bkey1 &= unchecked((byte)~0x04);
|
||||
}
|
||||
@ -540,7 +544,7 @@ namespace mame
|
||||
{
|
||||
bkey1 |= 0x04;
|
||||
}
|
||||
if (Keyboard.IsPressed(Key.K))
|
||||
if (Keyboard.IsPressed(MotionKey.P1_BTN_2))//if (Keyboard.IsPressed(Corekey.K))
|
||||
{
|
||||
bkey2 &= unchecked((byte)~0x04);
|
||||
}
|
||||
@ -548,7 +552,7 @@ namespace mame
|
||||
{
|
||||
bkey2 |= 0x04;
|
||||
}
|
||||
if (Keyboard.IsPressed(Key.L))
|
||||
if (Keyboard.IsPressed(MotionKey.P1_UNKNOW_E))//if (Keyboard.IsPressed(Corekey.L))
|
||||
{
|
||||
bkey3 &= unchecked((byte)~0x04);
|
||||
}
|
||||
@ -556,7 +560,7 @@ namespace mame
|
||||
{
|
||||
bkey3 |= 0x04;
|
||||
}
|
||||
if (Keyboard.IsPressed(Key.M))
|
||||
if (Keyboard.IsPressed(MotionKey.UNKNOW_M))//if (Keyboard.IsPressed(Corekey.M))
|
||||
{
|
||||
bkey0 &= unchecked((byte)~0x08);
|
||||
}
|
||||
@ -564,7 +568,7 @@ namespace mame
|
||||
{
|
||||
bkey0 |= 0x08;
|
||||
}
|
||||
if (Keyboard.IsPressed(Key.N))
|
||||
if (Keyboard.IsPressed(MotionKey.UNKNOW_N))//if (Keyboard.IsPressed(Corekey.N))
|
||||
{
|
||||
bkey1 &= unchecked((byte)~0x08);
|
||||
}
|
||||
@ -572,7 +576,7 @@ namespace mame
|
||||
{
|
||||
bkey1 |= 0x08;
|
||||
}
|
||||
if (Keyboard.IsPressed(Key.Q))
|
||||
if (Keyboard.IsPressed(MotionKey.UNKNOW_Q))//if (Keyboard.IsPressed(Corekey.Q))
|
||||
{
|
||||
bkey0 &= unchecked((byte)~0x10);
|
||||
}
|
||||
@ -580,7 +584,7 @@ namespace mame
|
||||
{
|
||||
bkey0 |= 0x10;
|
||||
}
|
||||
if (Keyboard.IsPressed(Key.R))
|
||||
if (Keyboard.IsPressed(MotionKey.UNKNOW_R)) //if (Keyboard.IsPressed(Corekey.R))
|
||||
{
|
||||
bkey1 &= unchecked((byte)~0x10);
|
||||
}
|
||||
@ -588,7 +592,7 @@ namespace mame
|
||||
{
|
||||
bkey1 |= 0x10;
|
||||
}
|
||||
if (Keyboard.IsPressed(Key.T))
|
||||
if (Keyboard.IsPressed(MotionKey.UNKNOW_T)) //if (Keyboard.IsPressed(Corekey.T))
|
||||
{
|
||||
bkey2 &= unchecked((byte)~0x08);
|
||||
}
|
||||
@ -596,7 +600,7 @@ namespace mame
|
||||
{
|
||||
bkey2 |= 0x08;
|
||||
}
|
||||
if (Keyboard.IsPressed(Key.W))
|
||||
if (Keyboard.IsPressed(MotionKey.P1_UP))//if (Keyboard.IsPressed(Corekey.W))
|
||||
{
|
||||
bkey3 &= unchecked((byte)~0x08);
|
||||
}
|
||||
@ -604,7 +608,7 @@ namespace mame
|
||||
{
|
||||
bkey3 |= 0x08;
|
||||
}
|
||||
if (Keyboard.IsPressed(Key.Z))
|
||||
if (Keyboard.IsPressed(Corekey.Z))
|
||||
{
|
||||
bkey2 &= unchecked((byte)~0x10);
|
||||
}
|
||||
@ -612,6 +616,7 @@ namespace mame
|
||||
{
|
||||
bkey2 |= 0x10;
|
||||
}
|
||||
*/
|
||||
}
|
||||
public static void record_port_drgnwrld()
|
||||
{
|
||||
|
@ -1,4 +1,4 @@
|
||||
namespace mame
|
||||
namespace MAME.Core
|
||||
{
|
||||
public partial class IGS011
|
||||
{
|
||||
|
@ -1,4 +1,4 @@
|
||||
namespace mame
|
||||
namespace MAME.Core
|
||||
{
|
||||
public partial class IGS011
|
||||
{
|
||||
|
@ -1,4 +1,4 @@
|
||||
namespace mame
|
||||
namespace MAME.Core
|
||||
{
|
||||
public partial class IGS011
|
||||
{
|
||||
|
@ -1,7 +1,7 @@
|
||||
using cpu.m68000;
|
||||
using System.IO;
|
||||
|
||||
namespace mame
|
||||
namespace MAME.Core
|
||||
{
|
||||
public partial class IGS011
|
||||
{
|
||||
@ -59,12 +59,12 @@ namespace mame
|
||||
writer.Write(blitter.flags);
|
||||
MC68000.m1.SaveStateBinary(writer);
|
||||
Cpuint.SaveStateBinary(writer);
|
||||
writer.Write(Timer.global_basetime.seconds);
|
||||
writer.Write(Timer.global_basetime.attoseconds);
|
||||
writer.Write(EmuTimer.global_basetime.seconds);
|
||||
writer.Write(EmuTimer.global_basetime.attoseconds);
|
||||
Video.SaveStateBinary(writer);
|
||||
writer.Write(Sound.last_update_second);
|
||||
Cpuexec.SaveStateBinary(writer);
|
||||
Timer.SaveStateBinary(writer);
|
||||
EmuTimer.SaveStateBinary(writer);
|
||||
OKI6295.SaveStateBinary(writer);
|
||||
YM3812.SaveStateBinary(writer);
|
||||
writer.Write(Sound.okistream.output_sampindex);
|
||||
@ -128,12 +128,12 @@ namespace mame
|
||||
blitter.flags = reader.ReadUInt16();
|
||||
MC68000.m1.LoadStateBinary(reader);
|
||||
Cpuint.LoadStateBinary(reader);
|
||||
Timer.global_basetime.seconds = reader.ReadInt32();
|
||||
Timer.global_basetime.attoseconds = reader.ReadInt64();
|
||||
EmuTimer.global_basetime.seconds = reader.ReadInt32();
|
||||
EmuTimer.global_basetime.attoseconds = reader.ReadInt64();
|
||||
Video.LoadStateBinary(reader);
|
||||
Sound.last_update_second = reader.ReadInt32();
|
||||
Cpuexec.LoadStateBinary(reader);
|
||||
Timer.LoadStateBinary(reader);
|
||||
EmuTimer.LoadStateBinary(reader);
|
||||
OKI6295.LoadStateBinary(reader);
|
||||
YM3812.LoadStateBinary(reader);
|
||||
Sound.okistream.output_sampindex = reader.ReadInt32();
|
||||
|
@ -1,4 +1,4 @@
|
||||
namespace mame
|
||||
namespace MAME.Core
|
||||
{
|
||||
public partial class IGS011
|
||||
{
|
||||
|
@ -1,4 +1,4 @@
|
||||
namespace mame
|
||||
namespace MAME.Core
|
||||
{
|
||||
public partial class Konami68000
|
||||
{
|
||||
|
@ -1,20 +0,0 @@
|
||||
using System.Collections.Generic;
|
||||
using Bitmap = MAME.Core.AxiBitmap.AxiBitmap;
|
||||
|
||||
namespace mame
|
||||
{
|
||||
public partial class Konami68000
|
||||
{
|
||||
private static string[] sde2 = new string[] { "," }, sde6 = new string[] { "-" };
|
||||
public static bool bTile0, bTile1, bTile2, bSprite;
|
||||
public delegate Bitmap GetBitmap();
|
||||
public static GetBitmap[] GetTilemaps;
|
||||
public static GetBitmap GetSprite;
|
||||
private static List<int> lSprite;
|
||||
public static int min_priority, max_priority;
|
||||
public static void GDIInit()
|
||||
{
|
||||
lSprite = new List<int>();
|
||||
}
|
||||
}
|
||||
}
|
File diff suppressed because it is too large
Load Diff
@ -1,7 +1,7 @@
|
||||
using cpu.m68000;
|
||||
using System;
|
||||
|
||||
namespace mame
|
||||
namespace MAME.Core
|
||||
{
|
||||
public partial class Konami68000
|
||||
{
|
||||
@ -603,8 +603,8 @@ namespace mame
|
||||
public static void sound_arm_nmi_w()
|
||||
{
|
||||
Cpuint.cpunum_set_input_line(1, (int)LineState.INPUT_LINE_NMI, LineState.CLEAR_LINE);
|
||||
Timer.emu_timer timer = Timer.timer_alloc_common(nmi_callback, "nmi_callback", true);
|
||||
Timer.timer_adjust_periodic(timer, new Atime(0, (long)50e12), Attotime.ATTOTIME_NEVER);
|
||||
EmuTimer.emu_timer timer = EmuTimer.timer_alloc_common(nmi_callback, "nmi_callback", true);
|
||||
EmuTimer.timer_adjust_periodic(timer, new Atime(0, (long)50e12), Attotime.ATTOTIME_NEVER);
|
||||
}
|
||||
public static ushort punkshot_kludge_r()
|
||||
{
|
||||
|
@ -1,6 +1,6 @@
|
||||
using System.IO;
|
||||
|
||||
namespace mame
|
||||
namespace MAME.Core
|
||||
{
|
||||
public partial class Konami68000
|
||||
{
|
||||
|
Some files were not shown because too many files have changed in this diff Show More
Loading…
Reference in New Issue
Block a user