


Script JS pour ajouter automatiquement des bordures et des informations EXIF aux images dans les compétences PhotoShop_javascript
En tant que "passionné de photographie" (ok, j'avoue que je ne suis pas très qualifié, je ne fais de la photo que depuis quelques jours -_- !!) il y a toujours une chose qui ne peut être évitée, c'est de avoir des paramètres EXIF dans les photos. Bien que mon blog ait installé un plug-in capable d'afficher des informations EXIF , j'estime que le plug-in n'est toujours pas très puissant. De plus, certaines opérations complètes doivent être envisagées, comme. comme le redimensionnement par lots, l'ajout d'informations sur les droits d'auteur, etc.
Bien sûr, heureusement, nous avons toujours besoin de PS, et nous pouvons également écrire des scripts PS pour lui permettre d'effectuer certaines opérations selon nos idées :) Hé, j'ai trouvé un script PS dans un post sur le forum Wuji et je l'ai suivi. moi-même L'idée est légèrement modifiée (principalement le temps, l'identification de l'objectif et l'identification de la distance focale) et les rendus sont présentés dans l'image de titre. Il est bien plus pratique d'avoir un script. Par exemple, si vous souhaitez ajouter des bordures EXIF par lots, c'est très simple. Enregistrez simplement une action puis exécutez l'action par lots :)
.Enfin, joignez ce script :
displayDialogs = DialogModes.NO; var defaultRulerUnits = preferences.rulerUnits; preferences.rulerUnits = Units.PIXELS; //将一个长字串分解成单个字符串 function explodeArray(item) { var i=0; var Count=0; var tempString=new String(item); tempArray=new Array(1); do{ i=tempString.indexOf(":"); if(i>0) tempString=tempString.substr(i+1,tempString.length-i-1); i=tempString.indexOf(">"); if(i>0) { tempArray[Count]=tempString.substr(0,i); tempString=tempString.substr(i+1,tempString.length-i-1); Count ++; } i=tempString.indexOf("<"); if(i>0) { tempArray[Count]=tempString.substr(0,i); tempString=tempString.substr(i-1,tempString.length-i+1); Count ++; } }while (tempString.indexOf("</x:xmpmeta>")>0); tempArray[Count]=tempString; return tempArray; } var i=0; var j=0; var k=0; var pResulotion=72; var AD=""; var resRatio=""; var imageRatio=""; var dateArray1=""; var dateArray2=""; var monthsArray=""; var exposureProgramArray=""; var phoDate=""; var phoTime=""; var photoWidth=""; var photoHight=""; var exifData=""; var black=""; var white=""; var grey=""; var fWidth=""; var fHight=""; var tSize=""; var tLeft=""; var tHight=""; var infoLayer=""; var TI=""; nameLayer=""; var TN=""; var stringTemp=""; //临时字串 var make=""; //相机公司 var model=""; //相机型号 var camera=""; //相机 var lens=""; //镜头类型 var lensUsed=""; //使用的镜头 var focalLength=""; //焦距 var exposureTime=""; //快门 var fNumber=""; //光圈 var ISOSpeedRatings=""; //ISO设置 var dateTimeOriginal=""; //拍摄时间 var exposureBiasValue=""; //曝光补偿 var exposureProgram=""; //曝光程序模式 var fired=""; //闪光模式 //改成你自己想写的,比如版权所有和你自己的网名等 //如果为空,将采用相机设置的名字 var creator="Photo By Kaisir"; //拍摄者 AD = activeDocument; //Aglin 编制了自动改变图象大小为网上交流大小的代码, //稍加修改,如果宽窄任一边大于1000,就自动剪裁 //这里最长边为750,最短边为500 //请根据自己相机拍出来的图像比例设置长宽比 //如果不用可以去掉 //-------------------------------------------- var resizeMax=1024; var resizeMin=678; if(AD.width.value > 1500 || AD.height.value > 1500) { imageRatio = AD.width.value/AD.height.value; if(imageRatio>1) AD.resizeImage(resizeMax,resizeMin,pResulotion,ResampleMethod.BICUBICSHARPER); if(imageRatio==1) AD.resizeImage(resizeMax,resizeMax,pResulotion,ResampleMethod.BICUBICSHARPER); if(imageRatio<1) AD.resizeImage(resizeMin,resizeMax,pResulotion,ResampleMethod.BICUBICSHARPER); } //-------------------------------------------- resRatio = AD.resolution/pResulotion; if(resRatio!=1){ AD.resizeImage(AD.width.value,AD.height.value,pResulotion); } photoWidth = AD.width.value; photoHight = AD.height.value; //获取RAW保存的信息 exifData = AD.xmpMetadata.rawData.toString(); //将EXIF信息分成单个的相关信息 explodeArray(exifData); //Photoshop CS获取EXIF信息 //快门速度 for(n = 0; n < tempArray.length; n ++) { stringTemp=tempArray[n]; if(stringTemp.indexOf("ExposureTime")!=-1) { exposureTime = tempArray[n+1]; break; } } //光圈大小 for(n = 0; n < tempArray.length; n ++) { stringTemp=tempArray[n]; if(stringTemp.indexOf("FNumber")!=-1){ fNumber = tempArray[n+1]; break; } } //曝光程序模式 for(n = 0; n < tempArray.length; n ++) { stringTemp=tempArray[n]; if(stringTemp.indexOf("ExposureProgram")!=-1){ exposureProgram = tempArray[n+1]; break; } } //曝光补偿 for(n = 0; n < tempArray.length; n ++) { stringTemp=tempArray[n]; if(stringTemp.indexOf("ExposureBiasValue")!=-1){ exposureBiasValue = tempArray[n+1]; break; } } //闪光模式 for(n = 0; n < tempArray.length; n ++) { stringTemp=tempArray[n]; if(stringTemp.indexOf("Fired")!=-1){ fired = tempArray[n+1]; break; } } //拍摄日期、时间 for(n = 0; n < tempArray.length; n ++) { stringTemp=tempArray[n]; if(stringTemp.indexOf("DateTimeOriginal")!=-1){ dateTimeOriginal = tempArray[n+1]; break; } } //使用焦距 for(n = 0; n < tempArray.length; n ++) { stringTemp=tempArray[n]; if(tempArray[n]=="FocalLength"){ focalLength = tempArray[n+1]; break; } } //ISO设置 for(n = 0; n < tempArray.length; n ++) { stringTemp=tempArray[n]; if(stringTemp.indexOf("ISOSpeedRatings")!=-1){ ISOSpeedRatings = ", ISO "+tempArray[n+5]; break; } } //使用镜头类型 for(n = 0; n < tempArray.length; n ++) { stringTemp=tempArray[n]; if(tempArray[n]=="Lens"){ lens=tempArray[n+1]; break; } } //相机厂商 for(n = 0; n < tempArray.length; n ++) { stringTemp=tempArray[n]; if(stringTemp.indexOf("Make")!=-1){ make = tempArray[n+1]; break; } } //相机型号 for(n = 0; n < tempArray.length; n ++) { stringTemp=tempArray[n]; if(stringTemp.indexOf("Model")!=-1){ var model = tempArray[n+1]; break; } } //对于有的相机型号不包括制造商部分 //camera = make+model; //对于有的相机型号包括制造商部分 camera = model; //相机所有者 for(n = 0; n < tempArray.length; n ++) { stringTemp=tempArray[n]; if(stringTemp.indexOf("creator")!=-1 && creator==""){ creator = tempArray[n+5]; break; } } //检查快门速度 dateArray1 = exposureTime.split("/"); j = dateArray1[0]; i = dateArray1[1]; if(j/i>=1) exposureTime=parseInt(j/i)+"."+(j-parseInt(j/i)*i); else { i=parseInt(i/j); j=1; exposureTime=j+"/"+i; } //计算光圈大小 dateArray1 = fNumber.split("/"); i = dateArray1[0]; j = dateArray1[1]; if(j>1) fNumber=i/j; else fNumber=i; //曝光补偿换算成小数 dateArray1 = exposureBiasValue.split("/"); i = dateArray1[0]; j = dateArray1[1]; exposureBiasValue=i/j; //小数点后面保留2位,就*100/100,保留一位,就*10/10 //这里保留了2位,20D可以不要这两行 if(exposureBiasValue!=0) exposureBiasValue=parseInt(exposureBiasValue*100)/100; if (exposureBiasValue > 0) exposureBiasValue="+"+exposureBiasValue; //确定曝光程序模式 exposureProgramArray = ["未定义", "Manual", "Normal Program", "Aperture Priority", "Shutter Priority", "Creative Program", "Action Program", "Portrait Mode", "Landscape Mode"]; exposureProgram = exposureProgramArray[exposureProgram]; //检查闪光模式 dateArray1 = fired; if(dateArray1.indexOf("True")!=-1) fired="FlashOn"; else fired="FlashOff"; //检查焦距 dateArray1 = focalLength.split("/"); i = dateArray1[0]; j = dateArray1[1]; focalLength=parseInt(i/j); //改变日期格式 dateArray1 = dateTimeOriginal.split("T"); phoDate = dateArray1[0]; phoTime = dateArray1[1]; dateArray2 = phoDate.split("-"); monthsArray =["1", "2", "3", "4", "5", "6", "7", "8", "9", "10", "11", "12"]; phoDate = dateArray2[0]+"-"+monthsArray[dateArray2[1]-1]+"-"+dateArray2[2]; dateArray2 = phoTime.split("+"); phoTime = dateArray2[0]; //你有什么镜头,就根据镜头和最大焦距改吧 if(lens != "") { if(lens.indexOf("17.0-40.0 mm")!=-1) lensUsed = "Canon 17-40mm F4L USM"; } //如果没有镜头信息,就使用原来的办法比较 else { var focLength=parseInt(focalLength); lensUsed="18-55mm 1:3.5-5.6G"; // if(focLength>=17 && focLength<=40) // lensUsed = "Nikon"; // if(focLength>=70 && focLength<=200) // lensUsed = "Nikon"; // if(focLength=="85") // lensUsed = "Nikon"; // if(focLength=="100") // lensUsed = "Nikon"; } //画线和框 //定义黑色,你也可以定义其他颜色哟 black = new SolidColor(); black.rgb.red = black.rgb.green = black.rgb.blue = 0; //定义白色,你也可以定义其他颜色哟 white = new SolidColor(); white.rgb.red = white.rgb.green = white.rgb.blue = 255; //定义灰色,你也可以定义其他颜色哟 grey = new SolidColor(); grey.rgb.red = grey.rgb.green = grey.rgb.blue = 50; //加入一条白线 backgroundColor = white; //如果改为黑线 //backgroundColor = black; //白线宽窄设为2或4,两边,实际宽度除以2 AD.resizeCanvas(AD.width.value+2,AD.height.value+2,AnchorPosition.MIDDLECENTER); //加入灰框 //backgroundColor = grey; //加入黑框 backgroundColor = black; //如果改为白框 //backgroundColor = white; //边框宽度和高度,这里将黑框宽窄设为图片宽度的1/40,两边,实际宽度再除以2 fWidth = parseInt(photoWidth/40); fHight = parseInt(photoWidth/40); //加框 AD.resizeCanvas(AD.width.value+fWidth,AD.height.value+fHight, AnchorPosition.MIDDLECENTER); //底部再加宽点,便于写字 AD.resizeCanvas(AD.width.value,AD.height.value+fHight+fHight+fHight,AnchorPosition.TOPCENTER); //标字和参数 nameLayer = AD.artLayers.add(); nameLayer.kind = LayerKind.TEXT; TN = nameLayer.textItem; TN.contents = creator; //版权字体、字号、颜色和加粗等 TN.font = "STXingkai"; //右对齐 TN.justification = Justification.RIGHT; //字号 tSize = parseInt((fWidth+10)/2); //字体左边距和下边距 tLeft = photoWidth; tHight = photoHight-fHight+tSize; //标字的位置 TN.position = [tLeft,tHight]; TN.size = tSize+4; TN.color = white; //如果为白框,字体为黑色 //TN.color = black; TN.fauxBold = true; infoLayer = AD.artLayers.add(); infoLayer.kind = LayerKind.TEXT; TI = infoLayer.textItem; //右对齐,如果左对齐可以省略下面这行 TI.justification = Justification.RIGHT; tHight = photoHight+fHight+tSize; //标字的位置 TI.position = [tLeft,tHight]; //显示:相机型号,镜头,焦距,曝光时间,光圈,ISO设置,拍摄日期等 TI.contents = camera+", "+lensUsed+" @"+focalLength+"mm,"+exposureTime+"Sec,F/"; TI.contents = TI.contents+fNumber+", EV "+exposureBiasValue+ISOSpeedRatings; //如果对曝光程式不感兴趣,请去掉下面行 TI.contents = TI.contents+", "+exposureProgram+", "+fired; TI.contents = TI.contents+"\u000D"+phoDate+" "+phoTime; //字体、字号、颜色等 TI.font = "黑体"; //TI.font = "Arial"; TI.size = tSize; TI.color = white; //如果为白框,字体为黑色 //TI.color = black; TI.fauxBold = true; AD.flatten(); //-------------

Outils d'IA chauds

Undresser.AI Undress
Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover
Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool
Images de déshabillage gratuites

Clothoff.io
Dissolvant de vêtements AI

AI Hentai Generator
Générez AI Hentai gratuitement.

Article chaud

Outils chauds

Bloc-notes++7.3.1
Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise
Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1
Puissant environnement de développement intégré PHP

Dreamweaver CS6
Outils de développement Web visuel

SublimeText3 version Mac
Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Sujets chauds

Avec le développement continu des médias sociaux, Xiaohongshu est devenue une plateforme permettant à de plus en plus de jeunes de partager leur vie et de découvrir de belles choses. De nombreux utilisateurs sont gênés par des problèmes de sauvegarde automatique lors de la publication d’images. Alors, comment résoudre ce problème ? 1. Comment résoudre le problème de l'enregistrement automatique des images lors de la publication sur Xiaohongshu ? 1. Vider le cache Tout d'abord, nous pouvons essayer de vider les données du cache de Xiaohongshu. Les étapes sont les suivantes : (1) Ouvrez Xiaohongshu et cliquez sur le bouton « Mon » dans le coin inférieur droit (2) Sur la page du centre personnel, recherchez « Paramètres » et cliquez dessus (3) Faites défiler vers le bas et recherchez « ; "Vider le cache". Cliquez sur OK. Après avoir vidé le cache, entrez à nouveau dans Xiaohongshu et essayez de publier des photos pour voir si le problème de sauvegarde automatique est résolu. 2. Mettez à jour la version Xiaohongshu pour vous assurer que votre Xiaohongshu

Avec la popularité des courtes vidéos Douyin, les interactions des utilisateurs dans la zone de commentaires sont devenues plus colorées. Certains utilisateurs souhaitent partager des images en commentaires pour mieux exprimer leurs opinions ou émotions. Alors, comment publier des photos dans les commentaires TikTok ? Cet article répondra à cette question en détail et vous fournira quelques conseils et précautions connexes. 1. Comment publier des photos dans les commentaires Douyin ? 1. Ouvrez Douyin : Tout d'abord, vous devez ouvrir l'application Douyin et vous connecter à votre compte. 2. Recherchez la zone de commentaire : lorsque vous parcourez ou publiez une courte vidéo, recherchez l'endroit où vous souhaitez commenter et cliquez sur le bouton "Commentaire". 3. Saisissez le contenu de votre commentaire : saisissez le contenu de votre commentaire dans la zone de commentaire. 4. Choisissez d'envoyer une photo : Dans l'interface de saisie du contenu des commentaires, vous verrez un bouton « image » ou un bouton « + », cliquez sur

Les iPhones récents d'Apple capturent des souvenirs avec des détails, une saturation et une luminosité nets. Mais parfois, vous pouvez rencontrer des problèmes qui peuvent rendre l’image moins claire. Bien que la mise au point automatique sur les appareils photo iPhone ait parcouru un long chemin, vous permettant de prendre des photos rapidement, l'appareil photo peut se concentrer par erreur sur le mauvais sujet dans certaines situations, rendant la photo floue dans les zones indésirables. Si vos photos sur votre iPhone semblent floues ou manquent globalement de netteté, l’article suivant devrait vous aider à les rendre plus nettes. Comment rendre les images plus claires sur iPhone [6 méthodes] Vous pouvez essayer d'utiliser l'application Photos native pour nettoyer vos photos. Si vous souhaitez plus de fonctionnalités et d'options

Dans PowerPoint, il est courant d'afficher les images une par une, ce qui peut être réalisé en définissant des effets d'animation. Ce guide détaille les étapes de mise en œuvre de cette technique, y compris la configuration de base, l'insertion d'images, l'ajout d'une animation et l'ajustement de l'ordre et du timing de l'animation. De plus, des paramètres et ajustements avancés sont fournis, tels que l'utilisation de déclencheurs, l'ajustement de la vitesse et de l'ordre de l'animation et la prévisualisation des effets d'animation. En suivant ces étapes et conseils, les utilisateurs peuvent facilement configurer les images pour qu'elles apparaissent les unes après les autres dans PowerPoint, améliorant ainsi l'impact visuel de la présentation et attirant l'attention du public.

Utilisez-vous également le logiciel Foxit PDF Reader ? Alors, savez-vous comment Foxit PDF Reader convertit les documents PDF en images jpg ? L'article suivant vous explique comment Foxit PDF Reader convertit les documents PDF en images jpg ? images jpg, venez jeter un oeil ci-dessous. Démarrez d'abord Foxit PDF Reader, puis recherchez « Fonctionnalités » dans la barre d'outils supérieure, puis sélectionnez la fonction « PDF vers autres ». Ensuite, ouvrez une page Web intitulée « Foxit PDF Online Conversion ». Cliquez sur le bouton « Connexion » en haut à droite de la page pour vous connecter, puis activez la fonction « PDF to Image ». Cliquez ensuite sur le bouton de téléchargement et ajoutez le fichier pdf que vous souhaitez convertir en image. Après l'avoir ajouté, cliquez sur "Démarrer la conversion".

Comment utiliser JavaScript pour implémenter la fonction glisser et zoomer des images ? Dans le développement Web moderne, faire glisser et zoomer sur des images est une exigence courante. En utilisant JavaScript, nous pouvons facilement ajouter des fonctions de glisser et de zoom aux images pour offrir une meilleure expérience utilisateur. Dans cet article, nous présenterons comment utiliser JavaScript pour implémenter cette fonction, avec des exemples de code spécifiques. Structure HTML Tout d'abord, nous avons besoin d'une structure HTML de base pour afficher les images et ajouter

Lors de l'utilisation du logiciel bureautique WPS, nous avons constaté que non seulement un formulaire est utilisé, mais que des tableaux et des images peuvent être ajoutés au texte, des images peuvent également être ajoutées au tableau, etc. Ceux-ci sont tous utilisés ensemble pour créer le contenu de l'ensemble du document. paraître plus riche, si vous devez insérer deux images dans le document et qu’elles doivent être disposées côte à côte. Notre prochain cours résoudra ce problème : comment placer deux images côte à côte dans un document wps. 1. Tout d'abord, vous devez ouvrir le logiciel WPS et trouver l'image que vous souhaitez ajuster. Faites un clic gauche sur l'image et une barre de menu apparaîtra, sélectionnez "Mise en page". 2. Sélectionnez « Emballage serré » dans l'habillage du texte. 3. Une fois que toutes les images dont vous avez besoin ont été confirmées comme étant définies sur « Habillage de texte serré », vous pouvez faire glisser les images vers la position appropriée et cliquer sur la première image.

Présentation des fonctions avancées d'utilisation de HTML, CSS et jQuery pour implémenter l'affichage de fusion d'images : dans la conception Web, l'affichage d'images est un lien important et l'affichage de fusion d'images est l'une des techniques courantes pour améliorer la vitesse de chargement des pages et améliorer l'expérience utilisateur. Cet article expliquera comment utiliser HTML, CSS et jQuery pour implémenter des fonctions avancées de fusion et d'affichage d'images, et fournira des exemples de code spécifiques. 1. Mise en page HTML : Tout d’abord, nous devons créer un conteneur en HTML pour afficher les images fusionnées. Vous pouvez utiliser di
