- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
虽然我设法放置了一个功能脚本来一起更改所选图层的字典语言,但这还不是我所需要的。
我目前正在检索我选择的图层的索引,使用它们来获取图层名称——这是有问题的部分——然后根据在我显示的自定义对话框。
层名称的使用是一个非常不成熟的解决方案,我需要精确度,我需要能够根据层 ID 或索引更改语言。不仅我的脚本容易出现名称冲突,而且我不知道那些选定的层将位于文档的根目录还是在 5 个组堆栈中。
这是我当前的代码:
主要功能
function main() {
// Create window with language selection and retrieve selected value
var lang = createWindow();
// Retrieve selected layers
var selectedLayers = getSelectedLayersIdx();
// Look at each entry and change language when possible
for(var a in selectedLayers){
try {
setLangByIndex(Number( selectedLayers[a]), lang );
} catch(err) { }
}
}
(createWindow 返回一个 lang 值,跳过那个)
迈克得到 Idx
function getSelectedLayersIdx(){
var selectedLayers = new Array;
var ref = new ActionReference();
ref.putEnumerated( charIDToTypeID('Dcmn'), charIDToTypeID('Ordn'), charIDToTypeID('Trgt') );
var desc = executeActionGet(ref);
if( desc.hasKey( stringIDToTypeID( 'targetLayers' ) ) ) {
desc = desc.getList( stringIDToTypeID( 'targetLayers' ));
var c = desc.count
var selectedLayers = new Array();
for(var i=0;i<c;i++) {
try{
activeDocument.backgroundLayer;
selectedLayers.push( desc.getReference( i ).getIndex() );
} catch(e) {
selectedLayers.push( desc.getReference( i ).getIndex()+1 );
}
}
} else {
var ref = new ActionReference();
ref.putProperty( charIDToTypeID('Prpr') , charIDToTypeID( 'ItmI' ));
ref.putEnumerated( charIDToTypeID('Lyr '), charIDToTypeID('Ordn'), charIDToTypeID('Trgt') );
try {
activeDocument.backgroundLayer;
selectedLayers.push( executeActionGet(ref).getInteger(charIDToTypeID( 'ItmI' ))-1);
} catch(e) {
selectedLayers.push( executeActionGet(ref).getInteger(charIDToTypeID( 'ItmI' )));
}
}
return selectedLayers;
}
设置语言的函数
function setLangByIndex(idx, lang){
ref = new ActionReference();
ref.putProperty( charIDToTypeID("Prpr") , charIDToTypeID( "Nm " ));
ref.putIndex( charIDToTypeID( "Lyr " ), idx );
var name = executeActionGet(ref).getString(charIDToTypeID( "Nm " ));
var el = activeDocument.layers.getByName( name );
// Temp quick block; MUST UPDATE IN CASE OF NEW LANGUAGES
if (lang == 'pt_br' )
el.textItem.language = Language.BRAZILLIANPORTUGUESE;
else if (lang == 'en_us' )
el.textItem.language = Language.ENGLISHUSA;
else
el.textItem.language = Language.ENGLISHUK;
}
我尝试过的低效解决方法:
最佳答案
在我注意到一些与段落样式相关的恼人故障(您可以将其定义为 PS 上的文本的默认样式,而不是 JS 对象)之后,我放弃了顽固并停止避免通过索引数组进行新循环完成后重新选择图层。
/*
* Based in Mike Hale's "getSelectedLayersIdx" script and Adobe's Scripting Listener dump.
Based the panel on Davide Barranca's code: http://www.davidebarranca.com/2012/10/scriptui-window-in-photoshop-palette-vs-dialog/
Useful Resources:
Photoshop char list: http://www.pcpix.com/Photoshop/char.htm
ActionDescriptor methods: http://jongware.mit.edu/pscs5js_html/psjscs5/pc_ActionDescriptor.html
TextItem methods: http://jongware.mit.edu/pscs5js_html/psjscs5/pc_TextItem.html
You can fish for language codes here: http://wingp.googlecode.com/svn/photogp/photoshopapi/photoshop/PIStringTerminology.h
*/
/* ______________________________ SCRIPT ______________________________ */
var scriptAlert = "Language Change says";
// MUST UPDATE IF YOU WANT TO CHANGE THE AVAILABLE LANGUAGES
// The available languages, as { text displayed on dialog window : codename }. See notes above for more language codes
var langs = {};
langs['Português (Brasil)'] = 'brazilianPortugueseLanguage';
langs['English (UK)'] = 'ukenglishLanguage';
langs['English (USA)'] = 'englishLanguage';
if(app.documents.length>0){ // the script will be executed only if an active document exists.
var imgName = activeDocument.name;
var extreme= imgName.substr(imgName.length - 5, 5);
var dot = extreme.lastIndexOf(".");
if(dot == -1) { // Checks if the active document was saved or not.
alert("Please, save your document!", scriptAlert, false);
} else {
main(); // if the active document was saved, go ahead!
}
}
function createWindow() { // Creates a panel asking for input
var isDone, win, windowResource, radio_group, cancel, rb, i;
//sentinel variable
isDone = false;
cancel = false;
// Build dialog radio buttons
i = 0;
for( var k in langs ) {
if( i==0 )
rb = "rb"+i+": RadioButton { text: '"+k+"', value: 1 }, \ ";
else
rb += "rb"+i+": RadioButton { text: '"+k+"' }, \ ";
i++;
}
windowResource = "palette { \
orientation: 'column', \
alignChildren: ['fill', 'top'], \
preferredSize:[300, 130], \
text: 'Change Spell Check Language', \
margins:15, \
\
optPanel: Panel { \
orientation: 'row', \
alignChildren: 'left', \
margins:15, \
text: ' Select the desired dictionary language for the select text ', \ "+ rb + " \
} \
\
bottomGroup: Group{ \
cancelButton: Button { text: 'Cancel', properties:{name:'cancel'}, size: [120,24], alignment:['right', 'center'] }, \
applyButton: Button { text: 'Ok', properties:{name:'ok'}, size: [120,24], alignment:['right', 'center'], active: true }, \
}\
}";
win = new Window(windowResource);
radio_group = win.optPanel; // set group
// Match options with language
function selected_rbutton (rbuttons)
{
for (var i = 0; i < rbuttons.children.length; i++)
if (rbuttons.children[i].value == true)
return langs[rbuttons.children[i].text];
}
win.bottomGroup.cancelButton.onClick = function() {
win.close();
return cancel = true;
};
// Button listeners
win.bottomGroup.applyButton.onClick = function() {
return isDone = true;
};
// don't forget this one!
win.onClose = function() {
return cancel = true;
};
win.addEventListener("keydown", function (k)
{
if (k.keyName == 'Enter')
return isDone = true;
});
win.show();
while (isDone === false) {
try {
app.refresh();
} catch(err) { // Esc cancels without errors
return false;
}
}
return cancel ? false : selected_rbutton (radio_group); // return value, or false if cancelled
}
function getSelectedLayersIdx(){ // Gets array of indexes of selected layers
var selectedLayers = new Array;
var ref = new ActionReference();
ref.putEnumerated( charIDToTypeID('Dcmn'), charIDToTypeID('Ordn'), charIDToTypeID('Trgt') );
var desc = executeActionGet(ref);
if( desc.hasKey( stringIDToTypeID( 'targetLayers' ) ) ) {
desc = desc.getList( stringIDToTypeID( 'targetLayers' ));
var c = desc.count
var selectedLayers = new Array();
for(var i=0;i<c;i++) {
try{
activeDocument.backgroundLayer;
selectedLayers.push( desc.getReference( i ).getIndex() );
} catch(e) {
selectedLayers.push( desc.getReference( i ).getIndex()+1 );
}
}
} else {
var ref = new ActionReference();
ref.putProperty( charIDToTypeID('Prpr') , charIDToTypeID( 'ItmI' ));
ref.putEnumerated( charIDToTypeID('Lyr '), charIDToTypeID('Ordn'), charIDToTypeID('Trgt') );
try {
activeDocument.backgroundLayer;
selectedLayers.push( executeActionGet(ref).getInteger(charIDToTypeID( 'ItmI' ))-1);
} catch(e) {
selectedLayers.push( executeActionGet(ref).getInteger(charIDToTypeID( 'ItmI' )));
}
}
return selectedLayers;
}
function selectLayerByIndex( selectedLayers, add ){ // Selects layers by index. If fed an array + true add, selects them, otherwise provide a single value so it selects a single layer
if (typeof(add)==='undefined') add = false;
if ( add ) // If Add it's an array
for(var a in selectedLayers){
var desc = new ActionDescriptor();
var ref = new ActionReference();
ref.putIndex( charIDToTypeID( "Lyr " ), Number(selectedLayers[a]) );
desc.putReference( charIDToTypeID( "null" ), ref );
desc.putEnumerated( stringIDToTypeID( "selectionModifier" ), stringIDToTypeID( "selectionModifierType" ), stringIDToTypeID( "addToSelection" ) );
var idMkVs = charIDToTypeID( "MkVs" );
desc.putBoolean( charIDToTypeID( "MkVs" ), false );
executeAction( charIDToTypeID( "slct" ), desc, DialogModes.NO );
}
else // Else I just need to make this layer active, it's a number
{
var desc = new ActionDescriptor();
var ref = new ActionReference();
var idLyr = charIDToTypeID( "Lyr " );
ref.putIndex( charIDToTypeID( "Lyr " ), selectedLayers );
desc.putReference( charIDToTypeID( "null" ), ref );
desc.putBoolean( charIDToTypeID( "MkVs" ), false );
executeAction( charIDToTypeID( "slct" ), desc, DialogModes.NO );
}
}
function setLangByIndex( idx, lang ){ // Sets the dictionary language for a text layer based on its index
// Make layer active
selectLayerByIndex( idx );
// And do tiny override
var textObj = new ActionDescriptor();
var target = new ActionReference();
target.putProperty( charIDToTypeID( "Prpr" ), charIDToTypeID( "TxtS" ) ); // desired property: text style
target.putEnumerated( charIDToTypeID( "TxLr" ), charIDToTypeID( "Ordn" ), charIDToTypeID( "Trgt" ) ); // the active layer
textObj.putReference( charIDToTypeID( "null" ), target );
var textStyle = new ActionDescriptor();
textStyle.putInteger( stringIDToTypeID( "textOverrideFeatureName" ), 808466225 );
textStyle.putInteger( stringIDToTypeID( "typeStyleOperationType" ), 3 );
textStyle.putEnumerated( stringIDToTypeID( "textLanguage" ), stringIDToTypeID( "textLanguage" ), stringIDToTypeID( lang ) );
textObj.putObject( charIDToTypeID( "T " ), charIDToTypeID( "TxtS" ), textStyle ); // to (end); text style, desc.
executeAction( charIDToTypeID( "setd" ), textObj, DialogModes.NO ); // execute
}
////////////////////////////////////
// Main function
function main() {
// Create window with language selection and retrieve selected value
var lang = createWindow();
if ( !lang ) // If cancelled please stop
return;
// Retrieve selected layers
var selectedLayers = getSelectedLayersIdx();
// Look at each entry and change language when possible; otherwise skip to next item
for(var k in selectedLayers){
try {
setLangByIndex(Number(selectedLayers[k]), lang);
} catch(err) {
continue;
}
}
selectLayerByIndex( selectedLayers, true );
}
关于javascript - 使用 photoshop 脚本更改选定的文本图层语言,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/30632255/
SO亲爱的 friend 们: 2014 年 3 月 18 日。我正在处理一种情况,在使用 ng-repeat 时,数组内的元素(我从 Json 字符串中获取)更改了原始顺序。 需要明确的是,数组中的
有很多问题询问如何在 JavaScript 单击处理程序中更改 div 的类,例如,此处:Change Div style onclick .我理解得很好(只需更改 .className),并且它有效
我从access导入了一个数据库到mysql,但其中一个表的列名“股数”带有空格,但我尝试更改、替换甚至删除列名,但失败了。任何人都可以帮助解决这一问题 String UpdateQuary = "U
我正在做一个随机的学校元素。 目前,我有一个包含两个 CSS 的页面。一种用于正常 View ,一种用于残障人士 View 。 此页面还包括两个按钮,它们将更改使用的样式表。 function c
我需要使用 javascript 更改 HTML 元素中的文本,但我不知道该怎么做。 ¿有什么帮助吗? 我把它定义成这样: Text I want to change. 我正在尝试这样做: docum
我在它自己的文件 nav_bar.shtml 中有一个主导航栏,每个其他页面都包含该导航栏。这个菜单栏是一个 jQuery 菜单栏(ApyCom 是销售这些导航栏的公司的名称)。导航栏上的元素如何确定
我正在摆弄我的代码,并开始想知道这个变化是否来自: if(array[index] == 0) 对此: if(!array[index] != 0) 可能会影响任何代码,或者它只是做同样的事情而我不需
我一直在想办法调整控制台窗口的大小。这是我正在使用的函数的代码: #include #include #define WIDTH 70 #define HEIGHT 35 HANDLE wHnd;
我有很多情况会导致相同的消息框警报。 有没有比做几个 if 语句更简单/更好的解决方案? PRODUCTS BOX1 BOX2 BOX3
我有一个包含这些元素的 XELEMENT B Bob Petier 19310227 1 我想像这样转换前缀。 B Bob Pet
我使用 MySQL 5.6 遇到了这种情况: 此查询有效并返回预期结果: select * from some_table where a = 'b' and metadata->>"$.countr
我想知道是否有人知道可以检测 R 中日期列格式的任何中断的包或函数,即检测日期向量格式更改的位置,例如: 11/2/90 12/2/90 . . . 15/Feb/1990 16/Feb/1990 .
我希望能够在小部件显示后更改 GtkButton 的标签 char *ButtonStance == "Connect"; GtkWidget *EntryButton = gtk_button_ne
我正在使用 Altera DE2 FPGA 开发板并尝试使用 SD 卡端口和音频线路输出。我正在使用 VHDL 和 C 进行编程,但由于缺乏经验/知识,我在 C 部分遇到了困难。 目前,我可以从 SD
注意到这个链接后: http://www.newscientist.com/blogs/nstv/2010/12/best-videos-of-2010-progress-bar-illusion.h
我想知道在某些情况下,即使剧本任务已成功执行并且 ok=2,ansible 也会显示“changed=0”。使用 Rest API 和 uri 模块时会发生这种情况。我试图找到解释但没有成功。谁能告诉
这个问题已经有答案了: 已关闭12 年前。 Possible Duplicate: add buttons to push notification alert 是否可以在远程通知显示的警报框中指定有
当您的 TabBarController 中有超过 5 个 View Controller 时,系统会自动为您设置一个“更多” View 。是否可以更改此 View 中导航栏的颜色以匹配我正在使用的颜
如何更改.AndroidStudioBeta文件夹的位置,默认情况下,该文件夹位于Windows中的\ .. \ User \ .AndroidStudioBeta,而不会破坏任何内容? /编辑: 找
我目前正在尝试将更具功能性的编程风格应用于涉及低级(基于 LWJGL)GUI 开发的项目。显然,在这种情况下,需要携带很多状态,这在当前版本中是可变的。我的目标是最终拥有一个完全不可变的状态,以避免状
我是一名优秀的程序员,十分优秀!