• php源码 单色bmp图片取模工具 按任意方式取模 生成字节数组 自由编辑点阵


    http://2.wjsou.com/BMP/index.html

    想试试chatGPT4生成,还是要手工改

    php 写一个网页界面上可以选择一张bmp图片,界面上就显示这张bmp图片,
    点生成取模按钮,在图片下方会显示这张bmp图片的取模数据。
    取模规则是按界面设置的,是否横向取模或纵向取模 ,是否从左到右,是否从下到上,是否高位在前或高位在后,是否字节内像素数据反转,这些可以在界面切换。最后的数据是16进制字节数组,类似于下面格式
    //图片:D:\test.bmp
    //数据排列:横向从左到右从上到下 高位在前,宽:16,高:16
    //点阵数据:
    char Msk[]={
    0x00, 0x00, 0x3E, 0x20, 0x20, 0x3C, 0x22, 0x02, 0x22, 0x1C, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
    };

    支持php 5.6及以上版本。其它版本我没有测。

    没有用插件gd2等。用原始的读文件。
    单色bmp图片取模工具 php源码

    读每个点的颜色(放弃这个方案)

    这个图片处理要用到插件,就不用这个方案。gd2要php7.2才支持。用这个的好处就是可以任意图片png,jpg,bmp32位等。

    bmp解析,直接读数据

    倒过来,即0000003E处是像素点阵数据。其它信息都不太重要。
    在这里插入图片描述

    单色点阵数据在bmp中的格式

    在这里插入图片描述

    取模规则

    在这里插入图片描述
    可以自由组合。参照windows版:
    在这里插入图片描述

    对照验证

    在这里插入图片描述
    在这里插入图片描述

    DOCTYPE html>
    <html lang="zh">
    <head>
    	<meta charset="UTF-8">
        <title>单色bmp图片取模工具 php源码title>
    head>
    <body>
        <form id="uploadForm" enctype="multipart/form-data">
            <input type="file" name="image" accept=".bmp" required>
            <br>
    		<input type="checkbox" name="horizontal"> 横向取模(不勾选为纵向)
            <br>
    		<input type="checkbox" name="secondByteOnRight" checked> 第二字节在右(不勾选为第二字节在在下)
            <br>
    		<input type="checkbox" name="topToBottom" checked> 从上到下(无效)
            <input type="checkbox" name="leftToRight" checked> 从左到右(无效)
            <br>
            <input type="checkbox" name="highBitFirst" checked> 高位在前(即大端模式)
            <input type="checkbox" name="pixelReverse" checked> 像素反转(即黑白颠倒)
            <br>
            <button type="button" onclick="submitForm()">生成取模button>
        form>
        <br>
        <img id="previewImage" style="display:none;">
        <pre id="modResult">pre>
    
        <script>
            function submitForm() {
                var formData = new FormData(document.getElementById('uploadForm'));
                fetch('process_image.php', {
                    method: 'POST',
                    body: formData,
                })
                .then(response => response.json())
                .then(data => {
                    document.getElementById('previewImage').src = data.imageUrl;
                    document.getElementById('previewImage').style.display = 'block';
                    document.getElementById('modResult').textContent = data.modData;
                });
            }
        script>
    body>
    html>
    
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26
    • 27
    • 28
    • 29
    • 30
    • 31
    • 32
    • 33
    • 34
    • 35
    • 36
    • 37
    • 38
    • 39
    • 40
    • 41
    • 42
    • 43
    • 44
  • 相关阅读:
    PostgreSQL 创建数据库、创建用户、赋予权限、创建表、主键总结
    消息队列的选择与应用
    GaussDB高斯数据库(数据库基础知识)
    基于spring boot 的学生科研项目共享平台 毕业设计-附源码271611
    【无标题】线性表-C语言 数据结构
    管理类联考——英语二——记忆篇——按题型记忆必要单词
    Linux 网络之ss
    广播状态实现注意事项
    StringBuilder解析
    基于Java+SpringBoot+小程序实现的小说阅读管理系统
  • 原文地址:https://blog.csdn.net/chenhao0568/article/details/136397565