openMSX
Public Member Functions | List of all members
openmsx::GLSaIScaler Class Referencefinal

#include <GLSaIScaler.hh>

Inheritance diagram for openmsx::GLSaIScaler:
Inheritance graph
[legend]
Collaboration diagram for openmsx::GLSaIScaler:
Collaboration graph
[legend]

Public Member Functions

 GLSaIScaler ()
 
void scaleImage (gl::ColorTexture &src, gl::ColorTexture *superImpose, unsigned srcStartY, unsigned srcEndY, unsigned srcWidth, unsigned dstStartY, unsigned dstEndY, unsigned dstWidth, unsigned logSrcHeight) override
 Scales the image in the given area, which must consist of lines which are all equally wide. More...
 
- Public Member Functions inherited from openmsx::GLScaler
virtual ~GLScaler ()=default
 
virtual void scaleImage (gl::ColorTexture &src, gl::ColorTexture *superImpose, unsigned srcStartY, unsigned srcEndY, unsigned srcWidth, unsigned dstStartY, unsigned dstEndY, unsigned dstWidth, unsigned logSrcHeight)=0
 Scales the image in the given area, which must consist of lines which are all equally wide. More...
 
virtual void uploadBlock (unsigned srcStartY, unsigned srcEndY, unsigned lineWidth, FrameSource &paintFrame)
 

Additional Inherited Members

- Protected Member Functions inherited from openmsx::GLScaler
 GLScaler (const std::string &progName)
 
void setup (bool superImpose)
 
void execute (gl::ColorTexture &src, gl::ColorTexture *superImpose, unsigned srcStartY, unsigned srcEndY, unsigned srcWidth, unsigned dstStartY, unsigned dstEndY, unsigned dstWidth, unsigned logSrcHeight, bool textureFromZero=false)
 Helper method to draw a rectangle with multiple texture coordinates. More...
 
- Protected Attributes inherited from openmsx::GLScaler
std::array< gl::BufferObject, 2 > vbo
 
std::array< gl::ShaderProgram, 2 > program
 
std::array< GLint, 2 > unifTexSize
 

Detailed Description

Definition at line 8 of file GLSaIScaler.hh.

Constructor & Destructor Documentation

◆ GLSaIScaler()

openmsx::GLSaIScaler::GLSaIScaler ( )

Definition at line 5 of file GLSaIScaler.cc.

Member Function Documentation

◆ scaleImage()

void openmsx::GLSaIScaler::scaleImage ( gl::ColorTexture src,
gl::ColorTexture superImpose,
unsigned  srcStartY,
unsigned  srcEndY,
unsigned  srcWidth,
unsigned  dstStartY,
unsigned  dstEndY,
unsigned  dstWidth,
unsigned  logSrcHeight 
)
overridevirtual

Scales the image in the given area, which must consist of lines which are all equally wide.

Scaling factor depends on the concrete scaler.

Parameters
srcSource: texture containing the frame to be scaled.
superImposeTexture containing the to-be-superimposed image (can be nullptr).
srcStartYY-coordinate of the top source line (inclusive).
srcEndYY-coordinate of the bottom source line (exclusive).
srcWidthThe number of pixels per line for the given area.
dstStartYY-coordinate of the top destination line (inclusive).
dstEndYY-coordinate of the bottom destination line (exclusive).
dstWidthThe number of pixels per line on the output screen.
logSrcHeightThe logical height of the complete src texture (actual texture height can be double as high in case of non-interlace). This is needed to translate src-Y-coordinates to superImpose-Y-coordinates.

Implements openmsx::GLScaler.

Definition at line 10 of file GLSaIScaler.cc.

References openmsx::GLScaler::execute(), and openmsx::GLScaler::setup().


The documentation for this class was generated from the following files: