获取照片尺寸代码

#pragma once
#include <stdio.h>
#include <tchar.h>
#include <SDKDDKVer.h>

#define MAKEUS(a, b)    ((unsigned short) ( ((unsigned short)(a))<<8 | ((unsigned short)(b)) ))
#define MAKEUI(a,b,c,d) ((unsigned int) ( ((unsigned int)(a)) << 24 | ((unsigned int)(b)) << 16 | ((unsigned int)(c)) << 8 | ((unsigned int)(d)) ))

#define M_DATA  0x00
#define M_SOF0  0xc0
#define M_DHT   0xc4
#define M_SOI   0xd8
#define M_EOI   0xd9
#define M_SOS   0xda
#define M_DQT   0xdb
#define M_DNL   0xdc
#define M_DRI   0xdd
#define M_APP0  0xe0
#define M_APPF  0xef
#define M_COM   0xfe

#include <stdlib.h>
#include <string.h>

int GetJPEGWidthHeight(const char* path, unsigned int *punWidth, unsigned int *punHeight)
{
    int Finished = 0;
    unsigned char id, ucHigh, ucLow;
    FILE *pfRead;

    *punWidth = 0;
    *punHeight = 0;

    if (fopen_s(&pfRead, path, "rb") != 0)
    {
        printf("[GetJPEGWidthHeight]:can't open file:%s\n", path);
        return -1;
    }

    while (!Finished)
    {
        if (!fread(&id, sizeof(char), 1, pfRead) || id != 0xff || !fread(&id, sizeof(char), 1, pfRead))
        {
            Finished = -2;
            break;
        }

        if (id >= M_APP0 && id <= M_APPF)
        {
            fread(&ucHigh, sizeof(char), 1, pfRead);
            fread(&ucLow, sizeof(char), 1, pfRead);
            fseek(pfRead, (long)(MAKEUS(ucHigh, ucLow) - 2), SEEK_CUR);
            continue;
        }

        switch (id)
        {
        case M_SOI:
            break;

        case M_COM:
        case M_DQT:
        case M_DHT:
        case M_DNL:
        case M_DRI:
            fread(&ucHigh, sizeof(char), 1, pfRead);
            fread(&ucLow, sizeof(char), 1, pfRead);
            fseek(pfRead, (long)(MAKEUS(ucHigh, ucLow) - 2), SEEK_CUR);
            break;

        case M_SOF0:
            fseek(pfRead, 3L, SEEK_CUR);
            fread(&ucHigh, sizeof(char), 1, pfRead);
            fread(&ucLow, sizeof(char), 1, pfRead);
            *punHeight = (unsigned int)MAKEUS(ucHigh, ucLow);
            fread(&ucHigh, sizeof(char), 1, pfRead);
            fread(&ucLow, sizeof(char), 1, pfRead);
            *punWidth = (unsigned int)MAKEUS(ucHigh, ucLow);
            fclose(pfRead);
            return 0;

        case M_SOS:
        case M_EOI:
        case M_DATA:
            Finished = -1;
            break;

        default:
            fread(&ucHigh, sizeof(char), 1, pfRead);
            fread(&ucLow, sizeof(char), 1, pfRead);
            printf("[GetJPEGWidthHeight]:unknown id: 0x%x ;  length=%hd\n", id, MAKEUS(ucHigh, ucLow));
            if (fseek(pfRead, (long)(MAKEUS(ucHigh, ucLow) - 2), SEEK_CUR) != 0)
                Finished = -2;
            break;
        }
    }

    if (Finished == -1)
        printf("[GetJPEGWidthHeight]:can't find SOF0!\n");
    else if (Finished == -2)
        printf("[GetJPEGWidthHeight]:jpeg format error!\n");
    fclose(pfRead);
    return -1;
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
以下是一个简单的示例代码,可以实现在固定尺寸照片上设置放大镜: ```html <!DOCTYPE html> <html> <head> <title>商品放大镜</title> <style> /* 放大镜容器 */ .zoom { position: relative; width: 200px; height: 200px; margin: 50px auto; overflow: hidden; border: 1px solid #d4d4d4; } /* 放大镜 */ .zoom img { position: absolute; top: 0; left: 0; width: 400px; /* 放大后的图片宽度 */ height: 400px; /* 放大后的图片高度 */ display: none; } /* 鼠标跟随区域 */ .zoom-lens { position: absolute; width: 100px; height: 100px; border: 1px solid #d4d4d4; opacity: 0.5; } </style> </head> <body> <div class="zoom"> <img src="image.jpg" width="200" height="200" alt="商品图片"> <div class="zoom-lens"></div> </div> <script> // 获取元素 var zoom = document.querySelector('.zoom'); var lens = document.querySelector('.zoom-lens'); var img = zoom.querySelector('img'); // 鼠标移动事件 zoom.addEventListener('mousemove', function(e) { // 获取鼠标在放大镜容器中的位置 var x = e.pageX - this.offsetLeft; var y = e.pageY - this.offsetTop; // 计算放大镜位置 var lensX = x - lens.offsetWidth / 2; var lensY = y - lens.offsetHeight / 2; // 限制放大镜的移动范围 if (lensX < 0) lensX = 0; if (lensY < 0) lensY = 0; if (lensX > zoom.offsetWidth - lens.offsetWidth) lensX = zoom.offsetWidth - lens.offsetWidth; if (lensY > zoom.offsetHeight - lens.offsetHeight) lensY = zoom.offsetHeight - lens.offsetHeight; // 设置放大镜位置 lens.style.left = lensX + 'px'; lens.style.top = lensY + 'px'; // 计算放大比例 var scale = img.offsetWidth / zoom.offsetWidth; // 设置放大后的图片位置 img.style.left = -lensX * scale + 'px'; img.style.top = -lensY * scale + 'px'; img.style.display = 'block'; }); // 鼠标移出事件 zoom.addEventListener('mouseout', function() { img.style.display = 'none'; }); </script> </body> </html> ``` 需要注意的是,代码中的图片路径需要根据实际情况进行修改。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值