Click here to Skip to main content
Click here to Skip to main content

Import Adobe Photoshop (.psd) images

, 24 Jul 2006
Rate this:
Please Sign up or sign in to vote.
A generic class to import Adobe's Photoshop (.psd) images.

Sample Image - MyPSD.jpg

Introduction

MyPSD::CPSD class is a C++ class that can load images saved in Adobe's Photoshop native format. Due to my new job I had to upgrade to Visual Studio 2005, but still the class is as portable as possible, hence it uses standard C++ and STL. With minor changes, it can be ported to Visual Studio 6 (uses an older version of STL) or even to other Operating Systems.

License

The class MyPSD::CPSD is free; but if you are to use it in any kind of software, especially commercial ones, I would appreciate if you could just email me, it's nice to learn that something you've written is used by others.

Using MyPSD::CPSD in your projects

To use the class, just include in your project the two files MyPSD.h/.cpp. Since the class is placed inside its own namespace, either use the full name MyPSD::CPSD psd; or first the directive using namespace MyPSD; and then just declare a local variable CPSD psd;.

How to use MyPSD::CPSD

MyPSD::CPSD psd; int nErrorCode = psd.Load("c:\\image.psd");
if ( 0 == nErrorCode )   // No errors were found
{
     int nDPI_x, nDPI_y; // for Horizontal & Vertical dpi
     int nWidth, nHeight; // for Width & Height in pixels
     psd.Dimensions(nWidth, nHeight);
     psd.DPI(nDPI_x, nDPI_y);
     HBITMAP hBitmap = psd.Detach();
}
else if ( -1 == nErrorCode ) // Cannot open file
     ; // Do something
else if ( -2 == nErrorCode ) // Error in the header of the file
     ; // Do something 
else if ( -3 == nErrorCode ) // Error in ColourMode Data, i.e. Palette
     ; // Do something       // File must be Index to have ColourMode Data 
else if ( -4 == nErrorCode ) // Error in ImageResource section of the file
     ; // Do something
else if ( -5 == nErrorCode ) // Error in Mask Info section of the file
     ; // Do something 
else if ( -6 == nErrorCode ) // Error in Image Data section of the file
     ; // Do something       // Actual data for pixels 
else if ( -7 == nErrorCode ) // Image is Black & White
     ; // Do something       // not yet implemented 
else if ( -8 == nErrorCode ) // An unsupported file format encountered
     ; // Do something 
else if ( -9 == nErrorCode ) // Cannot create HBITMAP handle
     ; // Do something 
else if ( -10 == nErrorCode ) // Data are compressed
     ; // Do something        // Zip format without prediction. Not yet
                              // implemented 
else if ( -11 == nErrorCode ) // Data are compressed
     ; // Do something        // Zip format with prediction. Not yet 
                              // implemented 
else if ( -12 == nErrorCode ) // Data are in an unknown format
     ; // Do something

How to make it compatible to Visual Studio 6

The STL that comes with Visual Studio 6 does not support the method push_back for std::string. One way is to use CStrings, but then you will have to use MFC, and the other way is to make some minor changes where strings are used. I.e.:

std::string strOSType;
for(unsigned int nChar = 0; nChar < 4; ++nChar)
    strOSType.push_back(image_resource.OSType[nChar]);

std::string strOSType = "";
for(unsigned int nChar = 0; nChar < 4; ++nChar)
    strOSType += image_resource.OSType[nChar];

More info than necessary... future release... maybe

In the MyPsd.h file, I have put more info than is actually used in the demo, as my intention is someday to implement layers as they are supported in Photoshop. The way MyPSD::CPSD class is implemented in the current version, the HBITMAP that someone gets is the merged outcome of all layers. In the future, I will try to have each layer separately detached from the original image, but don't hold your breath as I don't know if I have enough free time to do so.

Supported Formats

RGB, Lab, CMY, CMYK, Indexed, Grayscale, Duotone. These formats could be uncompressed or compressed with RLE.

Unsupported Formats/Not yet implemented

Bitmap (Black & White), and any format that is compressed with ZIP with prediction and without prediction, and that is basically because I don't know the ZIP compression algorithm (with and without prediction).

Thanks

I would like to thank my mathematician friend Kostas Papamarinos who helped me translate the data from planar to RGB order, and all of you who are going to use my MyPSD::CPSD class and either send me an email or not.

