OLED取模软件的编码算法(自己取模时候注意)

数据结构

使用16进制数的一维数列来传递信息。其中的每个4位的数控制4个pixe的亮灭。两个拼在一起控制8个像素。
但是其扫描的排列却是竖着的。具体来说,第一列表示为0XFF,灯全亮。第二列表示为0X01,只有第一个亮了。因此自己写取模软件时候,需要每八行为一组,每组表示一个8位数。同时注意字符串是反着

第一列第二列
11
10
10
10
10
10
10
10

算法一

按照数据格式直观来写:
伪代码

for 组数 in 图像高度/8:
	for 列数 in 图像长度:
		获取8位数的每一位
		转置一下
		for 位数 in 8:
			给1*8矩阵的对应位数赋值

算法二

观察到数据格式中有18和81两种,不如把它变换一下:
转置一下目标矩阵(此时还是空的),然后横着把数据填进去(八位数填八位数),最后转置回来。

注意这里的“高度”为了和图像对齐,没改,但是这里是转置过的

for 列数 in 图像长度:
	for 组数 in 图像高度/8:
		获取8位数对应的数组
		转置一下
		数组放在对应'组数'的位置
转置图像

java代码

import java.util.ArrayList;
//指定为128x64的像素点
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;
    }

    //8

    //128
    //64/8次
    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", "");
    }
}

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值