رفتن به مطلب

جلو گیری از دفورمه شدن تصویر در وردپرس


پست های پیشنهاد شده

سلام دوستان و اساتید محترم خسته نباشید من یه سوال دارم که میدونم سوال خیلی هاست چطور باید از دفورمه شدن تصویر شاخص جلوگیری کنیم؟ منظورم اینکه مثلا شما یک تصویر 900 در 400 رو برای تصویر شاخصتون بزارید اگر تصویر شاخصتون 400 در 400 باشه معمولا تصویر دفورمه میشه و کلا ماهیت و زیبایی کل سیستمتون رو تحت تاثیر قرار میده حالا آگه رسپانسیو هم باشه که دیگه بدتر میشه به دلیل اینکه معمولا width: 100%; height: auto; و سایز از فانکشن تنظیم میشه کلا همچیزو بهم میریزه ولی من دیدم بعضی از دوستان از کد خواصی استفاده میکنند که تصویرو جای اینکه دفورمه کنه کات میکنه که این عالیه و میدونم که از این کدها

     add_image_size('cs_media_1', 980, 418, true);
     add_image_size('cs_media_2', 980, 228, true);
     add_image_size('cs_media_3', 580, 580, true);
     add_image_size('cs_media_4', 438, 288, true);
     add_image_size('cs_media_5', 208, 208, true);
     add_image_size('cs_media_6', 120, 95, true);
     add_image_size('cs_media_7', 62, 58, true);

استفاده میشه اما نمیدونم چطور از اینها استفاده میکنن اگر دوستان نظری دارن لطفا بگن هم مشکل من هست هم مشکل خیلی ها که میری تو سایتشون مشهوده این جریان
سپاس

لینک به ارسال

بحث دفرمه شدن تصویر بستکی به کدهای استایل و قالب شما هم داره

در نسخه جدید وردپرس قابلیتی درونی برای ایجاد تصاویر ریسپانسیو وجود داره:

https://make.wordpress.org/core/2015/11/10/responsive-images-in-wordpress-4-4/

https://www.smashingmagazine.com/2015/12/responsive-images-in-wordpress-core/

لینک به ارسال

بله کاملا درسته اینکه دفورمه شدن به قالب بستگی داره اما در بهث استایل مشکلی ندرام مشکل کدهای php هست قابلیت VW مشکلش اینکه تو همه پلتفرمها جواب نمیده کلا جا نیفتاده، من یک سری قالب آماده نال شده حرفه ای دانلود کردم برای تست و دیدم درون اونهامثلا شما یه تصویر رو در سایز 960 در 400 برای تصویر شاخص انتخاب میکنید اگر مثلا نمایه که نیاز دارید 400 در 400 باشه بصورت اوتوماتیک تصویر رو تبدیل میکنه بدون دفرمه شدن به 400 در 400 یعنی از هر طرف crop میکنه نه اینکه بخواد بکشه یا جمع کنه! ولی من نتونستم شیوه کار این قالب هار در بیارم هرچند چیزهایی دستگیرم شد اما یک شیو درست نیست متاسفانه شما راهای دیگیری میدونید که بشه چنین کاری کرد یعنی نیازی نباشه هی ریسایز کنید تصویر رو فقط آپلود بشه تصویر و بصورت خودکار تنظیم بشه مثلا در سایز خواصی؟!!؟؟!

لینک به ارسال

ببینید اساس کار وردپرس برش عکس در سایزهای مختلف بصورت آنتایم نیست.

یعنی ودپرس بر اساس همون سایزهایی که در فانکشن تعریف می کنید میاد برشها رو انجام و فایل فیزیکی رو میسازه.

اساس کار اون قالبهایی که شما میگید این هست که میان اول اندازه عکسهاشون رو براساس ریسایز قالبهاشون در رزولیشین های مختلف مشخص میکنن و بعد درفانکشن تعریف میکنن.

بعد طبق همون با استایل عکس رو فیت میکنن(نه فیکس فقط فیت میکنن)

هم اینکه میتونید با کمک کراپرهای آنتایم مثل timthumb این عملیات ریسایز و برش آنتیام رو انجام بدید. ولی وردپرس خودش راهکاری نداره.

لینک به ارسال
در هم اکنون، Morteza گفته است :

ببینید اساس کار وردپرس برش عکس در سایزهای مختلف بصورت آنتایم نیست.

یعنی ودپرس بر اساس همون سایزهایی که در فانکشن تعریف می کنید میاد برشها رو انجام و فایل فیزیکی رو میسازه.

اساس کار اون قالبهایی که شما میگید این هست که میان اول اندازه عکسهاشون رو براساس ریسایز قالبهاشون در رزولیشین های مختلف مشخص میکنن و بعد درفانکشن تعریف میکنن.

بعد طبق همون با استایل عکس رو فیت میکنن(نه فیکس فقط فیت میکنن)