What's new in version 1.0.0.4

  • Bug fixes - For correctly rendering Grayscale and Duotone PSD files. Samples included in the images.zip file that previous version could not read. As Visual Studio 2005 is more strict to the standard C++ and I hated all the warnings I was getting I have used the proposed functions which supposedly are more secure. I would like to apologise for any inconvenience caused by this change. If there is any problem just replace them with their equivalent older versions. Finally, for the above mentioned reasons, I am using a function to convert doubles to integers, as I would like to avoid type casting either done by me or the system .

What's new in version 1.0.0.3

  • Bug fixes - For correctly rendering PSD files. Each Image Resource Block includes a Pascal string, and the way I translated into C/C++ was not the proper way, as a result some files could not be read.

What's new in version 1.0.0.2

  • Bug fixes - I've found out that my previous version had some minor memory leaks.

License

This article, along with any associated source code and files, is licensed under The Code Project Open License (CPOL)

Share

About the Author

ihaml
Software Developer
Greece Greece
No Biography provided

Comments and Discussions

 
GeneralAbout illustrator PinmemberMr.Heng13-Sep-10 12:04 
GeneralFix for crash with some PSD files PinmemberHaving To Register Isn't Cool17-Jun-09 5:11 
GeneralRe: Fix for crash with some PSD files Pinmemberihaml17-Jun-09 6:50 
Questionwhat is each section in PSD file? Pinmemberdtdh18-Nov-07 14:33 
Hello everyone!
Now I want to import PSD file in layer, that is each layer displays as one picture, but I can't understand the PSD format completely, such as what is the Channel Image Data in setcion four, what is different between Channel Imaga Data and Image Data in section five ..etc? can anyone give me an answer in detail? I want to communicate the PSD format with you, thanks for your help.

Questionwhy cannot download sourcecode? Pinmemberpsdviewer19-Jun-07 4:53 
AnswerRe: why cannot download sourcecode? Pinmemberihaml19-Jun-07 19:53 
GeneralRe: why cannot download sourcecode? [modified] Pinmemberpsdviewer20-Jun-07 3:15 
GeneralIts awesome PinmemberQuartz.3-Apr-07 13:32 
Questionpsd thumbnail Pinmemberwohahaha10-Feb-07 3:44 
AnswerRe: psd thumbnail Pinmemberihaml10-Feb-07 7:46 
QuestionMay you help me? Pinmemberan_handsome14-Jan-07 15:43 
AnswerRe: May you help me? Pinmemberihaml15-Jan-07 7:02 
AnswerRe: May you help me? Pinmemberihaml15-Jan-07 7:12 
GeneralI have a asking about article Import Adobe Photoshop Pinmemberan_handsome14-Jan-07 15:37 
GeneralRe: I have a asking about article Import Adobe Photoshop Pinmemberihaml15-Jan-07 7:08 
GeneralStrange Problem at loading Pinmemberimage_processor6-Aug-06 3:41 
GeneralRe: Strange Problem at loading Pinmemberihaml6-Aug-06 4:21 
GeneralRe: Strange Problem at loading Pinmemberimage_processor6-Aug-06 21:36 
GeneralRe: Strange Problem at loading Pinmemberihaml16-Aug-06 22:22 
GeneralRe: Strange Problem at loading Pinmemberimage_processor23-Aug-06 18:10 
GeneralGood Job, and a question PinmemberDSclub1-Aug-06 16:08 
QuestionTransparencies and Alpha. PinmemberJim Koornneef25-Jul-06 3:09 
QuestionTransparent background? Pinmembercrjaes7-Dec-05 11:25 
AnswerRe: Transparent background? Pinmemberihaml7-Dec-05 22:52 
GeneralRe: Transparent background? Pinmemberc2j221-Mar-06 2:54 

General General    News News    Suggestion Suggestion    Question Question    Bug Bug    Answer Answer    Joke Joke    Rant Rant    Admin Admin   

Use Ctrl+Left/Right to switch messages, Ctrl+Up/Down to switch threads, Ctrl+Shift+Left/Right to switch pages.

| Advertise | Privacy | Mobile
Web04 | 2.8.140827.1 | Last Updated 24 Jul 2006
Article Copyright 2005 by ihaml
Everything else Copyright © CodeProject, 1999-2014
Terms of Service
Layout: fixed | fluid