SVN commit 794348 by cgilles:
libkdcraw from KDE3 branch: update to new dcraw.c 8.84 Support the Canon EOS 450D, Nikon D60, and Fuji S100FS. Copied new matrices from Adobe DNG Converter 4.4. sRAW support in 1.393 broke Fuji DNG files, now fixed. CCMAIL: [hidden email] M +4 -1 CAMERALIST M +37 -16 dcraw.c --- branches/extragear/kde3/libs/libkdcraw/dcraw/CAMERALIST #794347:794348 @@ -49,6 +49,7 @@ Canon EOS 300D / Digital Rebel / Kiss Digital Canon EOS 350D / Digital Rebel XT / Kiss Digital N Canon EOS 400D / Digital Rebel XTi / Kiss Digital X +Canon EOS 450D / Digital Rebel XSi / Kiss Digital X2 Canon EOS D2000C Canon EOS-1D Canon EOS-1DS @@ -86,6 +87,7 @@ Fuji FinePix S3Pro Fuji FinePix S5Pro Fuji FinePix S20Pro +Fuji FinePix S100FS Fuji FinePix S5000 Fuji FinePix S5100/S5500 Fuji FinePix S5200/S5600 @@ -186,6 +188,7 @@ Nikon D40 Nikon D40X Nikon D50 +Nikon D60 Nikon D70 Nikon D70s Nikon D80 @@ -293,4 +296,4 @@ Sony DSLR-A350 Sony DSLR-A700 Sony XCD-SX910CR -STV680 VGA \ No newline at end of file +STV680 VGA \ No newline at end of file --- branches/extragear/kde3/libs/libkdcraw/dcraw/dcraw.c #794347:794348 @@ -19,11 +19,11 @@ *If you have not modified dcraw.c in any way, a link to my homepage qualifies as "full source code". - $Revision: 1.399 $ - $Date: 2008/03/05 01:29:34 $ + $Revision: 1.400 $ + $Date: 2008/04/06 01:18:43 $ */ -#define VERSION "8.83" +#define VERSION "8.84" #define _GNU_SOURCE #define _USE_MATH_DEFINES @@ -799,7 +799,7 @@ enough to decode Canon, Kodak and Adobe DNG images. */ struct jhead { - int bits, high, wide, clrs, psv, restart, vpred[4]; + int bits, high, wide, clrs, sraw, psv, restart, vpred[4]; struct CLASS decode *huff[4]; ushort *row; }; @@ -823,12 +823,13 @@ if (tag <= 0xff00) return 0; fread (data, 1, len, ifp); switch (tag) { - case 0xffc0: data[7] = 0; case 0xffc3: + jh->sraw = data[7] == 0x21; + case 0xffc0: jh->bits = data[0]; jh->high = data[1] << 8 | data[2]; jh->wide = data[3] << 8 | data[4]; - jh->clrs = data[5] + (data[7] == 0x21); + jh->clrs = data[5] + jh->sraw; if (len == 9 && !dng_version) getc(ifp); break; case 0xffc4: @@ -846,7 +847,7 @@ } } while (tag != 0xffda); if (info_only) return 1; - if (jh->clrs == 4) { + if (jh->sraw) { jh->huff[3] = jh->huff[2] = jh->huff[1]; jh->huff[1] = jh->huff[0]; } @@ -886,7 +887,7 @@ for (col=0; col < jh->wide; col++) FORC(jh->clrs) { diff = ljpeg_diff (jh->huff[c]); - if (jh->clrs == 4 && c < 2 && (col | c)) + if (jh->sraw && c < 2 && (col | c)) pred = row[0][(c << 1)-3]; else if (col) pred = row[0][-jh->clrs]; else pred = (jh->vpred[c] += diff) - diff; @@ -5358,6 +5359,7 @@ is_raw = 0; if (!dng_version && tiff_bps == 8 && tiff_compress == 1 && tiff_ifd[raw].phint == 1) is_raw = 0; + if (tiff_bps == 8 && tiff_samples == 4) is_raw = 0; for (i=0; i < tiff_nifds; i++) if (i != raw && tiff_ifd[i].samples == max_samp && tiff_ifd[i].width * tiff_ifd[i].height / SQR(tiff_ifd[i].bps+1) > @@ -6022,6 +6024,8 @@ { 6018,-617,-965,-8645,15881,2975,-1530,1719,7642 } }, { "Canon EOS 400D", 0, { 7054,-1501,-990,-8156,15544,2812,-1278,1414,7796 } }, + { "Canon EOS 450D", 0, + { 5784,-262,-821,-7539,15064,2672,-1982,2681,7427 } }, { "Canon EOS-1Ds Mark III", 0, { 5859,-211,-930,-8255,16017,2353,-1732,1887,7448 } }, { "Canon EOS-1Ds Mark II", 0, @@ -6100,6 +6104,8 @@ { 11044,-3888,-1120,-7248,15168,2208,-1531,2277,8069 } }, { "FUJIFILM FinePix F7", 0, { 10004,-3219,-1201,-7036,15047,2107,-1863,2565,7736 } }, + { "FUJIFILM FinePix S100FS", 514, + { 11521,-4355,-1065,-6524,13767,3058,-1466,1984,6045 } }, { "FUJIFILM FinePix S20Pro", 0, { 10004,-3219,-1201,-7036,15047,2107,-1863,2565,7736 } }, { "FUJIFILM FinePix S2Pro", 128, @@ -6230,6 +6236,8 @@ { 6992,-1668,-806,-8138,15748,2543,-874,850,7897 } }, { "NIKON D50", 0, { 7732,-2422,-789,-8238,15884,2498,-859,783,7330 } }, + { "NIKON D60", 0, + { 8736,-2458,-935,-9075,16894,2251,-1354,1242,8263 } }, { "NIKON D70", 0, { 7732,-2422,-789,-8238,15884,2498,-859,783,7330 } }, { "NIKON D80", 0, @@ -6306,6 +6314,8 @@ { 11597,-4006,-1049,-5432,12799,2957,-1029,1750,6516 } }, { "OLYMPUS SP560UZ", 0, { 10915,-3677,-982,-5587,12986,2911,-1168,1968,6223 } }, + { "OLYMPUS SP570UZ", 0, + { 11522,-4044,-1146,-4736,12172,2904,-988,1829,6039 } }, { "PENTAX *ist DL2", 0, { 10504,-2438,-1189,-8603,16207,2531,-1022,863,12242 } }, { "PENTAX *ist DL", 0, @@ -6320,6 +6330,10 @@ { 9566,-2863,-803,-7170,15172,2112,-818,803,9705 } }, { "PENTAX K1", 0, { 11095,-3157,-1324,-8377,15834,2720,-1108,947,11688 } }, + { "PENTAX K20D", 0, + { 9427,-2714,-868,-7493,16092,1373,-2199,3264,7180 } }, + { "PENTAX K200D", 0, + { 9186,-2678,-907,-8693,16517,2260,-1129,1094,8524 } }, { "Panasonic DMC-FZ8", 0, { 8986,-2755,-802,-6341,13575,3077,-1476,2144,6379 } }, { "Panasonic DMC-FZ18", 0, @@ -6360,8 +6374,8 @@ { 9437,-2811,-774,-8405,16215,2290,-710,596,7181 } }, { "SONY DSLR-A200", 0, { 9847,-3091,-928,-8485,16345,2225,-715,595,7103 } }, - { "SONY DSLR-A350", 0, /* copied from above */ - { 9847,-3091,-928,-8485,16345,2225,-715,595,7103 } }, + { "SONY DSLR-A3", 0, + { 6038,-1484,-578,-9146,16746,2513,-875,746,7217 } }, { "SONY DSLR-A700", 254, { 5775,-805,-359,-8574,16295,2391,-1943,2341,7249 } } }; @@ -6654,11 +6668,9 @@ load_raw = &CLASS adobe_dng_load_raw_lj; goto dng_skip; } - if ((is_canon = !strcmp(make,"Canon"))) { + if ((is_canon = !strcmp(make,"Canon"))) load_raw = memcmp (head+6,"HEAPCCDR",8) ? &CLASS lossless_jpeg_load_raw : &CLASS canon_compressed_load_raw; - maximum = 0xfff; - } if (!strcmp(make,"NIKON") && !load_raw) load_raw = &CLASS nikon_load_raw; @@ -6860,6 +6872,13 @@ width = 4032; top_margin = 12; left_margin = 48; + } else if (is_canon && raw_width == 4312) { + top_margin = 18; + left_margin = 22; + height -= 2; + if (unique_id == 0x80000176) + adobe_coeff ("Canon","EOS 450D"); + goto canon_cr2; } else if (is_canon && raw_width == 4476) { top_margin = 34; left_margin = 90; @@ -6885,6 +6904,7 @@ width -= 4; pixel_aspect = 0.5; } else if (!strcmp(model,"D40X") || + !strcmp(model,"D60") || !strcmp(model,"D80")) { height -= 3; width -= 4; @@ -6906,8 +6926,9 @@ } else if (!strncmp(model,"D2H",3)) { left_margin = 6; width -= 14; - } else if (!strcmp(model,"D2X")) { - width -= 8; + } else if (!strncmp(model,"D2X",3)) { + if (width == 3264) width -= 32; + else width -= 8; maximum = 0xf35; } else if (!strcmp(model,"D3")) { width -= 4; @@ -8318,7 +8339,7 @@ if (identify_only && verbose && make[0]) { printf (_("\nFilename: %s\n"), ifname); printf (_("Timestamp: %s"), ctime(×tamp)); - printf (_("Camera: %s\n"), make); + printf (_("Make: %s\n"), make); printf (_("Model: %s\n"), model); if (artist[0]) printf (_("Owner: %s\n"), artist); _______________________________________________ Digikam-devel mailing list [hidden email] https://mail.kde.org/mailman/listinfo/digikam-devel |
Free forum by Nabble | Edit this page |