هم اینکه میتونید با کمک کراپرهای آنتایم مثل timthumb این عملیات ریسایز و برش آنتیام رو انجام بدید. ولی وردپرس خودش راهکاری نداره.

ممنون از پاسختون، برای اینکار هک خاصی وجود نداره؟!

لینک به ارسال

با سلام

شما بعد از اینکه سایز هارو داخل فانکشن تعریف کردید باید داخل لوپ پست که درست میکنید برای فراخوانی عکس با اون سایزی که درست کردید از کد زیر استفاده کنید.

<?php if ( has_post_thumbnail() ) {
the_post_thumbnail('first-thumb', array( 'alt' => ''.get_the_title(), 'title' => ''.get_the_title().'' ));
} else { ?>
<img src="<?php bloginfo('template_url');?>/image/ronakweb.png" width="150" height="150" alt="<?php the_title(); ?>" title="<?php the_title(); ?>">
<?php } ?>

بعد از اضافه کردن این کد به جای first-thumb باید اسم اون سایزی که داخل فانکشن درست کردید رو بدید ، مثلاً الان شما با توجه به اون کد بالا که در فایل فانکشن دادید میخواید با این کد عکس در سایز که درست کردید 980 در 418 رو نمایش بدید باید بجای first-thumb از cs_media_1 استفاده کنید.

اون قسمت else هم میتونید برای بهتر شدن کار که اگر عکسی فراموش کردید بارگذاری کنید یه عکس ثابت درست کنید که اونرو نمایش بده سایزش هم از 150 به سایز دلخواه تغییر بدید.

مطالعه کنید آموزش همین روش که میخواید هستش .

https://developer.wordpress.org/reference/functions/add_image_size/

http://wpshout.com/adding-using-custom-image-sizes-wordpress-guide-best-thing-ever/

http://www.wpbeginner.com/wp-tutorials/how-to-create-additional-image-sizes-in-wordpress/

http://havecamerawilltravel.com/photographer/wordpress-thumbnail-crop

ویرایش شده توسط وردپرس فارسی
لینک به ارسال
در هم اکنون، وردپرس فارسی گفته است :

با سلام

شما بعد از اینکه سایز هارو داخل فانکشن تعریف کردید باید داخل لوپ پست که درست میکنید برای فراخوانی عکس با اون سایزی که درست کردید از کد زیر استفاده کنید.


<?php if ( has_post_thumbnail() ) {
the_post_thumbnail('first-thumb', array( 'alt' => ''.get_the_title(), 'title' => ''.get_the_title().'' ));
} else { ?>
<img src="<?php bloginfo('template_url');?>/image/ronakweb.png" width="150" height="150" alt="<?php the_title(); ?>" title="<?php the_title(); ?>">
<?php } ?>

بعد از اضافه کردن این کد به جای first-thumb باید اسم اون سایزی که داخل فانکشن درست کردید رو بدید ، مثلاً الان شما با توجه به اون کد بالا که در فایل فانکشن دادید میخواید با این کد عکس در سایز که درست کردید 980 در 418 رو نمایش بدید باید بجای first-thumb از cs_media_1 استفاده کنید.

اون قسمت else هم میتونید برای بهتر شدن کار که اگر عکسی فراموش کردید بارگذاری کنید یه عکس ثابت درست کنید که اونرو نمایش بده سایزش هم از 150 به سایز دلخواه تغییر بدید.

مطالعه کنید آموزش همین روش که میخواید هستش .

https://developer.wordpress.org/reference/functions/add_image_size/

http://wpshout.com/adding-using-custom-image-sizes-wordpress-guide-best-thing-ever/

http://www.wpbeginner.com/wp-tutorials/how-to-create-additional-image-sizes-in-wordpress/

http://havecamerawilltravel.com/photographer/wordpress-thumbnail-crop

ممنون دقیقا دنبال همین بودم مشکل حل شد عالی بود :D

لینک به ارسال

به گفتگو بپیوندید

هم اکنون می توانید مطلب خود را ارسال نمایید و بعداً ثبت نام کنید. اگر حساب کاربری دارید، برای ارسال با حساب کاربری خود اکنون وارد شوید .

مهمان
ارسال پاسخ به این موضوع ...

×   شما در حال چسباندن محتوایی با قالب بندی هستید.   حذف قالب بندی

  تنها استفاده از 75 اموجی مجاز می باشد.

×   لینک شما به صورت اتوماتیک جای گذاری شد.   نمایش به صورت لینک

×   محتوای قبلی شما بازگردانی شد.   پاک کردن محتوای ویرایشگر

×   شما مستقیما نمی توانید تصویر خود را قرار دهید. یا آن را اینجا بارگذاری کنید یا از یک URL قرار دهید.

×
×
  • اضافه کردن...