mirror of
https://github.com/Ale32bit/Capy64.git
synced 2025-01-18 18:46:43 +00:00
Allow gpubuffers to be drawn out of bounds
This commit is contained in:
parent
8b5fa96a74
commit
cf12454a83
2 changed files with 32 additions and 30 deletions
|
@ -16,6 +16,7 @@ public class Drawing : IDisposable
|
|||
private Texture2D _whitePixel;
|
||||
private RenderTarget2D _canvas;
|
||||
private bool _isDrawing;
|
||||
private HashSet<Texture2D> _disposeTextures = new();
|
||||
public RenderTarget2D Canvas
|
||||
{
|
||||
get => _canvas;
|
||||
|
@ -59,6 +60,11 @@ public class Drawing : IDisposable
|
|||
|
||||
_spriteBatch.End();
|
||||
_graphicsDevice.SetRenderTarget(null);
|
||||
|
||||
foreach (var t in _disposeTextures)
|
||||
t.Dispose();
|
||||
_disposeTextures.Clear();
|
||||
|
||||
_isDrawing = false;
|
||||
}
|
||||
|
||||
|
@ -178,6 +184,20 @@ public class Drawing : IDisposable
|
|||
_spriteBatch.Draw(_whitePixel, position3, null, color, rotation, Vector2.Zero, scale, SpriteEffects.None, layerDepth);
|
||||
}
|
||||
|
||||
public void DrawTexture(Texture2D texture, Vector2 pos)
|
||||
{
|
||||
_spriteBatch.Draw(texture, pos, null, Color.White, 0f, Vector2.Zero, 1, SpriteEffects.None, 0f);
|
||||
}
|
||||
|
||||
public void DrawBuffer(uint[] buffer, Rectangle rect)
|
||||
{
|
||||
var texture = new Texture2D(_graphicsDevice, rect.Width, rect.Height, false, SurfaceFormat.Color);
|
||||
texture.SetData(buffer);
|
||||
|
||||
DrawTexture(texture, new(rect.X, rect.Y));
|
||||
_disposeTextures.Add(texture);
|
||||
}
|
||||
|
||||
public void Dispose()
|
||||
{
|
||||
GC.SuppressFinalize(this);
|
||||
|
|
|
@ -435,8 +435,8 @@ public class GPU : IPlugin
|
|||
{
|
||||
var L = Lua.FromIntPtr(state);
|
||||
|
||||
var from = L.CheckObject<uint[]>(1, GPUBuffer.ObjectType, false);
|
||||
if (from is null)
|
||||
var buffer = L.CheckObject<uint[]>(1, GPUBuffer.ObjectType, false);
|
||||
if (buffer is null)
|
||||
{
|
||||
L.ArgumentError(1, GPUBuffer.ObjectType + " expected, got " + L.TypeName(L.Type(1)));
|
||||
}
|
||||
|
@ -445,32 +445,14 @@ public class GPU : IPlugin
|
|||
var y = (int)L.CheckInteger(3) - 1;
|
||||
var w = (int)L.CheckInteger(4);
|
||||
var h = (int)L.CheckInteger(5);
|
||||
try
|
||||
{
|
||||
_game.Drawing.Canvas.SetData(0, new Rectangle
|
||||
{
|
||||
X = x,
|
||||
Y = y,
|
||||
Width = w,
|
||||
Height = h,
|
||||
}, from, 0, from.Length);
|
||||
}
|
||||
catch (Exception e)
|
||||
{
|
||||
if (w * h != from.Length)
|
||||
{
|
||||
L.Error("buffer size does not match width and height");
|
||||
return 0;
|
||||
}
|
||||
|
||||
if(x < 0 || y < 0 || x + w >= _game.Drawing.Canvas.Width || y + h >= _game.Drawing.Canvas.Height)
|
||||
{
|
||||
L.Error("position out of bounds");
|
||||
return 0;
|
||||
}
|
||||
|
||||
L.Error(e.ToString());
|
||||
}
|
||||
_game.Drawing.DrawBuffer(buffer, new()
|
||||
{
|
||||
X = x,
|
||||
Y = y,
|
||||
Width = w,
|
||||
Height = h,
|
||||
});
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
|
Loading…
Reference in a new issue