2018-11-10 14:47:39 +01:00
|
|
|
// Copyright 2018 The Ebiten Authors
|
|
|
|
//
|
|
|
|
// Licensed under the Apache License, Version 2.0 (the "License");
|
|
|
|
// you may not use this file except in compliance with the License.
|
|
|
|
// You may obtain a copy of the License at
|
|
|
|
//
|
|
|
|
// http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
//
|
|
|
|
// Unless required by applicable law or agreed to in writing, software
|
|
|
|
// distributed under the License is distributed on an "AS IS" BASIS,
|
|
|
|
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
|
|
// See the License for the specific language governing permissions and
|
|
|
|
// limitations under the License.
|
|
|
|
|
2022-02-06 12:41:32 +01:00
|
|
|
package graphicsdriver
|
2018-11-10 14:47:39 +01:00
|
|
|
|
|
|
|
import (
|
2023-11-04 10:09:47 +01:00
|
|
|
"fmt"
|
2023-04-27 17:00:51 +02:00
|
|
|
"image"
|
|
|
|
|
2020-10-03 19:35:13 +02:00
|
|
|
"github.com/hajimehoshi/ebiten/v2/internal/graphics"
|
|
|
|
"github.com/hajimehoshi/ebiten/v2/internal/shaderir"
|
2018-11-10 14:47:39 +01:00
|
|
|
)
|
|
|
|
|
2022-11-04 08:17:40 +01:00
|
|
|
type DstRegion struct {
|
2023-09-28 07:29:55 +02:00
|
|
|
Region image.Rectangle
|
2022-11-04 08:17:40 +01:00
|
|
|
IndexCount int
|
|
|
|
}
|
|
|
|
|
2023-11-04 10:09:47 +01:00
|
|
|
type FillRule int
|
|
|
|
|
|
|
|
const (
|
2024-06-08 04:54:44 +02:00
|
|
|
FillRuleFillAll FillRule = iota
|
|
|
|
FillRuleNonZero
|
|
|
|
FillRuleEvenOdd
|
2023-11-04 10:09:47 +01:00
|
|
|
)
|
|
|
|
|
|
|
|
func (f FillRule) String() string {
|
|
|
|
switch f {
|
2024-06-08 04:54:44 +02:00
|
|
|
case FillRuleFillAll:
|
|
|
|
return "FillRuleFillAll"
|
|
|
|
case FillRuleNonZero:
|
|
|
|
return "FillRuleNonZero"
|
|
|
|
case FillRuleEvenOdd:
|
|
|
|
return "FillRuleEvenOdd"
|
2023-11-04 10:09:47 +01:00
|
|
|
default:
|
|
|
|
return fmt.Sprintf("FillRule(%d)", f)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2021-07-01 06:56:42 +02:00
|
|
|
const (
|
2021-07-01 07:58:55 +02:00
|
|
|
InvalidImageID = 0
|
|
|
|
InvalidShaderID = 0
|
2021-07-01 06:56:42 +02:00
|
|
|
)
|
|
|
|
|
2019-03-30 14:26:27 +01:00
|
|
|
type Graphics interface {
|
2022-03-21 14:05:21 +01:00
|
|
|
Initialize() error
|
2022-03-21 14:23:07 +01:00
|
|
|
Begin() error
|
|
|
|
End(present bool) error
|
2019-11-30 16:07:41 +01:00
|
|
|
SetTransparent(transparent bool)
|
2023-11-03 18:45:16 +01:00
|
|
|
SetVertices(vertices []float32, indices []uint32) error
|
2018-11-10 14:47:39 +01:00
|
|
|
NewImage(width, height int) (Image, error)
|
2018-11-11 15:57:23 +01:00
|
|
|
NewScreenFramebufferImage(width, height int) (Image, error)
|
2018-11-12 16:00:10 +01:00
|
|
|
SetVsyncEnabled(enabled bool)
|
2021-07-06 18:43:32 +02:00
|
|
|
NeedsClearingScreen() bool
|
2019-07-03 18:10:08 +02:00
|
|
|
MaxImageSize() int
|
2020-05-17 20:45:58 +02:00
|
|
|
|
|
|
|
NewShader(program *shaderir.Program) (Shader, error)
|
|
|
|
|
2021-07-01 08:41:25 +02:00
|
|
|
// DrawTriangles draws an image onto another image with the given parameters.
|
2024-06-09 19:02:47 +02:00
|
|
|
DrawTriangles(dst ImageID, srcs [graphics.ShaderSrcImageCount]ImageID, shader ShaderID, dstRegions []DstRegion, indexOffset int, blend Blend, uniforms []uint32, fillRule FillRule) error
|
2018-11-10 14:47:39 +01:00
|
|
|
}
|
|
|
|
|
2023-03-22 10:35:46 +01:00
|
|
|
type Resetter interface {
|
|
|
|
Reset() error
|
|
|
|
}
|
|
|
|
|
2018-11-10 14:47:39 +01:00
|
|
|
type Image interface {
|
2020-05-19 16:48:43 +02:00
|
|
|
ID() ImageID
|
2018-11-12 15:44:13 +01:00
|
|
|
Dispose()
|
2023-08-16 16:18:37 +02:00
|
|
|
ReadPixels(args []PixelsArgs) error
|
2023-08-16 16:18:37 +02:00
|
|
|
WritePixels(args []PixelsArgs) error
|
2019-11-21 15:42:46 +01:00
|
|
|
}
|
|
|
|
|
2020-05-19 16:48:43 +02:00
|
|
|
type ImageID int
|
|
|
|
|
2023-08-16 15:34:53 +02:00
|
|
|
type PixelsArgs struct {
|
2019-11-21 15:42:46 +01:00
|
|
|
Pixels []byte
|
2023-04-27 17:00:51 +02:00
|
|
|
Region image.Rectangle
|
2018-11-10 14:47:39 +01:00
|
|
|
}
|
2018-11-12 16:00:10 +01:00
|
|
|
|
2020-05-17 20:45:58 +02:00
|
|
|
type Shader interface {
|
|
|
|
ID() ShaderID
|
|
|
|
Dispose()
|
|
|
|
}
|
|
|
|
|
|
|
|
type ShaderID int
|