mirror of
https://github.com/OpenDiablo2/OpenDiablo2
synced 2025-01-13 21:07:31 -05:00
More rendering fixes
This commit is contained in:
parent
78fed23e21
commit
21eb39bf7a
@ -20,6 +20,7 @@ namespace OpenDiablo2.SDL2_
|
|||||||
public Point Location { get; set; } = new Point();
|
public Point Location { get; set; } = new Point();
|
||||||
public Size FrameSize { get; set; } = new Size();
|
public Size FrameSize { get; set; } = new Size();
|
||||||
|
|
||||||
|
private Point mapTileOffset = new Point();
|
||||||
|
|
||||||
private bool darken;
|
private bool darken;
|
||||||
public bool Darken
|
public bool Darken
|
||||||
@ -82,6 +83,7 @@ namespace OpenDiablo2.SDL2_
|
|||||||
FrameSize = new Size(Pow2((int)source.Frames.Max(x => x.Width)), Pow2((int)source.Frames.Max(x => x.Height)));
|
FrameSize = new Size(Pow2((int)source.Frames.Max(x => x.Width)), Pow2((int)source.Frames.Max(x => x.Height)));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private int[] idxtable = new int[] { 20, 21, 22, 23, 24, 15, 16, 17, 18, 19, 10, 11, 12, 13, 14, 5, 6, 7, 8, 9, 0, 1, 2, 3, 4 };
|
||||||
public unsafe SDL2Sprite(IntPtr renderer, Palette palette, MPQDS1 mapData, int x, int y, eRenderCellType cellType)
|
public unsafe SDL2Sprite(IntPtr renderer, Palette palette, MPQDS1 mapData, int x, int y, eRenderCellType cellType)
|
||||||
{
|
{
|
||||||
this.renderer = renderer;
|
this.renderer = renderer;
|
||||||
@ -115,12 +117,25 @@ namespace OpenDiablo2.SDL2_
|
|||||||
if (tile == null)
|
if (tile == null)
|
||||||
throw new ApplicationException("Could not locate tile!");
|
throw new ApplicationException("Could not locate tile!");
|
||||||
|
|
||||||
FrameSize = new Size(tile.Width, Math.Abs(tile.Height));
|
|
||||||
|
//FrameSize = new Size(tile.Width, Math.Abs(tile.Height));
|
||||||
TotalFrames = 1;
|
TotalFrames = 1;
|
||||||
frame = 0;
|
frame = 0;
|
||||||
IntPtr pixels;
|
IntPtr pixels;
|
||||||
int pitch;
|
int pitch;
|
||||||
|
|
||||||
|
|
||||||
|
var maxX = tile.Blocks.Max(z => z.PositionX + 32);
|
||||||
|
var maxY = tile.Blocks.Max(z => z.PositionY + 32);
|
||||||
|
var minX = tile.Blocks.Min(z => z.PositionX);
|
||||||
|
var minY = tile.Blocks.Min(z => z.PositionY);
|
||||||
|
|
||||||
|
FrameSize = new Size(Pow2(maxX - minX), Pow2(maxY - minY));
|
||||||
|
var yDiff = Math.Abs(minY);
|
||||||
|
var xDiff = Math.Abs(maxY);
|
||||||
|
|
||||||
|
mapTileOffset = new Point(minX, minY);
|
||||||
|
|
||||||
texture = SDL.SDL_CreateTexture(renderer, SDL.SDL_PIXELFORMAT_ARGB8888, (int)SDL.SDL_TextureAccess.SDL_TEXTUREACCESS_STREAMING, FrameSize.Width, FrameSize.Height);
|
texture = SDL.SDL_CreateTexture(renderer, SDL.SDL_PIXELFORMAT_ARGB8888, (int)SDL.SDL_TextureAccess.SDL_TEXTUREACCESS_STREAMING, FrameSize.Width, FrameSize.Height);
|
||||||
|
|
||||||
if (texture == IntPtr.Zero)
|
if (texture == IntPtr.Zero)
|
||||||
@ -133,13 +148,13 @@ namespace OpenDiablo2.SDL2_
|
|||||||
for (var i = 0; i < FrameSize.Width * FrameSize.Height; i++)
|
for (var i = 0; i < FrameSize.Width * FrameSize.Height; i++)
|
||||||
data[i] = 0x0;
|
data[i] = 0x0;
|
||||||
|
|
||||||
foreach (var block in tile.Blocks.Take(1))
|
foreach(var block in tile.Blocks)
|
||||||
{
|
{
|
||||||
//var px = block.PositionX;
|
var px = block.PositionX + xDiff;
|
||||||
//var py = block.PositionY;
|
var py = block.PositionY + yDiff;
|
||||||
|
|
||||||
var px = 0;
|
//var px = 0;
|
||||||
var py = 0;
|
//var py = 0;
|
||||||
for (int yy = 0; yy < 32; yy++)
|
for (int yy = 0; yy < 32; yy++)
|
||||||
{
|
{
|
||||||
for (int xx = 0; xx < 32; xx++)
|
for (int xx = 0; xx < 32; xx++)
|
||||||
@ -149,7 +164,9 @@ namespace OpenDiablo2.SDL2_
|
|||||||
continue;
|
continue;
|
||||||
if (index < 0)
|
if (index < 0)
|
||||||
continue;
|
continue;
|
||||||
data[index] = palette.Colors[block.PixelData[xx + (yy * 32)]];
|
var color = palette.Colors[block.PixelData[xx + (yy * 32)]];
|
||||||
|
if ((color >> 24) > 0)
|
||||||
|
data[index] = color;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -163,7 +180,7 @@ namespace OpenDiablo2.SDL2_
|
|||||||
internal Point GetRenderPoint()
|
internal Point GetRenderPoint()
|
||||||
{
|
{
|
||||||
return source == null
|
return source == null
|
||||||
? Location
|
? new Point(Location.X + mapTileOffset.X, (Location.Y - FrameSize.Height) + mapTileOffset.Y)
|
||||||
: new Point(Location.X + source.Frames[Frame].OffsetX, (Location.Y - FrameSize.Height) + source.Frames[Frame].OffsetY);
|
: new Point(Location.X + source.Frames[Frame].OffsetX, (Location.Y - FrameSize.Height) + source.Frames[Frame].OffsetY);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -87,7 +87,7 @@ namespace OpenDiablo2.Scenes
|
|||||||
for (int x = 0; x < gameState.MapData.Width; x++)
|
for (int x = 0; x < gameState.MapData.Width; x++)
|
||||||
{
|
{
|
||||||
testSprite[idx] = renderWindow.GenerateMapCell(gameState.MapData, x, y, eRenderCellType.Floor, gameState.CurrentPalette);
|
testSprite[idx] = renderWindow.GenerateMapCell(gameState.MapData, x, y, eRenderCellType.Floor, gameState.CurrentPalette);
|
||||||
testSprite[idx].Location = new Point(((x - y) * 80) - 0, ((x + y) * 40) - 0);
|
testSprite[idx].Location = new Point(((x - y) * 80) - 1200, ((x + y) * 40) - 1200);
|
||||||
idx++;
|
idx++;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user