Для получения полного доступа
зарегистрируйтесь.
RSS

Все сниппеты с тэгом «image»



dfatt
  • Репутация: 260
  • Сниппеты: 53
  • Ревизии: 7

Быстрый способ добавить цветовой оверлей на фоновое изображение

.block_business {
    background: linear-gradient(
            rgba(0, 0, 0, 0.7),
            rgba(0, 0, 0, 0.7)
    ),
    url('https://images.unsplash.com/photo-1524758631624-e2822e304c36');
}

Результат:

Gravatar image
blacksmoke26
  • Репутация: 13
  • Сниппеты: 11
  • Ревизии: 0
/**
 * Check that given file is an image file.
 * @param string $filename The file path to be checked
 * @return bool TRUE when image file | FALSE when none
 */
function isImageFile ( string $filename ) {
	if ( !is_file ( $filename) || !is_readable ( $filename) ) {
		return false;
	} else if ( class_exists('\finfo') ) {
		$mime = (new \finfo(FILEINFO_MIME))->file ( $filename);
		return strpos((string)$mime, 'image') !== false;
	} else if ( function_exists('getimagesize') ) {
		$size = @getimagesize ( $filename);
		return !@is_array($size) ? false : true;
	} else if ( function_exists('exif_imagetype') && exif_imagetype ( $filename) === false ) {
		return false;
	} else if ( function_exists('mime_content_type') ) {
		$mime = @mime_content_type ($filename);
		return strpos((string)$mime, 'image') !== false;
	} else {
		return true;
	}
}

/************
 * EXAMPLE
 ***********/
// Can validate all sort of images
var_dump ( isImageFile('image.jpg') );

/***********
 * OUTPUT
 **********/
# (bool) true
Gravatar image
blacksmoke26
  • Репутация: 13
  • Сниппеты: 11
  • Ревизии: 0
/**
 * Create image file from base64 image data
 * @param string $filename Path to the file where to write the data.
 * @param string $data The base64 image data
 * @return bool True when created | False anyway
 */
function imgBase64ToFile ( string $filename, string $data ) {
	list(, $data) = explode(';', $data);
	list(, $data) = explode(',', $data);
	$data = base64_decode($data);
	return file_put_contents($filename, $data) !== false;
}

/************
 * EXAMPLE
 ***********/
$base64Data = <<<BASE64

BASE64;

imgBase64ToFile('image.png', $base64Data);
FullZero
  • Репутация: 7
  • Сниппеты: 6
  • Ревизии: 0

Иногда при выгрузке товаров в json к товару может быть массив картинок,одна картинка или вообще небыть изображения используя функцию можно либо вернуть спец.картинку вместо отсутствующего изображения либо первую из массива

let obj,
arr= ['image1.jpg','image2.jpg'],
str ="image.jpg";

function is_array(a){
	return (typeof a ==='undefined')? 'noimage.jpg':((typeof a == "object") && (a instanceof Array)) ? a[0] : a;
}
console.log(is_array(obj))
console.log(is_array(arr));
console.log(is_array(str));
jestonedev
  • Репутация: 99
  • Сниппеты: 11
  • Ревизии: 1

Этим скриптом можно получить изображение из буфера обмена при нажатии ctrl+v на js. Работает только в хроме и мозиле. Может кто обращал внимание, в вк, в переписке есть возможность прикрепления картинки в диалог прямо из буфера, с этим скриптом вы можете реализовать то же самое.

// проверяем, поддерживает ли браузер объект Clipboard
// если нет создаем элемент с атрибутом contenteditable
if (!window.Clipboard) {
   var pasteCatcher = document.createElement("div");
    
   // Firefox вставляет все изображения в элементы с contenteditable
   pasteCatcher.setAttribute("contenteditable", "");
    
   pasteCatcher.style.position = "absolute";
   pasteCatcher.style.left = "-3000px";
   document.body.appendChild(pasteCatcher);
 
   // элемент должен быть в фокусе
   pasteCatcher.focus();
   document.addEventListener("click", function() { pasteCatcher.focus(); });
} 
// добавляем обработчик событию
window.addEventListener("paste", pasteHandler);
 
function pasteHandler(e) {
// если поддерживается event.clipboardData (Chrome)
      if (e.clipboardData && e.clipboardData.items) {
      // получаем все содержимое буфера
      var items = e.clipboardData.items;
      if (items) {
         // находим изображение
         for (var i = 0; i < items.length; i++) {
            if (items[i].type.indexOf("image") !== -1) {
               // представляем изображение в виде файла
               var blob = items[i].getAsFile();
               // создаем временный урл объекта
               var URLObj = window.URL || window.webkitURL;
               var source = URLObj.createObjectURL(blob);                
               // добавляем картинку в DOM
               createImage(source);
            }
         }
      }
   // для Firefox проверяем элемент с атрибутом contenteditable
   } else {      
      setTimeout(checkInput, 1);
   }
}
 
function checkInput() {
    var child = pasteCatcher.childNodes[0];   
   pasteCatcher.innerHTML = "";    
   if (child) {
// если пользователь вставил изображение – создаем изображение
      if (child.tagName === "IMG") {
         createImage(child.src);
      }
   }
}
 
function createImage(source) {
   var pastedImage = new Image();
   pastedImage.onload = function() {
      // теперь у нас есть изображение из буфера
   }
   pastedImage.src = source;
}

Valentin Sayik
  • Репутация: 37
  • Сниппеты: 5
  • Ревизии: 0

Этим скриптом можно получить изображение из буфера обмена при нажатии ctrl+v на js. Работает только в хроме и мозиле. Может кто обращал внимание, в вк, в переписке есть возможность прикрепления картинки в диалог прямо из буфера, с этим скриптом вы можете реализовать то же самое.

// проверяем, поддерживает ли браузер объект Clipboard
// если нет создаем элемент с атрибутом contenteditable
if (!window.Clipboard) {
   var pasteCatcher = document.createElement("div");
    
   // Firefox вставляет все изображения в элементы с contenteditable
   pasteCatcher.setAttribute("contenteditable", "");
    
   pasteCatcher.style.display = "none";
   document.body.appendChild(pasteCatcher);
 
   // элемент должен быть в фокусе
   pasteCatcher.focus();
   document.addEventListener("click", function() { pasteCatcher.focus(); });
} 
// добавляем обработчик событию
window.addEventListener("paste", pasteHandler);
 
function pasteHandler(e) {
// если поддерживается event.clipboardData (Chrome)
      if (e.clipboardData) {
      // получаем все содержимое буфера
      var items = e.clipboardData.items;
      if (items) {
         // находим изображение
         for (var i = 0; i < items.length; i++) {
            if (items[i].type.indexOf("image") !== -1) {
               // представляем изображение в виде файла
               var blob = items[i].getAsFile();
               // создаем временный урл объекта
               var URLObj = window.URL || window.webkitURL;
               var source = URLObj.createObjectURL(blob);                
               // добавляем картинку в DOM
               createImage(source);
            }
         }
      }
   // для Firefox проверяем элемент с атрибутом contenteditable
   } else {      
      setTimeout(checkInput, 1);
   }
}
 
function checkInput() {
    var child = pasteCatcher.childNodes[0];   
   pasteCatcher.innerHTML = "";    
   if (child) {
// если пользователь вставил изображение – создаем изображение
      if (child.tagName === "IMG") {
         createImage(child.src);
      }
   }
}
 
function createImage(source) {
   var pastedImage = new Image();
   pastedImage.onload = function() {
      // теперь у нас есть изображение из буфера
   }
   pastedImage.src = source;
}