Show Posts

This section allows you to view all posts made by this member. Note that you can only see posts made in areas you currently have access to.


Messages - Sunny C.

Pages: 1 2 3 4 [5] 6 7 8 9 ... 116
61
Chit Chat / Re: I am back ; )
« on: October 14, 2014, 05:55:16 PM »
Welcome Back !

62
Wenn ein Bildname sich "Künster - Bildname" nennt und die Keywords auto generiert werden. Wie bekomme ich das "-" aus den Keywords weg? Denn er erstellt die K-Words so "Künstler,-,Bildname" !?

63
Chit Chat / Re: Biete Anpassung und Validierung
« on: January 23, 2014, 09:06:05 PM »
Kai,

ich wüsste nicht was das jetzt hier zu suchen hat. Dieser Fall ist etwas ganz spezielles gewesen und Gründe für den dermaßen niedrigen Niveau des Auftrags meinerseits, brauche ich hier nicht nennen. Frage mal auch andere User für denen ich Aufträge übernommen habe und du wirst positives Feedback bekommen. Auf Wunsch kann ich dir diese nennen. Traurig das immer nur dann etwas geschrieben wird, wenn es negativ ist. Aber was positives wird nicht gar nicht erst beachtet.

InAction wird nun den fertiggestellten Auftrag erhalten.

64
Wenn ein Bild erfolgreich gemeldet wird, kommt die Nachricht das es erfolgreich war und dann wird meine Seite immer geschlossen...?
Woran kann das liegen?

Lag an dem Close.

65
Mods & Plugins (Releases & Support) / Re: [Mod] Login Page
« on: January 03, 2014, 12:29:23 AM »
Kann man da auch das reCaptcha verbauen?
Bzw. Generell das Captcha?

66
Work! Thank you!
An extension for "Google+", "Steam" and "Twitter" would be great as well. Thanks for your extension.

67
I cant find the api key at the new facebook developers site !?

69
Mods & Plugins (Releases & Support) / Re: [Mod] Shoutbox II
« on: December 06, 2013, 04:42:31 AM »
Beim absenden erhalte ich folgenden Fehler:
Quote
DB Error: Bad SQL Query: DELETE FROM 4images_shoutbox WHERE shoutbox_id <= (LAST_INSERT_ID() - 100)
BIGINT UNSIGNED value is out of range in '(last_insert_id() - 100)'
Allerdings ist der Eintrag dann vorhanden und auch im ACP wird der Eintrag gefunden.
Hast du eine Ahnung?

