Me gustaría saber si hay una manera simple (código personalizado o complemento) para crear tamaños de miniatura solo para las imágenes que pretendo usar como imágenes destacadas (index.php, archive.php, etc.), pero no para las imágenes utilizado en las publicaciones (single.php). Mi objetivo principal es reducir el uso del espacio del servidor al no crear miniaturas que mi tema nunca usará.
Mis miniaturas solo tendrían dos tamaños, 720px de ancho y 328px de ancho, y las imágenes destacadas de 720px de ancho (solo en la página de inicio) también tendrían una de 328px de ancho (para archive.php y sidebar.php)
Actualmente, la única forma programática que conozco es generar miniaturas para cada carga de imágenes , lo cual no es deseable, ya que la mayoría de mis cargas serán imágenes publicadas y tendría que eliminar muchas imágenes del servidor manualmente.
Preferiría código personalizado sobre complementos, pero un complemento sería aceptable. Sé que hay algunos complementos de cambio de tamaño de imagen, pero no se han actualizado en mucho tiempo (TimThumb, Dynamic Image Resizer ).
También he encontrado una pregunta similar aquí en Wordpress SE, pero la respuesta aceptada realmente no resuelve mi problema.
EDITAR: necesito eliminar o evitar miniaturas para las imágenes dentro de la publicación, no para las imágenes destacadas, es decir:
(1) Imagen destacada : las miniaturas adicionales generadas automáticamente por WP están bien.
(2) Imágenes utilizadas dentro de las publicaciones : cargue la imagen original y no genere ningún tamaño adicional. Recortaré, redimensionaré y optimizaré la imagen antes de subirla y un tamaño se ajustará a mis necesidades.
fuente
_thumbnail_id
-, que debería ser suficiente en realidad,save_post
y ganchos similares podrían ser un camino a seguir. Pero no olvide que esas imágenes en su publicación podrían usarse en otras publicaciones como miniaturas, es posible que desee tener un mecanismo para dar cuenta de eso.add_filter('intermediate_image_sizes_advanced', '__return_false')
y luegoRespuestas:
Esta función generará una imagen al registrar temporalmente un tamaño de imagen, generar la imagen (si es necesario) y eliminar el tamaño para que no se creen nuevas imágenes en ese tamaño.
Es "vago" porque las imágenes no se generan hasta que se necesitan.
En su caso de uso, lo llamaría
lazy_image_size
con la ID de miniatura de la publicación para obtener una imagen del tamaño deseado. Se generaría una imagen en la primera llamada. Las llamadas posteriores buscarían la imagen existente.Gist: https://gist.github.com/mtinsley/be503d90724be73cdda4
fuente
Puedes ver este enlace . hay algún ejemplo como
fuente
1.Vaya al Tablero> Configuración> Medios
2. Desmarque Recortar miniatura a dimensiones exactas (normalmente las miniaturas son proporcionales) 3. Ingrese
0 para todas las entradas (0 para todos los tamaños)
4. Agregue estos a sus funciones.php
5. Asegúrese de que no haya una línea de código en sus funciones.php comience con
add_imge_size
Nota: Supongo que usa un tamaño de 400x400 para su miniatura. Ahora, cuando cargue una foto, creará solo 2 versiones en lugar de al menos 4 versiones de fotos. como previamente.fuente
Hola, tuve un problema similar. Woocommerce utiliza imágenes de catálogo para imágenes de catálogo y productos relacionados. Eso no es lo ideal, ya que pierde calidad de imagen o velocidad. Así que intenté agregar una cuarta categoría de imagen para mis productos relacionados. Howdy McGee ha resuelto el problema. Por favor, eche un vistazo a la respuesta de Howdy McGees:
Ha funcionado magníficamente para mis necesidades. Para su problema, podría aplicarse la misma lógica. Espero que esto ayude. saludos - theo
Encontré una solución que funciona. 1.paso: asigna un nuevo tamaño de miniatura en tus functions.php. Consultar referencia: wp codex !
Nota: 'su pulgar', usará este nombre de variable más tarde
paso: a continuación, agregue el siguiente código donde desee mostrar sus productos destacados:
Referencia e información: no hay suficiente reputación para un tercer enlace, lo siento (www.haloseeker.com/display-woocommerce-featured-products-without-a-shortcode/) Lo coloqué en el index.php (mi página de inicio) de wootheme mystile . No olvide usar 'su pulgar' en línea:
paso: regenerar miniaturas, use el complemento https://wordpress.org/plugins/regenerate-thumbnails/
actualizar el navegador e inspeccionar el dom y comparar los valores
Según su tema, puede cambiar el marcado y los nombres de clase. Testifico el método anterior y funciona bien. Lo único que no pude hacer hasta ahora es agregar el botón agregar al carrito, ya que no sé cómo escribir una variable en el código abreviado del botón agregar al carrito. Este es el código:
Espero que esto ayude. Ciertamente hay una forma más elegante de hacer esto. Por ejemplo con una función en functions.php
saludos theo
fuente
Para evitar que WordPress haga los tamaños adicionales solo para ciertas imágenes, debe tener una manera de indicar que una imagen que ESTÁ A punto de cargar se usará solo para un propósito particular. Esto debe suceder ANTES de que lo haya subido.
dado que no existe dicha interfaz (lista para usar) para indicar tales opciones durante una acción de carga, no puede evitar la generación de imágenes adicionales, a menos que haya un complemento que agregue esta función.
pero ¿por qué no querrías los tamaños de imagen adicionales? nunca se sabe cuándo puede encontrarse con una situación en la que desea utilizar un tamaño diferente de cualquier imagen. ¿le preocupa el espacio de almacenamiento?
¿no puedes usar tus propias especificaciones de tamaño específico como esta?
the_post_thumbnail( array(100, 100) );
La mayoría de las respuestas y comentarios que he leído aquí explican cómo personalizar el entorno de WordPress para tamaños de imagen, pero ninguno menciona hacerlo condicionalmente. Además, ninguno de ellos aborda el hecho de que debe ser capaz de indicar el uso de una imagen antes de cargarla.
Si está tratando de compensar una imagen demasiado pequeña o demasiado grande en una publicación, puede utilizar algunas cosas.
CSS: puede agregar entradas a su hoja de estilo, por ejemplo
.post-entry img { max-width:200px; max-height:300px; }
, esto es más universal y efectivo que depender del tamaño de la imagen en sí, eso es MUCHO tiempo de photoshop.Plantilla: puede modificar el archivo de plantilla donde se genera la salida HTML de publicaciones y especificar un tamaño de imagen como este:
vea esta documentación en WordPress: https://codex.wordpress.org/Function_Reference/the_post_thumbnail
fuente