आप मूल चित्रों के लिए अधिकतम चौड़ाई कैसे निर्धारित कर सकते हैं?


11

केस: मेरे पास एक क्लाइंट है जो डिजिटल दुनिया के बारे में ज्यादा नहीं जानता है। हालाँकि वह क्या जानती है कि अपने कैमरे से फोटो को कंप्यूटर पर और वर्डप्रेस में कैसे लाया जाता है। हालाँकि वह नहीं जानती कि फोटो का आकार सामान्य कैसे हो सकता है।

समाधान: मुझे पसंद है कि वर्डप्रेस उन फ़ोटो को स्वचालित रूप से 1024px की अधिकतम चौड़ाई की पृष्ठभूमि में छोटा कर देता है।

समस्या: यद्यपि मैं सेटिंग्स में अधिकतम चौड़ाई सेट कर सकता हूं, मैं $ content_width सेट कर सकता हूं और मैं 'add_image_size' के साथ नई छवि आकार जोड़ सकता हूं। मूल फ़ोटो अभी भी मूल आकार में अपलोड-फ़ोल्डर में संग्रहीत है। मतलब हार्डडिस्क स्पेस आसानी से फुल हो जाएगा।

प्रश्न: वर्डप्रेस को ओरिजिनल इमेज को डाउन करने देने के लिए मुझे फंक्शन्स में क्या करना चाहिए (यदि यह बड़ा है तो अधिकतम चौड़ाई)?

जवाबों:


6

मैं निम्नलिखित कोड का उपयोग करके इसे हल करने में सक्षम था:

function my_handle_upload ( $params )
{
    $filePath = $params['file'];

    if ( (!is_wp_error($params)) && file_exists($filePath) && in_array($params['type'], array('image/png','image/gif','image/jpeg')))
    {
        $quality                        = 90;
        list($largeWidth, $largeHeight) = array( get_option( 'large_size_w' ), get_option( 'large_size_h' ) );
        list($oldWidth, $oldHeight)     = getimagesize( $filePath );
        list($newWidth, $newHeight)     = wp_constrain_dimensions( $oldWidth, $oldHeight, $largeWidth, $largeHeight );

        $resizeImageResult = image_resize( $filePath, $newWidth, $newHeight, false, null, null, $quality);

        unlink( $filePath );

        if ( !is_wp_error( $resizeImageResult ) )
        {
            $newFilePath = $resizeImageResult;
            rename( $newFilePath, $filePath );
        }
        else
        {
            $params = wp_handle_upload_error
            (
                $filePath,
                $resizeImageResult->get_error_message() 
            );
        }
    }

    return $params;
}
add_filter( 'wp_handle_upload', 'my_handle_upload' );

अपलोड होने के बाद मूल फ़ाइल 3,3Mb थी, जिसमें 2048x2048 के बड़े आयाम थे, इसने सर्वर पर केवल 375Kb लिया (लगभग 90% की कमी!)


1
क्या आप बुरा मानेंगे अगर मैंने अपने जवाब में दूसरे कोड के साथ एक ब्लॉगपोस्ट में इसका इस्तेमाल किया?
टॉम जम्मू नॉवेल

यदि आप इसे उपयोगी पाते हैं, तो मुझे कोई आपत्ति नहीं है, आपका ब्लॉग क्या है?
मार्क 10

मेरी साइट की tomjn.com, मैं पद अभी तक नहीं लिखा है, मैं अगले सप्ताह के दौरान ऐसा करने और यहां URL पोस्ट जब मेरा कार्य पूर्ण हो जाएगा
टॉम जम्मू नॉवेल

3

आकार बदलने का कार्य पहले से ही बड़े / मध्यम / अंगूठे के आकार बनाने के लिए किया जाता है, लेकिन आपके सामने समस्या यह है कि आकार बदलने के लिए छवि बहुत बड़ी है, या तो स्मृति या समय की कमी के कारण।

इसलिए आकार बदलना कोई विकल्प नहीं है, अगर ऐसा नहीं होता तो आपके पास अपना मुद्दा नहीं होता। इसके बजाय, छवियों को सीमित करने का प्रयास करें, इसलिए यदि 20MB अपलोड होता है, तो यह एक संदेश के साथ नकार दिया जाता है जो यह दर्शाता है कि इसे कम करने की आवश्यकता है।

