Add support for characters starting with a set pixel.
This commit is contained in:
parent
d3882b0b80
commit
1aaf25d5cc
3 changed files with 20 additions and 5 deletions
|
@ -50,6 +50,11 @@ uint8_t * pk_decode(const uint8_t * data,int * len){
|
|||
int pos=0; // Decoder internal: current bit position (0..7)
|
||||
int nyb; // Decoder internal: current nibble / value
|
||||
|
||||
if(data[ctr]>>4 == 14){ // Char starts with 1-bits.
|
||||
gnn();
|
||||
curbit=1;
|
||||
};
|
||||
|
||||
while(ctr<length){ /* Iterate the whole input stream */
|
||||
|
||||
/* Get next encoded nibble and decode */
|
||||
|
|
|
@ -89,6 +89,13 @@ int decode(char c){
|
|||
int curbit=0; // Decoder internal: current bit (1 or 0)
|
||||
int pos=0; // Decoder internal: current bit position (0..7)
|
||||
int nyb; // Decoder internal: current nibble / value
|
||||
|
||||
if(font->au8FontTable[off+0]>>4 == 14){
|
||||
// HACK: char starts with 1-bits,
|
||||
gnn();
|
||||
curbit=1;
|
||||
};
|
||||
|
||||
while(ctr<length){ /* Iterate the whole input stream */
|
||||
|
||||
/* Get next encoded nibble and decode */
|
||||
|
@ -168,3 +175,4 @@ int main(void){
|
|||
|
||||
exit(0);
|
||||
}
|
||||
|
||||
|
|
|
@ -307,9 +307,6 @@ sub pk_rle {
|
|||
|
||||
my $line=join("",@$char);;
|
||||
|
||||
my $fpx=substr($line,0,1);
|
||||
warn "first pixel ==1 - Encoder will do stupid things..." if $fpx ==1 ;
|
||||
|
||||
my @out;
|
||||
while($line=~/./){
|
||||
$line=~s/^(0*)(\[\d+\])?(1*)(\[\d+\])?//;
|
||||
|
@ -362,8 +359,12 @@ sub pk_encode {
|
|||
my $n=$1-1; # this deviates from PK spec, i think.
|
||||
push @enc,14,pk_encode_long($1-1);
|
||||
};
|
||||
}elsif($_ == 0){
|
||||
warn "Encoder asked to encode a zero?"; # Shouldn't happen.
|
||||
}elsif($_ == 0){ # Encoding a 0 will only happen at the start of
|
||||
# character if "first pixel" is 1 instead of 0.
|
||||
# HACK: We transmit this fact to the decoder
|
||||
# by encoding a "14"-nibble which would be
|
||||
# illegal at this point anyway.
|
||||
push @enc,14;
|
||||
}elsif($_ <= $dyn){ # Short length
|
||||
push @enc,$_;
|
||||
}elsif($_ <= 16*(13-$dyn)+$dyn){ # Medium length
|
||||
|
@ -417,3 +418,4 @@ sub do_pk {
|
|||
|
||||
return make_bytes(@enc);
|
||||
};
|
||||
|
||||
|
|
Loading…
Reference in a new issue