Ir para conteúdo
Fórum Script Brasil
  • 0

Incompatibilidade de código


thiro

Pergunta

Tenho um código que salva um range de células como imagem .bmp.

Ele funcionava no office 2007 com windows xp; mas não funciona no office 2011 com win 7 64 bits.

Pedi para um amigo testar e ele concluiu que o problema não é sistema operacional, mas sim a versao do office.

Mesmo botando PtrSafe, não funciona...

Segue o código.

Testo com: SaveRangePic Range("B2:D30"), "C:\teste.bmp"

Option Explicit

Private Declare PtrSafe Function OpenClipboard Lib "user32" (ByVal hwnd As Long) As Long

Private Declare PtrSafe Function GetClipboardData Lib "user32" (ByVal wFormat As Integer) As Long

Private Declare PtrSafe Function CloseClipboard Lib "user32" () As Long

Private Declare PtrSafe Function OleCreatePictureIndirect Lib "olepro32.dll" _

(PicDesc As uPicDesc, RefIID As GUID, ByVal fPictureOwnsHandle As Long, _

IPic As IPicture) As Long

'\\ Declare a UDT to store a GUID for the IPicture OLE Interface

Private Type GUID

Data1 As Long

Data2 As Integer

Data3 As Integer

Data4(0 To 7) As Byte

End Type

'\\ Declare a UDT to store the bitmap information

Private Type uPicDesc

Size As Long

Type As Long

hPic As Long

hPal As Long

End Type

Private Const CF_BITMAP = 2

Private Const PICTYPE_BITMAP = 1

Sub SaveRangePic(SourceRange As Range, FilePathName As String)

Dim IID_IDispatch As GUID

Dim uPicinfo As uPicDesc

Dim IPic As IPicture

Dim hPtr As Long

'\\ Copy Range to ClipBoard

SourceRange.CopyPicture Appearance:=xlScreen, Format:=xlBitmap

OpenClipboard 0

hPtr = GetClipboardData(CF_BITMAP)

CloseClipboard

'\\ Create the interface GUID for the picture

With IID_IDispatch

.Data1 = &H7BF80980

.Data2 = &HBF32

.Data3 = &H101A

.Data4(0) = &H8B

.Data4(1) = &HBB

.Data4(2) = &H0

.Data4(3) = &HAA

.Data4(4) = &H0

.Data4(5) = &H30

.Data4(6) = &HC

.Data4(7) = &HAB

End With

'\\ Fill uPicInfo with necessary parts.

With uPicinfo

.Size = Len(uPicinfo) '\\ Length of structure.

.Type = PICTYPE_BITMAP '\\ Type of Picture

.hPic = hPtr '\\ Handle to image.

.hPal = 0 '\\ Handle to palette (if bitmap).

End With

'\\ Create the Range Picture Object

OleCreatePictureIndirect uPicinfo, IID_IDispatch, True, IPic

'\\ Save Picture Object

stdole.SavePicture IPic, FilePathName

End Sub

Link para o comentário
Compartilhar em outros sites

0 respostass a esta questão

Posts Recomendados

Até agora não há respostas para essa pergunta

Participe da discussão

Você pode postar agora e se registrar depois. Se você já tem uma conta, acesse agora para postar com sua conta.

Visitante
Responder esta pergunta...

×   Você colou conteúdo com formatação.   Remover formatação

  Apenas 75 emoticons são permitidos.

×   Seu link foi incorporado automaticamente.   Exibir como um link em vez disso

×   Seu conteúdo anterior foi restaurado.   Limpar Editor

×   Você não pode colar imagens diretamente. Carregar ou inserir imagens do URL.



  • Estatísticas dos Fóruns

    • Tópicos
      152,3k
    • Posts
      652,2k
×
×
  • Criar Novo...