का उपयोग कर रहा कैनवास पर कुछ चित्र और पाठ के साथ एक डिजाइन (270x470) बनाया FabricJs का उपयोग कर तो मैं fabricJS के canvas.toJSON द्वारा JSON प्रारूप में सभी चित्रों/पाठ जानकारी निर्यात() विधि और अब मैं एक उच्च गुणवत्ता PHP में (2790x4560) छवि Imagick के प्रयोग पर है कि डिजाइन फिर से ड्रा की जरूरत है।डाटा की JSON/सरणी (चौड़ाई, ऊंचाई, एक्स, वाई, स्वर्गदूतों) से एक बड़ी (300dpi उच्च गुणवत्ता) छवि बनाने के लिए कैसे पीएचपी ImageMagic/Imagick
JSON ऊपर डिजाइन के लिए पैदा PHP में उच्च गुणवत्ता छवि के लिए dataArray जो आकार, स्थिति, कोण आदि जैसे सभी वस्तु की जानकारी शामिल है ..
{
"width": "2790",
"height": "4560",
"json_data": {
"objects": [{
"type": "image",
"originX": "left",
"originY": "top",
"left": "5",
"top": "105",
"width": "260",
"height": "260",
"scaleX": "1",
"scaleY": "1",
"angle": "0",
"opacity": "1",
"src": "http:\\example.com/images/098f20be9fb7b66d00cb573acc771e99.JPG",
}, {
"type": "image",
"originX": "left",
"originY": "top",
"left": "5",
"top": "229.5",
"width": "260",
"height": "11",
"scaleX": "1",
"scaleY": "1",
"angle": "0",
"opacity": "1",
"src": "http:\\example.com/images/aeced466089d875a7c0dc2467d179e58.png",
}, {
"type": "image",
"originX": "left",
"originY": "top",
"left": "51.07",
"top": "135.58",
"width": "260",
"height": "11",
"scaleX": "1",
"scaleY": "1",
"angle": "47.41",
"opacity": "1",
"src": "http:\\example.com/images/910ce024d984b6419d708354bf3641a3.png",
}, {
"type": "image",
"originX": "left",
"originY": "top",
"left": "139.71",
"top": "104.97",
"width": "260",
"height": "11",
"scaleX": "1",
"scaleY": "1",
"angle": "89.65",
"opacity": "1",
"src": "http:\\example.com/images/88e096a82e5f8a503a71233addaff64c.png",
}, {
"type": "image",
"originX": "left",
"originY": "top",
"left": "230.78",
"top": "146.93",
"width": "260",
"height": "11",
"scaleX": "1",
"scaleY": "1",
"angle": "134.98",
"src": "http:\\example.com/images/d2c0ec738c1fec827381cfeb600bd87d.png",
}, {
"type": "image",
"originX": "left",
"originY": "top",
"left": "265.01",
"top": "240.19",
"width": "260",
"height": "11",
"scaleX": "1",
"scaleY": "1",
"angle": "179.86",
"opacity": "1",
"src": "http:\\example.com/images/3f0bc771261860d917e0ad6d09cb2064.png",
}],
"background": "#FF00FF"
}}
और यहाँ मेरी कोड स्निपेट JSON डेटा का उपयोग करके
error_reporting(E_ALL | E_STRICT);
try {
$id = $_GET['id']; // Design ID
define('DS', DIRECTORY_SEPARATOR);
$jsonDir = dirname(__FILE__) . DS . 'media' . DS . 'designs';
$printData = json_decode(file_get_contents($jsonDir . DS . $id . '.json'));
} catch (Exception $e) {
echo $e->getMessage();
}
try {
$print = new Imagick();
$print->setResolution(300, 300);
$background = (empty($printData->json_data->background)) ? 'transparent' : $printData->json_data->background;
$print->newImage($printData->width, $printData->height, new ImagickPixel($background));
$print->setImageFormat('png32');
$print->setImageUnits(imagick::RESOLUTION_PIXELSPERCENTIMETER);
} catch (Exception $e) {
echo $e->getMessage();
}
// Re-Scaling each Image/Text for Larger Canvas/Image
foreach ($printData->json_data->objects as $i => $object) {
if ($object->type == 'image') {
addImage($object, $print, $printData);
} else {
addText($object, $print, $printData);
}
}
try {
// Saving High Quality Image in (300 dpi)
$fileDir = dirname(__FILE__) . DS . 'media' . DS . 'prints';
if (!file_exists($fileDir) || !is_dir($fileDir)) {
if (!mkdir($fileDir))
die("Could not create directory: {$fileDir}\n");
}
$saved = $print->writeimage($fileDir . DS . $id . '.png');
header('Content-type: image/png');
echo $print;
} catch (Exception $e) {
echo $e->getMessage();
}
addImage();
function addImage($object, $print, $printData) {
try {
$widthScale = ($printData->width/270);
$heightScale = ($printData->height/470);
$fileDir = dirname(__FILE__) . DS . 'media' . DS . 'original' . DS;
$src = new Imagick($fileDir . basename($object->src));
$size = $src->getImageGeometry();
$resizeWidth = ($object->width * $object->scaleX) * $widthScale;
$resizeHeight = ($object->height * $object->scaleY) * $heightScale;
$src->resizeImage($resizeWidth, $resizeHeight, Imagick::FILTER_LANCZOS, 1);
$sizeAfterResize = $src->getImageGeometry();
$src->rotateImage(new ImagickPixel('none'), $object->angle);
$sizeAfterRotate = $src->getImageGeometry();
if (!$object->angle) {
$left = $object->left * $widthScale;
$top = $object->top * $heightScale;
} else {
switch ($object->angle) {
case $object->angle > 315:
$left = ($object->left * $widthScale);
$top = ($object->top * $heightScale);
break;
case $object->angle > 270:
$left = ($object->left * $widthScale);
$top = ($object->top * $heightScale);
break;
case $object->angle > 225:
$left = ($object->left * $widthScale);
$top = ($object->top * $heightScale);
break;
case $object->angle > 180:
$left = ($object->left * $widthScale);
$top = ($object->top * $heightScale);
break;
case $object->angle > 135:
$left = ($object->left * $widthScale);
$top = ($object->top * $heightScale);
break;
case $object->angle > 90:
$left = ($object->left * $heightScale) - ($sizeAfterRotate['width']/2);
$top = ($object->top * $heightScale) - ($sizeAfterRotate['width']/2);
break;
case $object->angle > 45:
$left = ($object->left * $widthScale) - $size['height'] * $widthScale;
$top = ($object->top * $heightScale) - $size['height'] * $heightScale;
break;
default:
$left = $object->left * $widthScale;
$top = $object->top * $heightScale;
break;
}
}
$print->compositeImage($src, Imagick::COMPOSITE_DEFAULT, $left, $top);
} catch (Exception $e) {
echo $e->getMessage();
}
}
मेरे आउटपुट परिणाम (90%) ऊपर समाधान के साथ वहाँ है, लेकिन जैसा कि हम कुछ छवि देख सकते हैं (नीला नंबर लाइन) सही स्थिति जो पहली डिजाइन छवि की तरह दिखना चाहिए पर जगह नहीं है
असल में मुझे क्या करना कोशिश कर रहा हूँ है, "एक लूप पैमाने के लिए एक addImage विधि बुला अंदर - बारी बारी - मुद्रण छवि पर प्रत्येक छवि की स्थिति (300dpi)
01,235,मुझे यकीन है कि मैं क्या सटीक (नई एक्स, वाई निर्देशांक/स्थिति/वाम टॉप) Imagick में एक छवि या मैं स्केल के बाद वस्तु घूर्णन कर रहा हूँ के लिए ऑफसेट करने के लिए रोटेशन के बाद तो
रचनाया याद आ रही है नहीं कर रहा हूँ Math.PI की तरह एक गणित फार्मूला :) हो सकता है
प्रश्न है: मैं कैसे की गणना कर सकते नई रोटेशन डिग्री/कोण के अनुसार स्केल के बाद ऑफसेट/स्थिति?
मुझे आशा है कि पोस्ट स्निपेट सभी के लिए उपयोगी होगा।
दिया जवाब से दूर सवाल का संपादन के लिए दूसरों की मदद करेगा पर सबसे अच्छा असभ्य, है। लगातार एक ही प्रश्न पर एक बक्षीस की पेशकश करना आपका खुद का व्यवसाय है, मुझे लगता है (या शायद नहीं)। आपके पास 4 कोड डंप और 2 छवियां हैं, लेकिन हम जो कुछ भी देख रहे हैं उसे समझाते हुए बहुत कम है। आप 4 प्रश्न पूछते हैं। (1) एक बार जब आप स्पष्टीकरण देते हैं तो आप विषय पर होंगे ताकि हम इसे समझ सकें। (2) शायद विषय पर होगा। (3) विषय पर नहीं। (4) विषय पर नहीं। – Teepeemm
धन्यवाद आदमी, अब मेरा प्रश्न स्पष्ट है .. ऑफ़सेट " – AZinkey
" इस डिज़ाइन के लिए "क्या यह आपने शुरू किया है? और साथ समाप्त होना चाहते हैं? मुझे लगता है कि" रोटेशन डिग्री/कोण "संख्याओं की रेखा का कोण है ऑफसेट क्या है? विशेष रूप से, कहां से ऑफसेट करें? 'ऑफसेट' आपके कोड में दिखाई नहीं देता है, तो आप इसके साथ क्या करना चाहते हैं? केवल एक चीज जो मुझे स्पष्ट है वह यह है कि आपकी तस्वीरें अलग हैं। – Teepeemm