数据结构
使用16进制数的一维数列来传递信息。其中的每个4位的数控制4个pixe的亮灭。两个拼在一起控制8个像素。 但是其扫描的排列却是竖着的。具体来说,第一列表示为0XFF,灯全亮。第二列表示为0X01,只有第一个亮了。因此自己写取模软件时候,需要每八行为一组,每组表示一个8位数。同时注意字符串是反着的
算法一
按照数据格式直观来写: 伪代码
for 组数 in 图像高度/8:
for 列数 in 图像长度:
获取8位数的每一位
转置一下
for 位数 in 8:
给1*8矩阵的对应位数赋值
算法二
观察到数据格式中有18和81两种,不如把它变换一下: 转置一下目标矩阵(此时还是空的),然后横着把数据填进去(八位数填八位数),最后转置回来。
注意这里的“高度”为了和图像对齐,没改,但是这里是转置过的
for 列数 in 图像长度:
for 组数 in 图像高度/8:
获取8位数对应的数组
转置一下
数组放在对应'组数'的位置
转置图像
java代码
import java.util.ArrayList;
public class Hex2PixelCore {
private ArrayList<Integer> data = new ArrayList<>();
public Hex2PixelCore() {
}
public Hex2PixelCore(ArrayList<Integer> data) {
this.data = data;
}
public ArrayList<Integer> getData() {
return data;
}
public void setData(ArrayList<Integer> data) {
this.data = data;
}
private String tran(Integer integer){
String str = "" + Integer.toBinaryString(integer);
if (str.length() < 8){
String temp = "";
for (int i = 0; i < 8 - str.length(); i++) {
temp = temp + "0";
}
str = temp + str;
}
String result = "";
for (int i = 0; i < str.length(); i++) {
result += str.charAt(str.length() - i - 1);
}
return result;
}
private String getBin(){
StringBuilder builder = new StringBuilder();
for (int i = 0; i < 128; i++) {
for (int j = 0; j < 8; j++) {
builder.append(tran(data.get(i+128*j)));
}
builder.append("\r\n");
}
String string = builder.toString().replaceAll("\r\n", "");
char[][] stringChars = new char[128][64];
char[][] resultChars = new char[64][129];
int m = 0;
for (int i = 0; i < 128; i++) {
for (int j = 0; j < 64; j++) {
stringChars[i][j] = string.charAt(m++);
}
}
for (int i = 0; i < 64; i++) {
for (int j = 0; j < 128; j++) {
resultChars[i][j] = stringChars[j][i];
}
resultChars[i][128] = '\n';
}
char[] result = new char[129*64];
int len = 0;
for (int i = 0; i < 64; i++) {
for (int j = 0; j < 129; j++) {
result[len++] = resultChars[i][j];
}
}
return new String(result);
}
public String getResult(){
return getBin().replaceAll("0", "").replaceAll("1", "");
}
}
|