আপনি কীভাবে মূল চিত্রগুলির সর্বাধিক প্রস্থ নির্ধারণ করতে পারেন?


11

কেস: আমার একটি ক্লায়েন্ট রয়েছে যা ডিজিটাল ওয়ার্ল্ড সম্পর্কে খুব বেশি জানেন না। তবে তিনি যা জানেন তা হ'ল কীভাবে তার ক্যামেরা থেকে কম্পিউটারে এবং ওয়ার্ডপ্রেসে ফটোটি পাবেন। তবে তিনি কীভাবে ফটোটির সাধারণ আকারকে ছোট করতে পারবেন তা জানেন না।

সমাধান: আমি ওয়ার্ডপ্রেসটি পছন্দ করি যে এই ফটোগুলির পটভূমিতে স্বয়ংক্রিয়ভাবে সর্বাধিক প্রস্থে 1024px আকারে ছোট করতে হবে।

সমস্যা: যদিও আমি সেটিংসে সর্বাধিক প্রস্থ নির্ধারণ করতে পারি, আমি $ সামগ্রী_উইথ সেট করতে পারি এবং আমি '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
আপনি যদি আমার উত্তরটিতে অন্য কোডের পাশাপাশি একটি ব্লগপোস্টে এটি ব্যবহার করেন তবে আপত্তি করবেন কি?
টম জে নোয়েল

আপনি যদি এটি দরকারী মনে করেন, আমি কিছু মনে করি না, আপনার ব্লগটি কী?
মার্ক

আমার সাইটের tomjn.com, আমি এখনও পোস্টটি লিখিনি, আমি পরের সপ্তাহে এটি করব এবং আমার হয়ে যাওয়ার পরে URL টি এখানে পোস্ট করব
টম জে নওয়েল

3

বৃহত্তর / মাঝারি / থাম্ব আকারগুলি তৈরি করতে ইতিমধ্যে আকার পরিবর্তন করা হয়েছে, তবে আপনার মুখর সমস্যাটি হ'ল মেমরি বা সময়ের অভাবের কারণে চিত্রটি আকার পরিবর্তন করতে খুব বড় is

সুতরাং আকার পরিবর্তন একটি বিকল্প নয়, যদি এটি না হয় তবে আপনার সমস্যাটি না থাকত। পরিবর্তে চিত্রগুলি সীমাবদ্ধ রাখার চেষ্টা করুন, সুতরাং যদি কোনও 20 এমবি আপলোড ঘটে, তবে এটি একটি আকারের বার্তা দিয়ে প্রত্যাখ্যান করা হবে যে এটির আকার ছোট করা দরকার।

চিত্রের ক্ষেত্র / মেগাপিক্সেলের উপর ভিত্তি করে সীমাবদ্ধ করা:

<?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');

প্রস্থ বা উচ্চতার ভিত্তিতে সীমাবদ্ধ করা:

/wordpress//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আমি উপরে তালিকাভুক্ত ফাইলগুলিতে এমনকি ফিল্টারটি ব্যবহার করে, কিছু পিএইচপি রাইজাইজিং কোডের পরিবর্তে ত্রুটি সংযোজন করার চেয়ে ট্রিকটি এতক্ষণ করতে পারে যে আপনি মূল ফাইলটিতে আবার লিখবেন। যদিও পরীক্ষার প্রয়োজন হবে
টম জে নওয়েল

আপনি সঠিক. সমস্ত যথাযথ আকার তৈরি হচ্ছে আমি সেটিংস পৃষ্ঠাতে যখন মাত্রাগুলি সেট করা থাকে তখন ওয়ার্ডপ্রেস কেন আসল রাখবে তা আমি ঠিক বুঝতে পারি না। অথবা হতে পারে "আসল রাখুন" দিয়ে একটি চেক-ইন বিকল্প তৈরি করুন যা আপনি অনির্বাচন করতে পারেন। কেবল আমার 2 সেন্ট ...
চিহ্নিত করুন

1
কারণ এটি ফাইলটিকে অন্য মাপের জন্য ব্যবহারের জন্য সংরক্ষণ করতে হবে এবং যদি কোনও পরিবর্তন হয় বা পুনর্জীবন হয়
টম জে নওয়েল
আমাদের সাইট ব্যবহার করে, আপনি স্বীকার করেছেন যে আপনি আমাদের কুকি নীতি এবং গোপনীয়তা নীতিটি পড়েছেন এবং বুঝতে পেরেছেন ।
Licensed under cc by-sa 3.0 with attribution required.