获得jpg文件的实际尺寸

2016-01-29 18:32 32 1 收藏

获得jpg文件的实际尺寸,获得jpg文件的实际尺寸

【 tulaoshi.com - ASP 】

  bask

把它编译成组件就可以用了,还支持png


'I have released this source code into the public domain.  You may use it
'with no strings attached.
'Just call GetImageSize with a string containing the filename, and
'it will return a user defined type 'ImageSize'  (see below)
'Return values of 0 indicate an error of some sort.  The error handling
'in this module is limited.  There is *NO* error handling on the test
'form.  This routine is limited to X or Y sizes of 32767 pixels, but that
'should not be a problem.

'Check back at http://www.qtm.net/~davidc
'I may add support for more file types.

'supported in this version:
'JPEG
'GIF
'PNG

'This routine does not require any royalty fees for Unisys as it
'does nothing with the compressed part of GIF files.  It simply reads
'4 bytes to determine image size.

Option Explicit
Public WImg As Long
Public HImg As Long
Public Type ImageSize
    Width As Long
    Height As Long
End Type

Public Sub GetImageSize(sFileName As String)
    On Error Resume Next        'you'll want to change this
    Dim iFN As Integer
    Dim bTemp(3) As Byte
    Dim lFlen As Long
    Dim lPos As Long
    Dim bHmsb As Byte
    Dim bHlsb As Byte
    Dim bWmsb As Byte
    Dim bWlsb As Byte
    Dim bBuf(7) As Byte
    Dim bDone As Byte
    Dim iCount As Integer

    lFlen = FileLen(sFileName)
    iFN = FreeFile
    Open sFileName For Binary As iFN
    Get #iFN, 1, bTemp()
        
    'PNG file
    If bTemp(0) = &H89 And bTemp(1) = &H50 And bTemp(2) = &H4E _
    And bTemp(3) = &H47 Then
        Get #iFN, 19, bWmsb
        Get #iFN, 20, bWlsb
        Get #iFN, 23, bHmsb
        Get #iFN, 24, bHlsb
        'GetImageSize.Width = CombineBytes(bWlsb, bWmsb)
        'GetImageSize.Height = CombineBytes(bHlsb, bHmsb)
        WImg = CombineBytes(bWlsb, bWmsb)
        HImg = CombineBytes(bHlsb, bHmsb)
    End If
    
    'GIF file
    If bTemp(0) = &H47 And bTemp(1) = &H49 And bTemp(2) = &H46 _
    And bTemp(3) = &H38 Then
        Get #iFN, 7, bWlsb
        Get #iFN, 8, bWmsb
        Get #iFN, 9, bHlsb
        Get #iFN, 10, bHmsb
        'GetImageSize.Width = CombineBytes(bWlsb, bWmsb)
        'GetImageSize.Height = CombineBytes(bHlsb, bHmsb)
        WImg = CombineBytes(bWlsb, bWmsb)
        HImg = CombineBytes(bHlsb, bHmsb)
    End If
    
    
    'JPEG file
    If bTemp(0) = &HFF And bTemp(1) = &HD8 And bTemp(2) = &HFF Then
    D

来源:http://www.tulaoshi.com/n/20160129/1506246.html

延伸阅读
ps中如何做一把和实际尺寸一样的尺子   ps中如何做一把和实际尺寸一样的尺子呢? 最终效果: Tulaoshi.com 1,填充背景为灰色,再填充图案 2,新建一层,使用渐变,更改图层模式为柔光,如图; 3,新建图层,创建矩形,添加图层样式,如图; 4,再建立如图所示的蓝色矩形,添加图层样式,如图; ...
Author:David Euler Date: 2004/11/16 Email:de_euler-david@yahoo.com.cn 有任何问题,请与我联系:) 获取文件的版本信息: FileVersionInfo myFileVersionInfo1 = FileVersionInfo.GetVersionInfo("D:\\TEST.DLL"); textBox1.Text="版本号: " + myFileVersionInfo1.FileVersion; 更改文件属性,删除只读文件: 下例欲将E:\test.txt文件拷...
?xml:namespace prefix = o ns = "urn:schemas-microsoft-com:office:office" />   /** * jeruGraphics v 1.0 * * 看到一些动态生成图象的例子都是servlet完成的, * 而且程序很长,觉得不是无论从实用性还是可读性来说都不是太好。 * 这里给了段代码,命令行生成图象文件。这样是不是简单易用些呢? ...
要获得Windows的临时文件的存放路径,可以使用GetTempPathAPI函数。以下是该函数的声明: PrivateDeclareFunctionGetTempPathLib"kernel32"Alias_ "GetTempPathA"(ByValnBufferLengthAsLong,ByVallpBufferAsString)AsLong “BufferLength”是这个函数的第一个参数,它将指定接受传进来字符串的缓冲区大小。“Buffer...
鞋柜尺寸有哪些?鞋柜的尺寸介绍 鞋柜尺寸有哪些? 一般鞋柜尺寸 鞋柜尺寸在最初设计的时候,首先要考虑的是具体的使用情况,与实际的位置。不能太大,太大会影响美观,太小则不够使用,所以说一定要充分考虑清楚。 它并没有固定的标准尺寸,一般鞋柜尺寸高度不要超过1000mm,宽度是根据所利用的空间宽度合理划分;深度是...

经验教程

654

收藏

65
微博分享 QQ分享 QQ空间 手机页面 收藏网站 回到头部