mirror of
https://github.com/vlang/v.git
synced 2025-09-13 14:32:26 +03:00
fix
This commit is contained in:
parent
69623a2a22
commit
ca2d020d0c
1 changed files with 63 additions and 103 deletions
|
@ -1,7 +1,9 @@
|
|||
import arrays
|
||||
|
||||
pub fn Canvas.new(width int, height int) &Canvas {
|
||||
return &Canvas { layers: create_buffer(width, height) }
|
||||
return &Canvas{
|
||||
layers: create_buffer(width, height)
|
||||
}
|
||||
}
|
||||
|
||||
pub fn (canvas Canvas) size() (int, int) {
|
||||
|
@ -10,10 +12,10 @@ pub fn (canvas Canvas) size() (int, int) {
|
|||
|
||||
pub fn (canvas Canvas) string() string {
|
||||
output := buffer_to_braille(canvas.layers, dots_to_braille_rune_map)
|
||||
return arrays.join_to_string(output, "\n", |row| arrays.join_to_string(row, "", |character| "${character}"))
|
||||
return arrays.join_to_string(output, '\n', |row| arrays.join_to_string(row, '', |character| '${character}'))
|
||||
}
|
||||
|
||||
pub fn (mut canvas Canvas) set(x int , y int) {
|
||||
pub fn (mut canvas Canvas) set(x int, y int) {
|
||||
canvas.layers[y][x] = true
|
||||
}
|
||||
|
||||
|
@ -26,128 +28,86 @@ pub fn (mut canvas Canvas) clear() {
|
|||
canvas.layers = create_buffer(width, height)
|
||||
}
|
||||
|
||||
/* private code */
|
||||
|
||||
struct Canvas {
|
||||
mut:
|
||||
layers [][]bool
|
||||
mut:
|
||||
layers [][]bool
|
||||
}
|
||||
|
||||
/**
|
||||
* Maps each bit number in a dots byte (western reading order) to it's
|
||||
* corresponding bit number in the unicode Braille mapping.
|
||||
*/
|
||||
const dots_to_braille = [u8(0), 3, 1, 4, 2, 5, 6, 7]
|
||||
/**
|
||||
* Maps each possible dots byte to an unicode rune.
|
||||
*/
|
||||
const dots_to_braille_rune_map = memoize_dots_to_braille_rune()
|
||||
|
||||
/**
|
||||
* dots_to_braille_rune returns the Unicode Braille character for a given 8-dot
|
||||
* mask. Dots are numbered in “Western reading order” (left→right, top→bottom):
|
||||
* 1 2
|
||||
* 3 4
|
||||
* 5 6
|
||||
* 7 8
|
||||
* The input byte’s most significant bit represents dot 1, and the least
|
||||
* significant bit dot 8.
|
||||
* See: https://en.wikipedia.org/wiki/Braille_Patterns
|
||||
*
|
||||
* Parameters:
|
||||
* dots uint8 - 8-bit mask where each bit corresponds to a Braille dot.
|
||||
*
|
||||
* Returns:
|
||||
* rune - Unicode code point in the Braille block U+2800…U+28FF.
|
||||
*/
|
||||
fn dots_to_braille_rune(dots u8) rune {
|
||||
mut mask := 0
|
||||
for index in 0 .. 8 {
|
||||
mut mask := 0
|
||||
for index in 0 .. 8 {
|
||||
if ((dots >> index) & 1) == 1 {
|
||||
mask |= 1 << dots_to_braille[index]
|
||||
}
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
return rune(0x2800 + mask)
|
||||
}
|
||||
|
||||
fn memoize_dots_to_braille_rune() [256]rune {
|
||||
mut memo := [256]rune{}
|
||||
mut memo := [256]rune{}
|
||||
|
||||
for index in 0..256 {
|
||||
memo[index] = dots_to_braille_rune(index)
|
||||
}
|
||||
for index in 0 .. 256 {
|
||||
memo[index] = dots_to_braille_rune(index)
|
||||
}
|
||||
|
||||
return memo
|
||||
return memo
|
||||
}
|
||||
|
||||
/**
|
||||
* Converts a 2D boolean buffer into a 2D grid of Braille runes.
|
||||
*
|
||||
* Each group of 2x4 pixels from the boolean buffer is mapped into a single
|
||||
* Braille character. The function iterates through the buffer, calculates which
|
||||
* Braille dots should be active, and converts them into runes using
|
||||
* `dots_to_braille_rune`.
|
||||
*
|
||||
* Parameters:
|
||||
* buffer [][]bool - A 2D array of booleans representing pixels (true =
|
||||
* filled, false = empty). Dimensions are expected to be
|
||||
* multiples of 4 rows and 2 columns.
|
||||
* Returns:
|
||||
* [][]rune - A 2D array of runes where each rune corresponds to one Braille
|
||||
* character.
|
||||
*/
|
||||
fn buffer_to_braille(buffer [][]bool, braille_mapping [256]rune) [][]rune {
|
||||
out_rows := buffer.len/4
|
||||
out_cols := buffer[0].len/2
|
||||
mut output := [][]rune{len: out_rows, init: []rune{len: out_cols}}
|
||||
out_rows := buffer.len / 4
|
||||
out_cols := buffer[0].len / 2
|
||||
mut output := [][]rune{len: out_rows, init: []rune{len: out_cols}}
|
||||
|
||||
for row :=0; row < out_rows; row += 1 {
|
||||
row_offset := row * 4
|
||||
for column := 0; column < out_cols; column += 1 {
|
||||
col_offset := column * 2
|
||||
for row := 0; row < out_rows; row += 1 {
|
||||
row_offset := row * 4
|
||||
for column := 0; column < out_cols; column += 1 {
|
||||
col_offset := column * 2
|
||||
|
||||
mut dots := u8(buffer[row_offset+0][col_offset+0])
|
||||
dots |= u8(buffer[row_offset+0][col_offset+1]) << 1
|
||||
dots |= u8(buffer[row_offset+1][col_offset+0]) << 2
|
||||
dots |= u8(buffer[row_offset+1][col_offset+1]) << 3
|
||||
dots |= u8(buffer[row_offset+2][col_offset+0]) << 4
|
||||
dots |= u8(buffer[row_offset+2][col_offset+1]) << 5
|
||||
dots |= u8(buffer[row_offset+3][col_offset+0]) << 6
|
||||
dots |= u8(buffer[row_offset+3][col_offset+1]) << 7
|
||||
mut dots := u8(buffer[row_offset + 0][col_offset + 0])
|
||||
dots |= u8(buffer[row_offset + 0][col_offset + 1]) << 1
|
||||
dots |= u8(buffer[row_offset + 1][col_offset + 0]) << 2
|
||||
dots |= u8(buffer[row_offset + 1][col_offset + 1]) << 3
|
||||
dots |= u8(buffer[row_offset + 2][col_offset + 0]) << 4
|
||||
dots |= u8(buffer[row_offset + 2][col_offset + 1]) << 5
|
||||
dots |= u8(buffer[row_offset + 3][col_offset + 0]) << 6
|
||||
dots |= u8(buffer[row_offset + 3][col_offset + 1]) << 7
|
||||
|
||||
output[row][column] = dots_to_braille_rune(dots)
|
||||
}
|
||||
}
|
||||
|
||||
return output
|
||||
}
|
||||
|
||||
fn create_buffer(width int, height int) [][]bool {
|
||||
return [][]bool{len: height, init: []bool{len: width}}
|
||||
}
|
||||
|
||||
fn test_main() {
|
||||
braille_mapping := memoize_dots_to_braille_rune()
|
||||
width, height := 40, 48
|
||||
mut canvas := Canvas.new(width, height)
|
||||
mut buffer := [][]bool{len: height, init: []bool{len: width}}
|
||||
|
||||
minr := 16*16
|
||||
maxr := 20*20
|
||||
for y:=0; y<48; y+=1 {
|
||||
for x:=0; x<width; x+=1 {
|
||||
cy := y - 24
|
||||
big_cx := x - 20
|
||||
small_cx := x - 16
|
||||
big := (big_cx*big_cx) + (cy*cy)
|
||||
small := (small_cx*small_cx) + (cy*cy)
|
||||
if small > minr && big < maxr {
|
||||
buffer[y][x] = true
|
||||
canvas.set(x, y)
|
||||
}
|
||||
output[row][column] = dots_to_braille_rune(dots)
|
||||
}
|
||||
}
|
||||
|
||||
_ := buffer_to_braille(buffer, braille_mapping)
|
||||
}
|
||||
return output
|
||||
}
|
||||
|
||||
fn create_buffer(width int, height int) [][]bool {
|
||||
return [][]bool{len: height, init: []bool{len: width}}
|
||||
}
|
||||
|
||||
fn test_main() {
|
||||
braille_mapping := memoize_dots_to_braille_rune()
|
||||
width, height := 40, 48
|
||||
mut canvas := Canvas.new(width, height)
|
||||
mut buffer := [][]bool{len: height, init: []bool{len: width}}
|
||||
|
||||
minr := 16 * 16
|
||||
maxr := 20 * 20
|
||||
for y := 0; y < 48; y += 1 {
|
||||
for x := 0; x < width; x += 1 {
|
||||
cy := y - 24
|
||||
big_cx := x - 20
|
||||
small_cx := x - 16
|
||||
big := (big_cx * big_cx) + (cy * cy)
|
||||
small := (small_cx * small_cx) + (cy * cy)
|
||||
if small > minr && big < maxr {
|
||||
buffer[y][x] = true
|
||||
canvas.set(x, y)
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
_ := buffer_to_braille(buffer, braille_mapping)
|
||||
}
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue