mirror of https://github.com/encounter/SDL.git
metal: only 4 (instead of 5) vertices are needed to draw rectangles and textures, and only 3 (instead of 5) vertices are needed to cover the screen for the 'full-screen quad' when clearing.
This commit is contained in:
parent
d027f3602f
commit
49df65c25a
|
@ -324,7 +324,7 @@ METAL_CreateRenderer(SDL_Window * window, Uint32 flags)
|
||||||
data.mtlpipelinecopylinear = [[NSMutableArray alloc] init];
|
data.mtlpipelinecopylinear = [[NSMutableArray alloc] init];
|
||||||
MakePipelineStates(data, data.mtlpipelinecopylinear, @"SDL texture pipeline (linear)", @"SDL_Copy_vertex", @"SDL_Copy_fragment_linear");
|
MakePipelineStates(data, data.mtlpipelinecopylinear, @"SDL texture pipeline (linear)", @"SDL_Copy_vertex", @"SDL_Copy_fragment_linear");
|
||||||
|
|
||||||
static const float clearverts[] = { -1, -1, -1, 1, 1, 1, 1, -1, -1, -1 };
|
static const float clearverts[] = { -1, -1, -1, 3, 3, -1 };
|
||||||
data.mtlbufclearverts = [data.mtldevice newBufferWithBytes:clearverts length:sizeof(clearverts) options:MTLResourceCPUCacheModeWriteCombined];
|
data.mtlbufclearverts = [data.mtldevice newBufferWithBytes:clearverts length:sizeof(clearverts) options:MTLResourceCPUCacheModeWriteCombined];
|
||||||
data.mtlbufclearverts.label = @"SDL_RenderClear vertices";
|
data.mtlbufclearverts.label = @"SDL_RenderClear vertices";
|
||||||
|
|
||||||
|
@ -562,12 +562,12 @@ METAL_RenderClear(SDL_Renderer * renderer)
|
||||||
viewport.znear = 0.0;
|
viewport.znear = 0.0;
|
||||||
viewport.zfar = 1.0;
|
viewport.zfar = 1.0;
|
||||||
|
|
||||||
// Draw as if we're doing a simple filled rect to the screen now.
|
// Draw a simple filled fullscreen triangle now.
|
||||||
[data.mtlcmdencoder setViewport:viewport];
|
[data.mtlcmdencoder setViewport:viewport];
|
||||||
[data.mtlcmdencoder setRenderPipelineState:ChoosePipelineState(data.mtlpipelineprims, renderer->blendMode)];
|
[data.mtlcmdencoder setRenderPipelineState:ChoosePipelineState(data.mtlpipelineprims, renderer->blendMode)];
|
||||||
[data.mtlcmdencoder setVertexBuffer:data.mtlbufclearverts offset:0 atIndex:0];
|
[data.mtlcmdencoder setVertexBuffer:data.mtlbufclearverts offset:0 atIndex:0];
|
||||||
[data.mtlcmdencoder setFragmentBytes:color length:sizeof(color) atIndex:0];
|
[data.mtlcmdencoder setFragmentBytes:color length:sizeof(color) atIndex:0];
|
||||||
[data.mtlcmdencoder drawPrimitives:MTLPrimitiveTypeTriangleStrip vertexStart:0 vertexCount:5];
|
[data.mtlcmdencoder drawPrimitives:MTLPrimitiveTypeTriangle vertexStart:0 vertexCount:3];
|
||||||
|
|
||||||
// reset the viewport for the rest of our usual drawing work...
|
// reset the viewport for the rest of our usual drawing work...
|
||||||
viewport.originX = renderer->viewport.x;
|
viewport.originX = renderer->viewport.x;
|
||||||
|
@ -675,13 +675,12 @@ METAL_RenderFillRects(SDL_Renderer * renderer, const SDL_FRect * rects, int coun
|
||||||
const float verts[] = {
|
const float verts[] = {
|
||||||
normx(rects->x, w), normy(rects->y + rects->h, h),
|
normx(rects->x, w), normy(rects->y + rects->h, h),
|
||||||
normx(rects->x, w), normy(rects->y, h),
|
normx(rects->x, w), normy(rects->y, h),
|
||||||
normx(rects->x + rects->w, w), normy(rects->y, h),
|
normx(rects->x + rects->w, w), normy(rects->y + rects->h, h),
|
||||||
normx(rects->x, w), normy(rects->y + rects->h, h),
|
normx(rects->x + rects->w, w), normy(rects->y, h)
|
||||||
normx(rects->x + rects->w, w), normy(rects->y + rects->h, h)
|
|
||||||
};
|
};
|
||||||
|
|
||||||
[data.mtlcmdencoder setVertexBytes:verts length:sizeof(verts) atIndex:0];
|
[data.mtlcmdencoder setVertexBytes:verts length:sizeof(verts) atIndex:0];
|
||||||
[data.mtlcmdencoder drawPrimitives:MTLPrimitiveTypeTriangleStrip vertexStart:0 vertexCount:5];
|
[data.mtlcmdencoder drawPrimitives:MTLPrimitiveTypeTriangleStrip vertexStart:0 vertexCount:4];
|
||||||
}
|
}
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
|
@ -702,17 +701,15 @@ METAL_RenderCopy(SDL_Renderer * renderer, SDL_Texture * texture,
|
||||||
const float xy[] = {
|
const float xy[] = {
|
||||||
normx(dstrect->x, w), normy(dstrect->y + dstrect->h, h),
|
normx(dstrect->x, w), normy(dstrect->y + dstrect->h, h),
|
||||||
normx(dstrect->x, w), normy(dstrect->y, h),
|
normx(dstrect->x, w), normy(dstrect->y, h),
|
||||||
normx(dstrect->x + dstrect->w, w), normy(dstrect->y, h),
|
normx(dstrect->x + dstrect->w, w), normy(dstrect->y + dstrect->h, h),
|
||||||
normx(dstrect->x, w), normy(dstrect->y + dstrect->h, h),
|
normx(dstrect->x + dstrect->w, w), normy(dstrect->y, h)
|
||||||
normx(dstrect->x + dstrect->w, w), normy(dstrect->y + dstrect->h, h)
|
|
||||||
};
|
};
|
||||||
|
|
||||||
const float uv[] = {
|
const float uv[] = {
|
||||||
normtex(srcrect->x, texw), normtex(srcrect->y + srcrect->h, texh),
|
normtex(srcrect->x, texw), normtex(srcrect->y + srcrect->h, texh),
|
||||||
normtex(srcrect->x, texw), normtex(srcrect->y, texh),
|
normtex(srcrect->x, texw), normtex(srcrect->y, texh),
|
||||||
normtex(srcrect->x + srcrect->w, texw), normtex(srcrect->y, texh),
|
normtex(srcrect->x + srcrect->w, texw), normtex(srcrect->y + srcrect->h, texh),
|
||||||
normtex(srcrect->x, texw), normtex(srcrect->y + srcrect->h, texh),
|
normtex(srcrect->x + srcrect->w, texw), normtex(srcrect->y, texh)
|
||||||
normtex(srcrect->x + srcrect->w, texw), normtex(srcrect->y + srcrect->h, texh)
|
|
||||||
};
|
};
|
||||||
|
|
||||||
float color[4] = { 1.0f, 1.0f, 1.0f, 1.0f };
|
float color[4] = { 1.0f, 1.0f, 1.0f, 1.0f };
|
||||||
|
@ -728,7 +725,7 @@ METAL_RenderCopy(SDL_Renderer * renderer, SDL_Texture * texture,
|
||||||
[data.mtlcmdencoder setFragmentTexture:texturedata.mtltexture atIndex:0];
|
[data.mtlcmdencoder setFragmentTexture:texturedata.mtltexture atIndex:0];
|
||||||
[data.mtlcmdencoder setVertexBytes:xy length:sizeof(xy) atIndex:0];
|
[data.mtlcmdencoder setVertexBytes:xy length:sizeof(xy) atIndex:0];
|
||||||
[data.mtlcmdencoder setVertexBytes:uv length:sizeof(uv) atIndex:1];
|
[data.mtlcmdencoder setVertexBytes:uv length:sizeof(uv) atIndex:1];
|
||||||
[data.mtlcmdencoder drawPrimitives:MTLPrimitiveTypeTriangleStrip vertexStart:0 vertexCount:5];
|
[data.mtlcmdencoder drawPrimitives:MTLPrimitiveTypeTriangleStrip vertexStart:0 vertexCount:4];
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}}
|
}}
|
||||||
|
|
Loading…
Reference in New Issue