छवि क्षेत्र / मेगापिक्सेल के आधार पर सीमा:

<?php
/**
 * Plugin Name: Deny Giant Image Uploads
 * Description: Prevents Uploads of images greater than 3.2MP
 */

function tomjn_deny_giant_images($file){
    $type = explode('/',$file['type']);

    if($type[0] == 'image'){
        list( $width, $height, $imagetype, $hwstring, $mime, $rgb_r_cmyk, $bit ) = getimagesize( $file['tmp_name'] );
        if($width * $height > 3200728){ // I added 100,000 as sometimes there are more rows/columns than visible pixels depending on the format
            $file['error'] = 'This image is too large, resize it prior to uploading, ideally below 3.2MP or 2048x1536';
        }
    }
    return $file;
}
add_filter('wp_handle_upload_prefilter','tomjn_deny_giant_images');

चौड़ाई या ऊंचाई के आधार पर सीमा:

https://wordpress.stackexchange.com/posts/67110/revisions

<?php
/** Plugin Name: (#67107) »kaiser« Restrict file upload */

function wpse67107_restrict_upload( $file )
{
    $file_data = getimagesize( $file );
    // Handle cases where we can't get any info:
    if ( ! $file_data )
        return $file;

    list( $width, $height, $type, $hwstring, $mime, $rgb_r_cmyk, $bit ) = $file_data;

    // Add conditions when to abort
    if ( $width > 2048 )
        $file['error'] = 'Error statement';

    return $file;
}
add_filter( 'wp_handle_upload_prefilter', 'wpse67107_restrict_upload' );

क्षेत्र द्वारा सीमित करने से लम्बी / पतली या चौड़ी / छोटी छवियों को आकार दिया जा सकता है, जिन्हें आयामों द्वारा सीमित करना समझाने में आसान हो सकता है


वैसे मैं जो सोच रहा हूं उसमें बहुत मेहनत कर रहा हूं और मैं चाहता हूं कि मूल छवि को उसी आकार में मिलेगा जैसा कि 'बड़े' छवि के आकार को निर्धारित किया गया है। ऐसा करने के लिए मुझे लगता है कि मुझे 'wp_handle_upload' से जांचना होगा कि आप क्या सोचते हैं?
मार्क

आह, तो आपके पास बड़े / मध्यम आकार हैं, आप सिर्फ मूल को इस्तेमाल होने से रोकना चाहते हैं? मुझे लगा कि आपका मतलब है कि वह बड़े पैमाने पर छवियां अपलोड कर रही थी और बड़े पैमाने पर संस्करण का हमेशा उपयोग किया जा रहा था और यह छोटे संस्करणों को उत्पन्न नहीं कर रहा था?
टॉम जम्मू नॉवेल

1
लेकिन वह हुक सही जगह के बारे में लगता है, या यहां तक ​​कि wp_handle_upload_prefilterजिन लोगों को मैंने ऊपर सूचीबद्ध किया था, उनमें उपयोग किए गए फ़िल्टर, कुछ PHP आकार कोड के बजाय एक त्रुटि के अलावा चाल को इतना लंबा कर सकता है जब तक आप मूल फ़ाइल पर वापस लिखते हैं। परीक्षण हालांकि इसकी आवश्यकता होगी
टॉम जम्मू नॉवेल

तुम सही हो। सभी उचित आकार उत्पन्न हो रहे हैं मुझे समझ में नहीं आ रहा है कि सेटिंग्स पेज में आयाम सेट किए जाने पर वर्डप्रेस मूल क्यों रखेगा। या शायद "कीप ओरिजिनल" के साथ एक चेक-इन विकल्प बनाएं जिसे आप ऑप्ट-आउट कर सकते हैं। बस मेरे 2 सेंट ...
मार्क

1
क्योंकि यह तो करने के लिए फ़ाइल को सहेजने के अन्य आकार के लिए इसका इस्तेमाल करने की जरूरत है, और अगर किसी भी संशोधन किया गया है या उत्थान कर रहे हैं यह आवश्यक है
टॉम जम्मू नॉवेल
हमारी साइट का प्रयोग करके, आप स्वीकार करते हैं कि आपने हमारी Cookie Policy और निजता नीति को पढ़ और समझा लिया है।
Licensed under cc by-sa 3.0 with attribution required.