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.
|
|
|
|
|
2019-03-30 14:26:27 +01:00
|
|
|
package driver
|
2018-11-10 14:47:39 +01:00
|
|
|
|
|
|
|
import (
|
2020-04-12 13:01:15 +02:00
|
|
|
"errors"
|
|
|
|
|
2018-11-10 14:47:39 +01:00
|
|
|
"github.com/hajimehoshi/ebiten/internal/affine"
|
2020-05-17 20:45:58 +02:00
|
|
|
"github.com/hajimehoshi/ebiten/internal/shaderir"
|
2019-06-05 17:05:53 +02:00
|
|
|
"github.com/hajimehoshi/ebiten/internal/thread"
|
2018-11-10 14:47:39 +01:00
|
|
|
)
|
|
|
|
|
2020-06-29 17:02:33 +02:00
|
|
|
type Region struct {
|
|
|
|
X float32
|
|
|
|
Y float32
|
|
|
|
Width float32
|
|
|
|
Height float32
|
|
|
|
}
|
|
|
|
|
2019-03-30 14:26:27 +01:00
|
|
|
type Graphics interface {
|
2019-06-05 17:05:53 +02:00
|
|
|
SetThread(thread *thread.Thread)
|
2019-04-20 08:17:59 +02:00
|
|
|
Begin()
|
|
|
|
End()
|
2019-11-30 16:07:41 +01:00
|
|
|
SetTransparent(transparent bool)
|
2018-11-11 15:54:58 +01:00
|
|
|
SetVertices(vertices []float32, indices []uint16)
|
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-10 14:47:39 +01:00
|
|
|
Reset() error
|
2018-11-12 16:00:10 +01:00
|
|
|
SetVsyncEnabled(enabled bool)
|
2020-05-08 09:49:19 +02:00
|
|
|
FramebufferYDirection() YDirection
|
2019-05-26 12:08:46 +02:00
|
|
|
NeedsRestoring() bool
|
2018-11-12 16:00:10 +01:00
|
|
|
IsGL() bool
|
2019-06-21 21:47:48 +02:00
|
|
|
HasHighPrecisionFloat() 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)
|
|
|
|
|
2020-06-29 17:02:33 +02:00
|
|
|
// Draw draws an image onto another image.
|
|
|
|
//
|
|
|
|
// TODO: Merge this into DrawShader.
|
|
|
|
Draw(dst, src ImageID, indexLen int, indexOffset int, mode CompositeMode, colorM *affine.ColorM, filter Filter, address Address, sourceRegion Region) error
|
|
|
|
|
2020-05-17 20:45:58 +02:00
|
|
|
// DrawShader draws the shader.
|
|
|
|
//
|
|
|
|
// uniforms represents a colletion of uniform variables. The values must be one of these types:
|
2020-07-05 18:55:46 +02:00
|
|
|
//
|
|
|
|
// * float32
|
|
|
|
// * []float32
|
|
|
|
DrawShader(dst ImageID, shader ShaderID, indexLen int, indexOffset int, mode CompositeMode, uniforms []interface{}, textures []ImageID) error
|
2018-11-10 14:47:39 +01:00
|
|
|
}
|
|
|
|
|
2020-04-12 13:01:15 +02:00
|
|
|
// GraphicsNotReady represents that the graphics driver is not ready for recovering from the context lost.
|
|
|
|
var GraphicsNotReady = errors.New("graphics not ready")
|
|
|
|
|
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()
|
2018-11-10 14:47:39 +01:00
|
|
|
IsInvalidated() bool
|
|
|
|
Pixels() ([]byte, error)
|
2019-11-21 15:42:46 +01:00
|
|
|
ReplacePixels(args []*ReplacePixelsArgs)
|
|
|
|
}
|
|
|
|
|
2020-05-19 16:48:43 +02:00
|
|
|
type ImageID int
|
|
|
|
|
2019-11-21 15:42:46 +01:00
|
|
|
type ReplacePixelsArgs struct {
|
|
|
|
Pixels []byte
|
|
|
|
X int
|
|
|
|
Y int
|
|
|
|
Width int
|
|
|
|
Height int
|
2018-11-10 14:47:39 +01:00
|
|
|
}
|
2018-11-12 16:00:10 +01:00
|
|
|
|
2020-05-08 09:49:19 +02:00
|
|
|
type YDirection int
|
2018-11-12 16:00:10 +01:00
|
|
|
|
|
|
|
const (
|
2020-05-08 09:49:19 +02:00
|
|
|
Upward YDirection = iota
|
|
|
|
Downward
|
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
|