mirror of
https://github.com/hajimehoshi/ebiten.git
synced 2025-01-27 11:12:44 +01:00
internal/graphicsdriver/directx: refactoring
This commit is contained in:
parent
caab1ee29f
commit
a41af4528b
@ -24,7 +24,6 @@ import (
|
|||||||
"github.com/hajimehoshi/ebiten/v2/internal/graphics"
|
"github.com/hajimehoshi/ebiten/v2/internal/graphics"
|
||||||
"github.com/hajimehoshi/ebiten/v2/internal/graphicsdriver"
|
"github.com/hajimehoshi/ebiten/v2/internal/graphicsdriver"
|
||||||
"github.com/hajimehoshi/ebiten/v2/internal/shaderir"
|
"github.com/hajimehoshi/ebiten/v2/internal/shaderir"
|
||||||
"github.com/hajimehoshi/ebiten/v2/internal/shaderir/hlsl"
|
|
||||||
)
|
)
|
||||||
|
|
||||||
var inputElementDescsForDX11 = []_D3D11_INPUT_ELEMENT_DESC{
|
var inputElementDescsForDX11 = []_D3D11_INPUT_ELEMENT_DESC{
|
||||||
@ -482,8 +481,7 @@ func (g *graphics11) MaxImageSize() int {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func (g *graphics11) NewShader(program *shaderir.Program) (graphicsdriver.Shader, error) {
|
func (g *graphics11) NewShader(program *shaderir.Program) (graphicsdriver.Shader, error) {
|
||||||
vs, ps, offsets := hlsl.Compile(program)
|
vsh, psh, offsets, err := compileShader(program)
|
||||||
vsh, psh, err := compileShader(vs, ps)
|
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
|
@ -25,7 +25,6 @@ import (
|
|||||||
"github.com/hajimehoshi/ebiten/v2/internal/graphicsdriver"
|
"github.com/hajimehoshi/ebiten/v2/internal/graphicsdriver"
|
||||||
"github.com/hajimehoshi/ebiten/v2/internal/microsoftgdk"
|
"github.com/hajimehoshi/ebiten/v2/internal/microsoftgdk"
|
||||||
"github.com/hajimehoshi/ebiten/v2/internal/shaderir"
|
"github.com/hajimehoshi/ebiten/v2/internal/shaderir"
|
||||||
"github.com/hajimehoshi/ebiten/v2/internal/shaderir/hlsl"
|
|
||||||
)
|
)
|
||||||
|
|
||||||
type resourceWithSize struct {
|
type resourceWithSize struct {
|
||||||
@ -1064,8 +1063,7 @@ func (g *graphics12) MaxImageSize() int {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func (g *graphics12) NewShader(program *shaderir.Program) (graphicsdriver.Shader, error) {
|
func (g *graphics12) NewShader(program *shaderir.Program) (graphicsdriver.Shader, error) {
|
||||||
vs, ps, offsets := hlsl.Compile(program)
|
vsh, psh, offsets, err := compileShader(program)
|
||||||
vsh, psh, err := compileShader(vs, ps)
|
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
|
@ -21,11 +21,13 @@ import (
|
|||||||
|
|
||||||
"github.com/hajimehoshi/ebiten/v2/internal/graphics"
|
"github.com/hajimehoshi/ebiten/v2/internal/graphics"
|
||||||
"github.com/hajimehoshi/ebiten/v2/internal/shaderir"
|
"github.com/hajimehoshi/ebiten/v2/internal/shaderir"
|
||||||
|
"github.com/hajimehoshi/ebiten/v2/internal/shaderir/hlsl"
|
||||||
)
|
)
|
||||||
|
|
||||||
var vertexShaderCache = map[string]*_ID3DBlob{}
|
var vertexShaderCache = map[string]*_ID3DBlob{}
|
||||||
|
|
||||||
func compileShader(vs, ps string) (vsh, psh *_ID3DBlob, ferr error) {
|
func compileShader(program *shaderir.Program) (vsh, psh *_ID3DBlob, uniformOffsets []int, ferr error) {
|
||||||
|
vs, ps, offsets := hlsl.Compile(program)
|
||||||
var flag uint32 = uint32(_D3DCOMPILE_OPTIMIZATION_LEVEL3)
|
var flag uint32 = uint32(_D3DCOMPILE_OPTIMIZATION_LEVEL3)
|
||||||
|
|
||||||
defer func() {
|
defer func() {
|
||||||
@ -74,10 +76,10 @@ func compileShader(vs, ps string) (vsh, psh *_ID3DBlob, ferr error) {
|
|||||||
})
|
})
|
||||||
|
|
||||||
if err := wg.Wait(); err != nil {
|
if err := wg.Wait(); err != nil {
|
||||||
return nil, nil, err
|
return nil, nil, nil, err
|
||||||
}
|
}
|
||||||
|
|
||||||
return
|
return vsh, psh, offsets, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
func constantBufferSize(uniformTypes []shaderir.Type, uniformOffsets []int) int {
|
func constantBufferSize(uniformTypes []shaderir.Type, uniformOffsets []int) int {
|
||||||
|
Loading…
Reference in New Issue
Block a user