ebiten/graphics.go

167 lines
5.1 KiB
Go
Raw Permalink Normal View History

// Copyright 2014 Hajime Hoshi
//
// 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.
2014-12-09 15:16:04 +01:00
2014-12-09 14:09:22 +01:00
package ebiten
2013-12-02 13:45:10 +01:00
2014-12-22 20:32:36 +01:00
import (
"fmt"
"github.com/hajimehoshi/ebiten/v2/internal/builtinshader"
"github.com/hajimehoshi/ebiten/v2/internal/ui"
2014-12-22 20:32:36 +01:00
)
// Filter represents the type of texture filter to be used when an image is magnified or minified.
2014-12-31 06:57:51 +01:00
type Filter int
const (
2016-08-01 18:47:25 +02:00
// FilterNearest represents nearest (crisp-edged) filter
FilterNearest Filter = Filter(builtinshader.FilterNearest)
2016-08-01 18:47:25 +02:00
// FilterLinear represents linear filter
FilterLinear Filter = Filter(builtinshader.FilterLinear)
)
2014-12-31 06:57:51 +01:00
// CompositeMode represents Porter-Duff composition mode.
//
// Deprecated: as of v2.5. Use Blend instead.
type CompositeMode int
const (
// CompositeModeCustom indicates to refer Blend.
CompositeModeCustom CompositeMode = iota
// Deprecated: as of v2.5. Use BlendSourceOver instead.
CompositeModeSourceOver
// Deprecated: as of v2.5. Use BlendClear instead.
CompositeModeClear
// Deprecated: as of v2.5. Use BlendCopy instead.
CompositeModeCopy
// Deprecated: as of v2.5. Use BlendDestination instead.
CompositeModeDestination
// Deprecated: as of v2.5. Use BlendDestinationOver instead.
CompositeModeDestinationOver
// Deprecated: as of v2.5. Use BlendSourceIn instead.
CompositeModeSourceIn
// Deprecated: as of v2.5. Use BlendDestinationIn instead.
CompositeModeDestinationIn
// Deprecated: as of v2.5. Use BlendSourceOut instead.
CompositeModeSourceOut
// Deprecated: as of v2.5. Use BlendDestinationOut instead.
CompositeModeDestinationOut
// Deprecated: as of v2.5. Use BlendSourceAtop instead.
CompositeModeSourceAtop
// Deprecated: as of v2.5. Use BlendDestinationAtop instead.
CompositeModeDestinationAtop
// Deprecated: as of v2.5. Use BlendXor instead.
CompositeModeXor
// Deprecated: as of v2.5. Use BlendLighter instead.
CompositeModeLighter
// Deprecated: as of v2.5. Use Blend with BlendFactorDestinationColor and BlendFactorZero instead.
CompositeModeMultiply
)
func (c CompositeMode) blend() Blend {
switch c {
case CompositeModeSourceOver:
return BlendSourceOver
case CompositeModeClear:
return BlendClear
case CompositeModeCopy:
return BlendCopy
case CompositeModeDestination:
return BlendDestination
case CompositeModeDestinationOver:
return BlendDestinationOver
case CompositeModeSourceIn:
return BlendSourceIn
case CompositeModeDestinationIn:
return BlendDestinationIn
case CompositeModeSourceOut:
return BlendSourceOut
case CompositeModeDestinationOut:
return BlendDestinationOut
case CompositeModeSourceAtop:
return BlendSourceAtop
case CompositeModeDestinationAtop:
return BlendDestinationAtop
case CompositeModeXor:
return BlendXor
case CompositeModeLighter:
return BlendLighter
case CompositeModeMultiply:
return Blend{
BlendFactorSourceRGB: BlendFactorDestinationColor,
BlendFactorSourceAlpha: BlendFactorDestinationColor,
BlendFactorDestinationRGB: BlendFactorZero,
BlendFactorDestinationAlpha: BlendFactorZero,
BlendOperationRGB: BlendOperationAdd,
BlendOperationAlpha: BlendOperationAdd,
}
default:
panic(fmt.Sprintf("ebiten: invalid composite mode: %d", c))
}
}
// GraphicsLibrary represents graphics libraries supported by the engine.
type GraphicsLibrary int
const (
GraphicsLibraryAuto GraphicsLibrary = GraphicsLibrary(ui.GraphicsLibraryAuto)
// GraphicsLibraryUnknown represents the state at which graphics library cannot be determined,
// e.g. hasn't loaded yet or failed to initialize.
GraphicsLibraryUnknown GraphicsLibrary = GraphicsLibrary(ui.GraphicsLibraryUnknown)
2022-08-07 21:37:03 +02:00
// GraphicsLibraryOpenGL represents the graphics library OpenGL.
GraphicsLibraryOpenGL GraphicsLibrary = GraphicsLibrary(ui.GraphicsLibraryOpenGL)
2022-08-07 21:37:03 +02:00
// GraphicsLibraryDirectX represents the graphics library Microsoft DirectX.
GraphicsLibraryDirectX GraphicsLibrary = GraphicsLibrary(ui.GraphicsLibraryDirectX)
2022-08-07 21:37:03 +02:00
// GraphicsLibraryMetal represents the graphics library Apple's Metal.
GraphicsLibraryMetal GraphicsLibrary = GraphicsLibrary(ui.GraphicsLibraryMetal)
)
// String returns a string representing the graphics library.
func (g GraphicsLibrary) String() string {
return ui.GraphicsLibrary(g).String()
}
// Ensures GraphicsLibraryAuto is zero (the default value for RunOptions).
var _ [GraphicsLibraryAuto]int = [0]int{}
// DebugInfo is a struct to store debug info about the graphics.
type DebugInfo struct {
// GraphicsLibrary represents the graphics library currently in use.
GraphicsLibrary GraphicsLibrary
}
// ReadDebugInfo writes debug info (e.g. current graphics library) into a provided struct.
func ReadDebugInfo(d *DebugInfo) {
d.GraphicsLibrary = GraphicsLibrary(ui.GetGraphicsLibrary())
}