2019-05-12 17:22:32 +00:00
|
|
|
package apple2
|
|
|
|
|
|
|
|
import (
|
|
|
|
"image"
|
2019-05-12 22:17:31 +00:00
|
|
|
"image/color"
|
2019-05-12 17:22:32 +00:00
|
|
|
)
|
|
|
|
|
|
|
|
const (
|
2019-11-08 23:44:13 +00:00
|
|
|
loResPixelWidth = charWidth * 2
|
|
|
|
doubleLoResPixelWidth = charWidth
|
|
|
|
loResPixelHeight = charHeight / 2
|
2019-05-12 17:22:32 +00:00
|
|
|
)
|
|
|
|
|
2019-05-12 22:17:31 +00:00
|
|
|
func getColorPatterns(light color.Color) [16][16]color.Color {
|
|
|
|
/*
|
|
|
|
For each lores pixel we have to fill 14 half mono pixels with
|
|
|
|
the 4 bits of the color repeated. We will need to shift by 2 bits
|
|
|
|
on the odd columns. Lets prepare 14+2 values for each color.
|
|
|
|
*/
|
|
|
|
|
|
|
|
var data [16][16]color.Color
|
|
|
|
|
|
|
|
for ci := 0; ci < 16; ci++ {
|
|
|
|
for cb := uint8(0); cb < 4; cb++ {
|
|
|
|
bit := (ci >> cb) & 1
|
|
|
|
var colour color.Color
|
|
|
|
if bit == 0 {
|
|
|
|
colour = color.Black
|
|
|
|
} else {
|
|
|
|
colour = light
|
|
|
|
}
|
|
|
|
for i := uint8(0); i < 4; i++ {
|
|
|
|
data[ci][cb+4*i] = colour
|
|
|
|
}
|
2019-05-12 17:22:32 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
return data
|
2019-05-12 22:17:31 +00:00
|
|
|
|
2019-05-12 17:22:32 +00:00
|
|
|
}
|
|
|
|
|
2019-11-08 23:44:13 +00:00
|
|
|
func snapshotLoResModeMono(a *Apple2, isDoubleResMode bool, isSecondPage bool, isMixMode bool, light color.Color) *image.RGBA {
|
|
|
|
text, columns, lines := getActiveText(a, isDoubleResMode, isSecondPage, false)
|
2019-11-08 22:56:54 +00:00
|
|
|
if isMixMode {
|
|
|
|
lines -= textLinesMix
|
2019-05-12 17:22:32 +00:00
|
|
|
}
|
2019-11-08 22:56:54 +00:00
|
|
|
grLines := lines * 2
|
2019-11-08 23:44:13 +00:00
|
|
|
pixelWidth := loResPixelWidth
|
|
|
|
if isDoubleResMode {
|
|
|
|
pixelWidth = doubleLoResPixelWidth
|
|
|
|
}
|
2019-05-12 17:22:32 +00:00
|
|
|
|
2019-11-08 23:44:13 +00:00
|
|
|
size := image.Rect(0, 0, columns*pixelWidth, grLines*loResPixelHeight)
|
2019-05-12 17:22:32 +00:00
|
|
|
img := image.NewRGBA(size)
|
|
|
|
|
2019-05-12 22:17:31 +00:00
|
|
|
patterns := getColorPatterns(light)
|
2019-11-08 22:56:54 +00:00
|
|
|
for l := 0; l < grLines; l++ {
|
|
|
|
for c := 0; c < columns; c++ {
|
|
|
|
char := text[(l/2)*columns+c]
|
|
|
|
grPixel := char >> 4
|
|
|
|
if l%2 == 0 {
|
|
|
|
grPixel = char & 0xf
|
|
|
|
}
|
2019-11-08 23:44:13 +00:00
|
|
|
// We place pixelWidth mono pixels per graphic pixel.
|
|
|
|
// The groups of 4 mono pixels need to be alligned with an offset to get plain surfaces
|
|
|
|
offset := (c * pixelWidth) % 4
|
2019-05-12 22:17:31 +00:00
|
|
|
|
2019-11-08 23:44:13 +00:00
|
|
|
// Insert the pixelWidth pixels required
|
|
|
|
for i := 0; i < pixelWidth; i++ {
|
2019-11-08 22:56:54 +00:00
|
|
|
v := patterns[grPixel][i+offset]
|
2019-05-12 22:17:31 +00:00
|
|
|
// Repeat the same color for 4 lines
|
|
|
|
for r := 0; r < loResPixelHeight; r++ {
|
2019-11-08 22:56:54 +00:00
|
|
|
img.Set(c*loResPixelWidth+i, l*4+r, v)
|
2019-05-12 17:22:32 +00:00
|
|
|
}
|
|
|
|
}
|
2019-11-08 22:56:54 +00:00
|
|
|
|
2019-05-12 17:22:32 +00:00
|
|
|
}
|
|
|
|
}
|
2019-11-08 22:56:54 +00:00
|
|
|
|
2019-05-12 17:22:32 +00:00
|
|
|
return img
|
|
|
|
}
|