____________________
Liegt wohl daran:
      if (!$error)  {
        
$sql "INSERT INTO ".SHOUTBOX_TABLE."
                (user_id, user_name, shoutbox_text, shoutbox_ip, shoutbox_date)
                VALUES
                ("
.$user_info['user_id'].", '$user_name', '".mysql_real_escape_string($shoutbox_text)."', '".$session_info['session_ip']."', ".time().")";
        
$site_db->query($sql);
        
        
$sql "DELETE FROM ".SHOUTBOX_TABLE."
                WHERE shoutbox_id <= (LAST_INSERT_ID() - "
.$config['shoutbox_stored_rows'].")
               "
;
        
$site_db->query($sql); 
              
      }

Meine Frage ist nur, warum diese Meldung beim absenden erscheint..

Bisher muss ich das auskommentieren:
	
	
/*
        $sql = "DELETE FROM ".SHOUTBOX_TABLE."
                WHERE shoutbox_id <= (LAST_INSERT_ID() - ".$config['shoutbox_stored_rows'].")";
        $site_db->query($sql); 
	
	
*/

70
TOP!

71
Mods & Plugins (Requests & Discussions) / PSD in 4images anzeigen
« on: December 04, 2013, 03:09:44 AM »
Hallo zusammen,

ich würde gerne auch PSD-Dateien als Bild ausgeben und anzeigen lassen.
Ich habe dazu eine php-class gefunden, welche die PSD als JPG ausgibt
<?php
class PhpPsdReader {
	
var 
$infoArray;
	
var 
$fp;
	
var 
$fileName;
	
var 
$tempFileName;
	
var 
$colorBytesLength;

	
function 
PhpPsdReader($fileName) {
	
	
set_time_limit(0);
	
	
$this->infoArray = array();
	
	
$this->fileName $fileName;
	
	
$this->fp fopen($this->fileName,'r');

	
	
if (
fread($this->fp,4)=='8BPS') {
	
	
	
$this->infoArray['version id'] = $this->_getInteger(2);
	
	
	
fseek($this->fp,6,SEEK_CUR); // 6 bytes of 0's
	
	
	
$this->infoArray['channels'] = $this->_getInteger(2);
	
	
	
$this->infoArray['rows'] = $this->_getInteger(4);
	
	
	
$this->infoArray['columns'] = $this->_getInteger(4);
	
	
	
$this->infoArray['colorDepth'] = $this->_getInteger(2);
	
	
	
$this->infoArray['colorMode'] = $this->_getInteger(2);


	
	
	
/* COLOR MODE DATA SECTION */ //4bytes Length The length of the following color data.
	
	
	
$this->infoArray['colorModeDataSectionLength'] = $this->_getInteger(4);
	
	
	
fseek($this->fp,$this->infoArray['colorModeDataSectionLength'],SEEK_CUR); // ignore this snizzle

	
	
	
/*  IMAGE RESOURCES */
	
	
	
$this->infoArray['imageResourcesSectionLength'] = $this->_getInteger(4);
	
	
	
fseek($this->fp,$this->infoArray['imageResourcesSectionLength'],SEEK_CUR); // ignore this snizzle

	
	
	
/*  LAYER AND MASK */
	
	
	
$this->infoArray['layerMaskDataSectionLength'] = $this->_getInteger(4);
	
	
	
fseek($this->fp,$this->infoArray['layerMaskDataSectionLength'],SEEK_CUR); // ignore this snizzle


	
	
	
/*  IMAGE DATA */
	
	
	
$this->infoArray['compressionType'] = $this->_getInteger(2);
	
	
	
$this->infoArray['oneColorChannelPixelBytes'] = $this->infoArray['colorDepth']/8;
	
	
	
$this->colorBytesLength $this->infoArray['rows']*$this->infoArray['columns']*$this->infoArray['oneColorChannelPixelBytes'];

	
	
	
if (
$this->infoArray['colorMode']==2) {
	
	
	
	
$this->infoArray['error'] = 'images with indexed colours are not supported yet';
	
	
	
	
return 
false;
	
	
	
}
	
	
} else {
	
	
	
$this->infoArray['error'] = 'invalid or unsupported psd';
	
	
	
return 
false;
	
	
}
	
}


	
function 
getImage() {
	
	
// decompress image data if required
	
	
switch(
$this->infoArray['compressionType']) {
	
	
	
// case 2:, case 3: zip not supported yet..
	
	
	
case 
1:
	
	
	
	
// packed bits
	
	
	
	
$this->infoArray['scanLinesByteCounts'] = array();
	
	
	
	
for (
$i=0$i<($this->infoArray['rows']*$this->infoArray['channels']); $i++) $this->infoArray['scanLinesByteCounts'][] = $this->_getInteger(2);
	
	
	
	
$this->tempFileName tempnam(realpath('/tmp'),'decompressedImageData');
	
	
	
	
$tfp fopen($this->tempFileName,'wb');
	
	
	
	
foreach (
$this->infoArray['scanLinesByteCounts'] as $scanLinesByteCount) {
	
	
	
	
	
fwrite($tfp,$this->_getPackedBitsDecoded(fread($this->fp,$scanLinesByteCount)));
	
	
	
	
}
	
	
	
	
fclose($tfp);
	
	
	
	
fclose($this->fp);
	
	
	
	
$this->fp fopen($this->tempFileName,'r');
	
	
	
default:
	
	
	
	
// continue with current file handle;
	
	
	
	
break;
	
	
}

	
	
// let's write pixel by pixel....
	
	
$image imagecreatetruecolor($this->infoArray['columns'],$this->infoArray['rows']);

	
	
for (
$rowPointer 0; ($rowPointer $this->infoArray['rows']); $rowPointer++) {
	
	
	
for (
$columnPointer 0; ($columnPointer $this->infoArray['columns']); $columnPointer++) {
	
	
	
	
/* 
	
The color mode of the file. Supported values are: Bitmap=0;
	
	
	
	
	
Grayscale=1; Indexed=2; RGB=3; CMYK=4; Multichannel=7;
	
	
	
	
	
Duotone=8; Lab=9.
	
	
	
	
*/
	
	
	
	
switch (
$this->infoArray['colorMode']) {
	
	
	
	
	
case 
2// indexed... info should be able to extract from color mode data section. not implemented yet, so is grayscale
	
	
	
	
	
	
exit;
	
	
	
	
	
	
break;
	
	
	
	
	
case 
0:
	
	
	
	
	
	
// bit by bit
	
	
	
	
	
	
if (
$columnPointer == 0$bitPointer 0;
	
	
	
	
	
	
if (
$bitPointer==0$currentByteBits str_pad(base_convert(bin2hex(fread($this->fp,1)), 162),8,'0',STR_PAD_LEFT);
	
	
	
	
	
	
$r $g $b = (($currentByteBits[$bitPointer]=='1')?0:255);
	
	
	
	
	
	
$bitPointer++;
	
	
	
	
	
	
if (
$bitPointer==8$bitPointer 0;
	
	
	
	
	
	
break;

	
	
	
	
	
case 
1:
	
	
	
	
	
case 
8// 8 is indexed with 1 color..., so grayscale
	
	
	
	
	
	
$r $g $b $this->_getInteger($this->infoArray['oneColorChannelPixelBytes']);
	
	
	
	
	
	
break;

	
	
	
	
	
case 
4// CMYK
	
	
	
	
	
	
$c $this->_getInteger($this->infoArray['oneColorChannelPixelBytes']);
	
	
	
	
	
	
$currentPointerPos ftell($this->fp);
	
	
	
	
	
	
fseek($this->fp,$this->colorBytesLength-1,SEEK_CUR);
	
	
	
	
	
	
$m $this->_getInteger($this->infoArray['oneColorChannelPixelBytes']);
	
	
	
	
	
	
fseek($this->fp,$this->colorBytesLength-1,SEEK_CUR);
	
	
	
	
	
	
$y $this->_getInteger($this->infoArray['oneColorChannelPixelBytes']);
	
	
	
	
	
	
fseek($this->fp,$this->colorBytesLength-1,SEEK_CUR);
	
	
	
	
	
	
$k $this->_getInteger($this->infoArray['oneColorChannelPixelBytes']);
	
	
	
	
	
	
fseek($this->fp,$currentPointerPos);
	
	
	
	
	
	
$r round(($c $k) / (pow(2,$this->infoArray['colorDepth'])-1));
	
	
	
	
	
	
$g round(($m $k) / (pow(2,$this->infoArray['colorDepth'])-1));
	
	
	
	
	
	
$b round(($y $k) / (pow(2,$this->infoArray['colorDepth'])-1));

  
	
	
	
	
	
	
break;

  
	
	
	
	
	
	
case 
9// hunter Lab
  
	
	
	
	
	
	
	
// i still need an understandable lab2rgb convert algorithm... if you have one, please let me know!
	
	
	
	
	
	
	
$l $this->_getInteger($this->infoArray['oneColorChannelPixelBytes']);
	
	
	
	
	
	
	
$currentPointerPos ftell($this->fp);
	
	
	
	
	
	
	
fseek($this->fp,$this->colorBytesLength-1,SEEK_CUR);
	
	
	
	
	
	
	
$a $this->_getInteger($this->infoArray['oneColorChannelPixelBytes']);
	
	
	
	
	
	
	
fseek($this->fp,$this->colorBytesLength-1,SEEK_CUR);
	
	
	
	
	
	
	
$b =  $this->_getInteger($this->infoArray['oneColorChannelPixelBytes']);
	
	
	
	
	
	
	
fseek($this->fp,$currentPointerPos);

	
	
	
	
	
	
	
$r $l;
	
	
	
	
	
	
	
$g $a;
	
	
	
	
	
	
	
$b $b;

	
	
	
	
	
	
break;
	
	
	
	
	
default:
	
	
	
	
	
	
$r $this->_getInteger($this->infoArray['oneColorChannelPixelBytes']);
	
	
	
	
	
	
$currentPointerPos ftell($this->fp);
	
	
	
	
	
	
fseek($this->fp,$this->colorBytesLength-1,SEEK_CUR);
	
	
	
	
	
	
$g $this->_getInteger($this->infoArray['oneColorChannelPixelBytes']);
	
	
	
	
	
	
fseek($this->fp,$this->colorBytesLength-1,SEEK_CUR);
	
	
	
	
	
	
$b =  $this->_getInteger($this->infoArray['oneColorChannelPixelBytes']);
	
	
	
	
	
	
fseek($this->fp,$currentPointerPos);
	
	
	
	
	
	
break;

	
	
	
	
}

	
	
	
	
if ((
$this->infoArray['oneColorChannelPixelBytes']==2)) {
	
	
	
	
	
$r $r >> 8;
	
	
	
	
	
$g $g >> 8;
	
	
	
	
	
$b $b >> 8;
	
	
	
	
} elseif ((
$this->infoArray['oneColorChannelPixelBytes']==4)) {
	
	
	
	
	
$r $r >> 24;
	
	
	
	
	
$g $g >> 24;
	
	
	
	
	
$b $b >> 24;
	
	
	
	
}

	
	
	
	
$pixelColor imagecolorallocate($image,$r,$g,$b);
	
	
	
	
imagesetpixel($image,$columnPointer,$rowPointer,$pixelColor);
	
	
	
}
	
	
}
	
	
fclose($this->fp);
	
	
if (isset(
$this->tempFileName)) unlink($this->tempFileName);
	
	
return 
$image;
	
}

	
/**
	
 *
	
 * PRIVATE FUNCTIONS
	
 *
	
 */

	
function 
_getPackedBitsDecoded($string) {
	
	
/*
	
	
The PackBits algorithm will precede a block of data with a one byte header n, where n is interpreted as follows:
	
	
n Meaning
	
	
0 to 127 Copy the next n + 1 symbols verbatim
	
	
-127 to -1 Repeat the next symbol 1 - n times
	
	
-128 Do nothing

	
	
Decoding:
	
	
Step 1. Read the block header (n).
	
	
Step 2. If the header is an EOF exit.
	
	
Step 3. If n is non-negative, copy the next n + 1 symbols to the output stream and go to step 1.
	
	
Step 4. If n is negative, write 1 - n copies of the next symbol to the output stream and go to step 1.

	
	
*/

	
	
$stringPointer 0;
	
	
$returnString '';

	
	
while (
1) {
	
	
	
if (isset(
$string[$stringPointer])) $headerByteValue $this->_unsignedToSigned(hexdec(bin2hex($string[$stringPointer])),1);
	
	
	
else return 
$returnString;
	
	
	
$stringPointer++;

	
	
	
if (
$headerByteValue >= 0) {
	
	
	
	
for (
$i=0$i <= $headerByteValue$i++) {
	
	
	
	
	
$returnString .= $string[$stringPointer];
	
	
	
	
	
$stringPointer++;
	
	
	
	
}
	
	
	
} else {
	
	
	
	
if (
$headerByteValue != -128) {
	
	
	
	
	
$copyByte $string[$stringPointer];
	
	
	
	
	
$stringPointer++;

	
	
	
	
	
for (
$i=0$i < (1-$headerByteValue); $i++) {
	
	
	
	
	
	
$returnString .= $copyByte;
	
	
	
	
	
}
	
	
	
	
}
	
	
	
}
	
	
}
	
}

	
function 
_unsignedToSigned($int,$byteSize=1) {
	
	
switch(
$byteSize) {
	
	
	
case 
1:
	
	
	
	
if (
$int<128) return $int;
	
	
	
	
else return -
256+$int;
	
	
	
	
break;

	
	
	
case 
2:
	
	
	
	
if (
$int<32768) return $int;
	
	
	
	
else return -
65536+$int;

	
	
	
case 
4:
	
	
	
	
if (
$int<2147483648) return $int;
	
	
	
	
else return -
4294967296+$int;

	
	
	
default:
	
	
	
	
return 
$int;
	
	
}
	
}

	
function 
_hexReverse($hex) {
	
	
$output '';
	
	
if (
strlen($hex)%2) return false;
	
	
for (
$pointer strlen($hex);$pointer>=0;$pointer-=2$output .= substr($hex,$pointer,2);
	
	
return 
$output;
	
}

	
function 
_getInteger($byteCount=1) {
	
	
switch (
$byteCount) {
	
	
	
case 
4:
	
	
	
	
// for some strange reason this is still broken...
	
	
	
	
return @
reset(unpack('N',fread($this->fp,4)));
	
	
	
	
break;

	
	
	
case 
2:
	
	
	
	
return @
reset(unpack('n',fread($this->fp,2)));
	
	
	
	
break;

	
	
	
default:
	
	
	
	
return 
hexdec($this->_hexReverse(bin2hex(fread($this->fp,$byteCount))));
	
	
}
	
}
}

/**
 * Returns an image identifier representing the image obtained from the given filename, using only GD, returns an empty string on failure
 *
 * @param string $fileName
 * @return image identifier
 */

function imagecreatefrompsd($fileName) {
	
$psdReader = new PhpPsdReader($fileName);
	
if (isset(
$psdReader->infoArray['error'])) return '';
	
else return 
$psdReader->getImage();
}
header("Content-type: image/jpeg");
print 
imagejpeg(imagecreatefrompsd('PATH-TO-FILE.PSD'));
?>


Wie kann man das umsetzen?

Ich habe nun versucht die Klasse und die functionen zu separieren:
psdtojpg.php (includes ordner)
<?php
class PhpPsdReader {
	
var 
$infoArray;
	
var 
$fp;
	
var 
$fileName;
	
var 
$tempFileName;
	
var 
$colorBytesLength;

	
function 
PhpPsdReader($fileName) {
	
	
set_time_limit(0);
	
	
$this->infoArray = array();
	
	
$this->fileName $fileName;
	
	
$this->fp fopen($this->fileName,'r');

	
	
if (
fread($this->fp,4)=='8BPS') {
	
	
	
$this->infoArray['version id'] = $this->_getInteger(2);
	
	
	
fseek($this->fp,6,SEEK_CUR); // 6 bytes of 0's
	
	
	
$this->infoArray['channels'] = $this->_getInteger(2);
	
	
	
$this->infoArray['rows'] = $this->_getInteger(4);
	
	
	
$this->infoArray['columns'] = $this->_getInteger(4);
	
	
	
$this->infoArray['colorDepth'] = $this->_getInteger(2);
	
	
	
$this->infoArray['colorMode'] = $this->_getInteger(2);


	
	
	
/* COLOR MODE DATA SECTION */ //4bytes Length The length of the following color data.
	
	
	
$this->infoArray['colorModeDataSectionLength'] = $this->_getInteger(4);
	
	
	
fseek($this->fp,$this->infoArray['colorModeDataSectionLength'],SEEK_CUR); // ignore this snizzle

	
	
	
/*  IMAGE RESOURCES */
	
	
	
$this->infoArray['imageResourcesSectionLength'] = $this->_getInteger(4);
	
	
	
fseek($this->fp,$this->infoArray['imageResourcesSectionLength'],SEEK_CUR); // ignore this snizzle

	
	
	
/*  LAYER AND MASK */
	
	
	
$this->infoArray['layerMaskDataSectionLength'] = $this->_getInteger(4);
	
	
	
fseek($this->fp,$this->infoArray['layerMaskDataSectionLength'],SEEK_CUR); // ignore this snizzle


	
	
	
/*  IMAGE DATA */
	
	
	
$this->infoArray['compressionType'] = $this->_getInteger(2);
	
	
	
$this->infoArray['oneColorChannelPixelBytes'] = $this->infoArray['colorDepth']/8;
	
	
	
$this->colorBytesLength $this->infoArray['rows']*$this->infoArray['columns']*$this->infoArray['oneColorChannelPixelBytes'];

	
	
	
if (
$this->infoArray['colorMode']==2) {
	
	
	
	
$this->infoArray['error'] = 'images with indexed colours are not supported yet';
	
	
	
	
return 
false;
	
	
	
}
	
	
} else {
	
	
	
$this->infoArray['error'] = 'invalid or unsupported psd';
	
	
	
return 
false;
	
	
}
	
}


	
function 
getImage() {
	
	
// decompress image data if required
	
	
switch(
$this->infoArray['compressionType']) {
	
	
	
// case 2:, case 3: zip not supported yet..
	
	
	
case 
1:
	
	
	
	
// packed bits
	
	
	
	
$this->infoArray['scanLinesByteCounts'] = array();
	
	
	
	
for (
$i=0$i<($this->infoArray['rows']*$this->infoArray['channels']); $i++) $this->infoArray['scanLinesByteCounts'][] = $this->_getInteger(2);
	
	
	
	
$this->tempFileName tempnam(realpath('/tmp'),'decompressedImageData');
	
	
	
	
$tfp fopen($this->tempFileName,'wb');
	
	
	
	
foreach (
$this->infoArray['scanLinesByteCounts'] as $scanLinesByteCount) {
	
	
	
	
	
fwrite($tfp,$this->_getPackedBitsDecoded(fread($this->fp,$scanLinesByteCount)));
	
	
	
	
}
	
	
	
	
fclose($tfp);
	
	
	
	
fclose($this->fp);
	
	
	
	
$this->fp fopen($this->tempFileName,'r');
	
	
	
default:
	
	
	
	
// continue with current file handle;
	
	
	
	
break;
	
	
}

	
	
// let's write pixel by pixel....
	
	
$image imagecreatetruecolor($this->infoArray['columns'],$this->infoArray['rows']);

	
	
for (
$rowPointer 0; ($rowPointer $this->infoArray['rows']); $rowPointer++) {
	
	
	
for (
$columnPointer 0; ($columnPointer $this->infoArray['columns']); $columnPointer++) {
	
	
	
	
/* 
	
The color mode of the file. Supported values are: Bitmap=0;
	
	
	
	
	
Grayscale=1; Indexed=2; RGB=3; CMYK=4; Multichannel=7;
	
	
	
	
	
Duotone=8; Lab=9.
	
	
	
	
*/
	
	
	
	
switch (
$this->infoArray['colorMode']) {
	
	
	
	
	
case 
2// indexed... info should be able to extract from color mode data section. not implemented yet, so is grayscale
	
	
	
	
	
	
exit;
	
	
	
	
	
	
break;
	
	
	
	
	
case 
0:
	
	
	
	
	
	
// bit by bit
	
	
	
	
	
	
if (
$columnPointer == 0$bitPointer 0;
	
	
	
	
	
	
if (
$bitPointer==0$currentByteBits str_pad(base_convert(bin2hex(fread($this->fp,1)), 162),8,'0',STR_PAD_LEFT);
	
	
	
	
	
	
$r $g $b = (($currentByteBits[$bitPointer]=='1')?0:255);
	
	
	
	
	
	
$bitPointer++;
	
	
	
	
	
	
if (
$bitPointer==8$bitPointer 0;
	
	
	
	
	
	
break;

	
	
	
	
	
case 
1:
	
	
	
	
	
case 
8// 8 is indexed with 1 color..., so grayscale
	
	
	
	
	
	
$r $g $b $this->_getInteger($this->infoArray['oneColorChannelPixelBytes']);
	
	
	
	
	
	
break;

	
	
	
	
	
case 
4// CMYK
	
	
	
	
	
	
$c $this->_getInteger($this->infoArray['oneColorChannelPixelBytes']);
	
	
	
	
	
	
$currentPointerPos ftell($this->fp);
	
	
	
	
	
	
fseek($this->fp,$this->colorBytesLength-1,SEEK_CUR);
	
	
	
	
	
	
$m $this->_getInteger($this->infoArray['oneColorChannelPixelBytes']);
	
	
	
	
	
	
fseek($this->fp,$this->colorBytesLength-1,SEEK_CUR);
	
	
	
	
	
	
$y $this->_getInteger($this->infoArray['oneColorChannelPixelBytes']);
	
	
	
	
	
	
fseek($this->fp,$this->colorBytesLength-1,SEEK_CUR);
	
	
	
	
	
	
$k $this->_getInteger($this->infoArray['oneColorChannelPixelBytes']);
	
	
	
	
	
	
fseek($this->fp,$currentPointerPos);
	
	
	
	
	
	
$r round(($c $k) / (pow(2,$this->infoArray['colorDepth'])-1));
	
	
	
	
	
	
$g round(($m $k) / (pow(2,$this->infoArray['colorDepth'])-1));
	
	
	
	
	
	
$b round(($y $k) / (pow(2,$this->infoArray['colorDepth'])-1));

  
	
	
	
	
	
	
break;

  
	
	
	
	
	
	
case 
9// hunter Lab
  
	
	
	
	
	
	
	
// i still need an understandable lab2rgb convert algorithm... if you have one, please let me know!
	
	
	
	
	
	
	
$l $this->_getInteger($this->infoArray['oneColorChannelPixelBytes']);
	
	
	
	
	
	
	
$currentPointerPos ftell($this->fp);
	
	
	
	
	
	
	
fseek($this->fp,$this->colorBytesLength-1,SEEK_CUR);
	
	
	
	
	
	
	
$a $this->_getInteger($this->infoArray['oneColorChannelPixelBytes']);
	
	
	
	
	
	
	
fseek($this->fp,$this->colorBytesLength-1,SEEK_CUR);
	
	
	
	
	
	
	
$b =  $this->_getInteger($this->infoArray['oneColorChannelPixelBytes']);
	
	
	
	
	
	
	
fseek($this->fp,$currentPointerPos);

	
	
	
	
	
	
	
$r $l;
	
	
	
	
	
	
	
$g $a;
	
	
	
	
	
	
	
$b $b;

	
	
	
	
	
	
break;
	
	
	
	
	
default:
	
	
	
	
	
	
$r $this->_getInteger($this->infoArray['oneColorChannelPixelBytes']);
	
	
	
	
	
	
$currentPointerPos ftell($this->fp);
	
	
	
	
	
	
fseek($this->fp,$this->colorBytesLength-1,SEEK_CUR);
	
	
	
	
	
	
$g $this->_getInteger($this->infoArray['oneColorChannelPixelBytes']);
	
	
	
	
	
	
fseek($this->fp,$this->colorBytesLength-1,SEEK_CUR);
	
	
	
	
	
	
$b =  $this->_getInteger($this->infoArray['oneColorChannelPixelBytes']);
	
	
	
	
	
	
fseek($this->fp,$currentPointerPos);
	
	
	
	
	
	
break;

	
	
	
	
}

	
	
	
	
if ((
$this->infoArray['oneColorChannelPixelBytes']==2)) {
	
	
	
	
	
$r $r >> 8;
	
	
	
	
	
$g $g >> 8;
	
	
	
	
	
$b $b >> 8;
	
	
	
	
} elseif ((
$this->infoArray['oneColorChannelPixelBytes']==4)) {
	
	
	
	
	
$r $r >> 24;
	
	
	
	
	
$g $g >> 24;
	
	
	
	
	
$b $b >> 24;
	
	
	
	
}

	
	
	
	
$pixelColor imagecolorallocate($image,$r,$g,$b);
	
	
	
	
imagesetpixel($image,$columnPointer,$rowPointer,$pixelColor);
	
	
	
}
	
	
}
	
	
fclose($this->fp);
	
	
if (isset(
$this->tempFileName)) unlink($this->tempFileName);
	
	
return 
$image;
	
}

	
/**
	
 *
	
 * PRIVATE FUNCTIONS
	
 *
	
 */

	
function 
_getPackedBitsDecoded($string) {
	
	
/*
	
	
The PackBits algorithm will precede a block of data with a one byte header n, where n is interpreted as follows:
	
	
n Meaning
	
	
0 to 127 Copy the next n + 1 symbols verbatim
	
	
-127 to -1 Repeat the next symbol 1 - n times
	
	
-128 Do nothing

	
	
Decoding:
	
	
Step 1. Read the block header (n).
	
	
Step 2. If the header is an EOF exit.
	
	
Step 3. If n is non-negative, copy the next n + 1 symbols to the output stream and go to step 1.
	
	
Step 4. If n is negative, write 1 - n copies of the next symbol to the output stream and go to step 1.

	
	
*/

	
	
$stringPointer 0;
	
	
$returnString '';

	
	
while (
1) {
	
	
	
if (isset(
$string[$stringPointer])) $headerByteValue $this->_unsignedToSigned(hexdec(bin2hex($string[$stringPointer])),1);
	
	
	
else return 
$returnString;
	
	
	
$stringPointer++;

	
	
	
if (
$headerByteValue >= 0) {
	
	
	
	
for (
$i=0$i <= $headerByteValue$i++) {
	
	
	
	
	
$returnString .= $string[$stringPointer];
	
	
	
	
	
$stringPointer++;
	
	
	
	
}
	
	
	
} else {
	
	
	
	
if (
$headerByteValue != -128) {
	
	
	
	
	
$copyByte $string[$stringPointer];
	
	
	
	
	
$stringPointer++;

	
	
	
	
	
for (
$i=0$i < (1-$headerByteValue); $i++) {
	
	
	
	
	
	
$returnString .= $copyByte;
	
	
	
	
	
}
	
	
	
	
}
	
	
	
}
	
	
}
	
}

	
function 
_unsignedToSigned($int,$byteSize=1) {
	
	
switch(
$byteSize) {
	
	
	
case 
1:
	
	
	
	
if (
$int<128) return $int;
	
	
	
	
else return -
256+$int;
	
	
	
	
break;

	
	
	
case 
2:
	
	
	
	
if (
$int<32768) return $int;
	
	
	
	
else return -
65536+$int;

	
	
	
case 
4:
	
	
	
	
if (
$int<2147483648) return $int;
	
	
	
	
else return -
4294967296+$int;

	
	
	
default:
	
	
	
	
return 
$int;
	
	
}
	
}

	
function 
_hexReverse($hex) {
	
	
$output '';
	
	
if (
strlen($hex)%2) return false;
	
	
for (
$pointer strlen($hex);$pointer>=0;$pointer-=2$output .= substr($hex,$pointer,2);
	
	
return 
$output;
	
}

	
function 
_getInteger($byteCount=1) {
	
	
switch (
$byteCount) {
	
	
	
case 
4:
	
	
	
	
// for some strange reason this is still broken...
	
	
	
	
return @
reset(unpack('N',fread($this->fp,4)));
	
	
	
	
break;

	
	
	
case 
2:
	
	
	
	
return @
reset(unpack('n',fread($this->fp,2)));
	
	
	
	
break;

	
	
	
default:
	
	
	
	
return 
hexdec($this->_hexReverse(bin2hex(fread($this->fp,$byteCount))));
	
	
}
	
}
}

/**
 * Returns an image identifier representing the image obtained from the given filename, using only GD, returns an empty string on failure
 *
 * @param string $fileName
 * @return image identifier
 */

function imagecreatefrompsd($fileName) {
	
$psdReader = new PhpPsdReader($fileName);
	
if (isset(
$psdReader->infoArray['error'])) return '';
	
else return 
$psdReader->getImage();
?>

template/.../media/psd.html
<?php
include_once('includes/psdtojpg.php')
header("Content-type: image/jpeg");
print 
imagejpeg(imagecreatefrompsd('{media_src}'));
?>

Funktioniert nicht.... hat da jemand eine Idee

72
Hallo zusammen,

ich arbeite derzeit an einem neuen Aussehen für das Control Panel.

UPDATE:
Complete Design refresh.


73
Discussion & Troubleshooting / Re: Double $$ / Doppelte $$ - Bug 4images ?
« on: September 14, 2013, 06:31:31 AM »
Achsooo.
Ok, vielen Dank für die Info.

74
Discussion & Troubleshooting / Double $$ / Doppelte $$ - Bug 4images ?
« on: September 14, 2013, 05:56:55 AM »
Hallo zusammen,

mir ist gerade aufgefallen in der Version 1.7.11
admin_functions.php
function show_num_select_row($title$option$desc "") {
  global 
$site_sess$PHP_SELF$action, $$option;
  echo 
"<tr class=\"".get_row_bg()."\">\n<td><p>".$title."</p></td>\n";
  echo 
"<td align=\"right\"><p>".$desc;
  
$url $PHP_SELF;
  
$url .= preg_match("/\?/"$url) ? "&amp;" "?";
  
$url .= "action=".$action;
  
$url $site_sess->url($url);
  echo 
"<select name=\"num\" onchange=\"window.location=('".$url."&";
  echo 
$option."='+this.options[this.selectedIndex].value)\">\n";
  for (
$i 1$i 11$i++) {
    echo 
"<option value=\"$i\"";
    if (
$i == ${$option}) {
      echo 
" selected";
    }
    echo 
">".$i."</option>\n";
  }
  echo 
"</select></p></td>\n</tr>\n";
}

Folgendes ist angegeben:
  global $site_sess$PHP_SELF$action, $$option;
$$option;
$$option;
Ist da nicht ein $ zu viel?

Das ist aus einer aktuellen "frischen" 4images Installation.
Es wurden noch keine Modifizierungen vorgenommen.
Sollte das so sein, sollte man die User offiziell darauf Aufmerksam machen.

75
4images Licence
Hallo zusammen, hiermit verkaufe ich meine Lizenz für 70 EUR.
EUR 70

4images Licence
Hello together, hereby, I sell my license for $92,97.
$ 92,79

PayPal, Überweisung/Bank transfer

Pages: 1 2 3 4 [5] 6 7 8 9 ... 116