mirror of
https://github.com/irmen/prog8.git
synced 2025-01-13 10:29:52 +00:00
fixed petscii conversion when printing text
This commit is contained in:
parent
0c7f107d01
commit
34dcce67e4
@ -1086,5 +1086,38 @@ class Petscii {
|
|||||||
val decodeTable = if(lowercase) decodingScreencodeLowercase else decodingScreencodeUppercase
|
val decodeTable = if(lowercase) decodingScreencodeLowercase else decodingScreencodeUppercase
|
||||||
return screencode.map { decodeTable[it.toInt()] }.joinToString("")
|
return screencode.map { decodeTable[it.toInt()] }.joinToString("")
|
||||||
}
|
}
|
||||||
|
|
||||||
|
fun petscii2scr(petscii_code: Short, inverseVideo: Boolean): Short {
|
||||||
|
val code = when {
|
||||||
|
petscii_code <= 0x1f -> petscii_code + 128
|
||||||
|
petscii_code <= 0x3f -> petscii_code.toInt()
|
||||||
|
petscii_code <= 0x5f -> petscii_code - 64
|
||||||
|
petscii_code <= 0x7f -> petscii_code - 32
|
||||||
|
petscii_code <= 0x9f -> petscii_code + 64
|
||||||
|
petscii_code <= 0xbf -> petscii_code - 64
|
||||||
|
petscii_code <= 0xfe -> petscii_code - 128
|
||||||
|
petscii_code == 255.toShort() -> 95
|
||||||
|
else -> throw CharConversionException("petscii code out of range")
|
||||||
|
}
|
||||||
|
if(inverseVideo)
|
||||||
|
return (code or 0x80).toShort()
|
||||||
|
return code.toShort()
|
||||||
|
}
|
||||||
|
|
||||||
|
fun scr2petscii(screencode: Short): Short {
|
||||||
|
val petscii = when {
|
||||||
|
screencode <= 0x1f -> screencode + 64
|
||||||
|
screencode <= 0x3f -> screencode.toInt()
|
||||||
|
screencode <= 0x5d -> screencode +123
|
||||||
|
screencode == 0x5e.toShort() -> 255
|
||||||
|
screencode == 0x5f.toShort() -> 223
|
||||||
|
screencode <= 0x7f -> screencode + 64
|
||||||
|
screencode <= 0xbf -> screencode - 128
|
||||||
|
screencode <= 0xfe -> screencode - 64
|
||||||
|
screencode == 255.toShort() -> 191
|
||||||
|
else -> throw CharConversionException("screencode out of range")
|
||||||
|
}
|
||||||
|
return petscii.toShort()
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -621,7 +621,7 @@ class AstVm(val program: Program) {
|
|||||||
dialog.canvas.setCursorPos(args[0].integerValue(), args[1].integerValue())
|
dialog.canvas.setCursorPos(args[0].integerValue(), args[1].integerValue())
|
||||||
}
|
}
|
||||||
"c64.CHROUT" -> {
|
"c64.CHROUT" -> {
|
||||||
dialog.canvas.printChar(args[0].byteval!!)
|
dialog.canvas.printPetscii(args[0].byteval!!)
|
||||||
}
|
}
|
||||||
"c64flt.print_f" -> {
|
"c64flt.print_f" -> {
|
||||||
dialog.canvas.printText(args[0].floatval.toString(), 1, true)
|
dialog.canvas.printText(args[0].floatval.toString(), 1, true)
|
||||||
|
@ -61,23 +61,23 @@ class BitmapScreenPanel : KeyListener, JPanel() {
|
|||||||
g2d.color = Colors.palette[color % Colors.palette.size]
|
g2d.color = Colors.palette[color % Colors.palette.size]
|
||||||
g2d.drawLine(x1, y1, x2, y2)
|
g2d.drawLine(x1, y1, x2, y2)
|
||||||
}
|
}
|
||||||
fun printText(text: String, color: Short, lowercase: Boolean) {
|
fun printText(text: String, color: Short, lowercase: Boolean, inverseVideo: Boolean=false) {
|
||||||
val t2 = text.substringBefore(0.toChar())
|
val t2 = text.substringBefore(0.toChar())
|
||||||
val lines = t2.split('\n')
|
val lines = t2.split('\n')
|
||||||
for(line in lines.withIndex()) {
|
for(line in lines.withIndex()) {
|
||||||
printTextSingleLine(line.value, color, lowercase)
|
printTextSingleLine(line.value, color, lowercase, inverseVideo)
|
||||||
if(line.index<lines.size-1) {
|
if(line.index<lines.size-1) {
|
||||||
cursorX=0
|
cursorX=0
|
||||||
cursorY++
|
cursorY++
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
private fun printTextSingleLine(text: String, color: Short, lowercase: Boolean) {
|
private fun printTextSingleLine(text: String, color: Short, lowercase: Boolean, inverseVideo: Boolean=false) {
|
||||||
for(clearx in cursorX until cursorX+text.length) {
|
for(clearx in cursorX until cursorX+text.length) {
|
||||||
g2d.clearRect(8*clearx, 8*y, 8, 8)
|
g2d.clearRect(8*clearx, 8*y, 8, 8)
|
||||||
}
|
}
|
||||||
for(sc in Petscii.encodeScreencode(text, lowercase)) {
|
for(sc in Petscii.encodePetscii(text, lowercase)) {
|
||||||
setChar(cursorX, cursorY, sc, color)
|
setPetscii(cursorX, cursorY, sc, color, inverseVideo)
|
||||||
cursorX++
|
cursorX++
|
||||||
if(cursorX>=(SCREENWIDTH /8)) {
|
if(cursorX>=(SCREENWIDTH /8)) {
|
||||||
cursorY++
|
cursorY++
|
||||||
@ -86,12 +86,12 @@ class BitmapScreenPanel : KeyListener, JPanel() {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
fun printChar(char: Short) {
|
fun printPetscii(char: Short, inverseVideo: Boolean=false) {
|
||||||
if(char==13.toShort() || char==141.toShort()) {
|
if(char==13.toShort() || char==141.toShort()) {
|
||||||
cursorX=0
|
cursorX=0
|
||||||
cursorY++
|
cursorY++
|
||||||
} else {
|
} else {
|
||||||
setChar(cursorX, cursorY, char, 1)
|
setPetscii(cursorX, cursorY, char, 1, inverseVideo)
|
||||||
cursorX++
|
cursorX++
|
||||||
if (cursorX >= (SCREENWIDTH / 8)) {
|
if (cursorX >= (SCREENWIDTH / 8)) {
|
||||||
cursorY++
|
cursorY++
|
||||||
@ -100,10 +100,18 @@ class BitmapScreenPanel : KeyListener, JPanel() {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
fun setChar(x: Int, y: Int, screenCode: Short, color: Short) {
|
fun setPetscii(x: Int, y: Int, petscii: Short, color: Short, inverseVideo: Boolean) {
|
||||||
g2d.clearRect(8*x, 8*y, 8, 8)
|
g2d.clearRect(8*x, 8*y, 8, 8)
|
||||||
val colorIdx = (color % Colors.palette.size).toShort()
|
val colorIdx = (color % Colors.palette.size).toShort()
|
||||||
val coloredImage = Charset.getColoredChar(screenCode, colorIdx)
|
val screencode = Petscii.petscii2scr(petscii, inverseVideo)
|
||||||
|
val coloredImage = Charset.getColoredChar(screencode, colorIdx)
|
||||||
|
g2d.drawImage(coloredImage, 8*x, 8*y , null)
|
||||||
|
}
|
||||||
|
|
||||||
|
fun setChar(x: Int, y: Int, screencode: Short, color: Short) {
|
||||||
|
g2d.clearRect(8*x, 8*y, 8, 8)
|
||||||
|
val colorIdx = (color % Colors.palette.size).toShort()
|
||||||
|
val coloredImage = Charset.getColoredChar(screencode, colorIdx)
|
||||||
g2d.drawImage(coloredImage, 8*x, 8*y , null)
|
g2d.drawImage(coloredImage, 8*x, 8*y , null)
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -116,16 +124,16 @@ class BitmapScreenPanel : KeyListener, JPanel() {
|
|||||||
return Pair(cursorX, cursorY)
|
return Pair(cursorX, cursorY)
|
||||||
}
|
}
|
||||||
|
|
||||||
fun writeText(x: Int, y: Int, text: String, color: Short, lowercase: Boolean) {
|
fun writeText(x: Int, y: Int, text: String, color: Short, lowercase: Boolean, inverseVideo: Boolean=false) {
|
||||||
val colorIdx = (color % Colors.palette.size).toShort()
|
val colorIdx = (color % Colors.palette.size).toShort()
|
||||||
var xx=x
|
var xx=x
|
||||||
for(clearx in xx until xx+text.length) {
|
for(clearx in xx until xx+text.length) {
|
||||||
g2d.clearRect(8*clearx, 8*y, 8, 8)
|
g2d.clearRect(8*clearx, 8*y, 8, 8)
|
||||||
}
|
}
|
||||||
for(sc in Petscii.encodeScreencode(text, lowercase)) {
|
for(sc in Petscii.encodePetscii(text, lowercase)) {
|
||||||
if(sc==0.toShort())
|
if(sc==0.toShort())
|
||||||
break
|
break
|
||||||
setChar(xx++, y, sc, colorIdx)
|
setPetscii(xx++, y, sc, colorIdx, inverseVideo)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1926,7 +1926,7 @@ class StackVm(private var traceOutputFile: String?) {
|
|||||||
}
|
}
|
||||||
"c64.CHROUT" -> {
|
"c64.CHROUT" -> {
|
||||||
val sc=variables.getValue("A").integerValue()
|
val sc=variables.getValue("A").integerValue()
|
||||||
canvas?.printChar(sc.toShort())
|
canvas?.printPetscii(sc.toShort())
|
||||||
callstack.pop()
|
callstack.pop()
|
||||||
}
|
}
|
||||||
"c64.GETIN" -> {
|
"c64.GETIN" -> {
|
||||||
|
@ -1,18 +1,17 @@
|
|||||||
%import c64utils
|
%import c64utils
|
||||||
%zeropage basicsafe
|
%zeropage basicsafe
|
||||||
%option enable_floats
|
|
||||||
|
|
||||||
~ main {
|
~ main {
|
||||||
|
|
||||||
sub start() {
|
sub start() {
|
||||||
|
c64scr.print("you start here! --> S\n")
|
||||||
word zc
|
for A in 0 to 16 {
|
||||||
word qq = zc>>13
|
for Y in 0 to 39 {
|
||||||
ubyte[] colors = [1,2,3,4,5,6,7,8]
|
if rnd() >128 c64.CHROUT(109)
|
||||||
|
else c64.CHROUT(110)
|
||||||
uword bb = zc>>13
|
}
|
||||||
c64.SPCOL[0] = colors[(zc>>13) as byte + 4]
|
}
|
||||||
|
c64scr.print(" x <-- try to find your way here!")
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user