// Licence: wxWindows licence
/////////////////////////////////////////////////////////////////////////////
-#if defined(__GNUG__) && !defined(NO_GCC_PRAGMA)
-#pragma implementation "imagtiff.h"
-#endif
-
// For compilers that support precompilation, includes "wx.h".
#include "wx/wxprec.h"
}
static void
-TIFFwxWarningHandler(const char* module, const char* fmt, va_list ap)
+TIFFwxWarningHandler(const char* module,
+ const char* WXUNUSED_IN_UNICODE(fmt),
+ va_list WXUNUSED_IN_UNICODE(ap))
{
if (module != NULL)
- wxLogWarning(_("tiff module: %s"), module);
- wxLogWarning((wxChar *) fmt, ap);
+ wxLogWarning(_("tiff module: %s"), wxString::FromAscii(module).c_str());
+
+ // FIXME: this is not terrible informative but better than crashing!
+#if wxUSE_UNICODE
+ wxLogWarning(_("TIFF library warning."));
+#else
+ wxVLogWarning(fmt, ap);
+#endif
}
static void
-TIFFwxErrorHandler(const char* module, const char* fmt, va_list ap)
+TIFFwxErrorHandler(const char* module,
+ const char* WXUNUSED_IN_UNICODE(fmt),
+ va_list WXUNUSED_IN_UNICODE(ap))
{
if (module != NULL)
- wxLogError(_("tiff module: %s"), module);
- wxVLogError((wxChar *) fmt, ap);
+ wxLogError(_("tiff module: %s"), wxString::FromAscii(module).c_str());
+
+ // FIXME: as above
+#if wxUSE_UNICODE
+ wxLogError(_("TIFF library error."));
+#else
+ wxVLogError(fmt, ap);
+#endif
}
} // extern "C"
image->HasOption(wxIMAGE_OPTION_RESOLUTIONY) )
{
TIFFSetField(tif, TIFFTAG_XRESOLUTION,
- image->GetOptionInt(wxIMAGE_OPTION_RESOLUTIONX));
+ (float)image->GetOptionInt(wxIMAGE_OPTION_RESOLUTIONX));
TIFFSetField(tif, TIFFTAG_YRESOLUTION,
- image->GetOptionInt(wxIMAGE_OPTION_RESOLUTIONY));
+ (float)image->GetOptionInt(wxIMAGE_OPTION_RESOLUTIONY));
}
int spp = image->GetOptionInt(wxIMAGE_OPTION_SAMPLESPERPIXEL);
TIFFSetField(tif, TIFFTAG_ROWSPERSTRIP,TIFFDefaultStripSize(tif, (uint32) -1));
- uint8 bitmask;
-
unsigned char *ptr = image->GetData();
for ( int row = 0; row < image->GetHeight(); row++ )
{
for ( int column = 0; column < linebytes; column++ )
{
uint8 reverse = 0;
- bitmask = 1;
for ( int bp = 0; bp < 8; bp++ )
{
if ( ptr[column*24 + bp*3] > 0 )
// check only red as this is sufficient
reverse = reverse | 128 >> bp;
}
-
- bitmask <<= 1;
}
buf[column] = reverse;