LinesLabels.efs
File Name: LinesLabels.efs
Description:
Draws up to 30 horizontal lines at price levels specified by the user through the "Edit Studies" option.
Formula Parameters:
vEditing: Default is False (True/False).
Line Thickness: Default is 1
Line Color: Default is Navy
Display Labels: Default is ON (ON/OFF)
Label Position: Default is Left (Left/Right)
Line 1 - Line 30: No default values (price levels for the lines).
Line 1 Label - Line 30 Label: No default values (labels for the lines).
Notes:
This formula has an additional feature built in to it that automatically draws the same lines and labels on other charts that you apply this formula to. The formula is also symbol specific. Only charts with the same symbol will be able to share lines. For example, let's say you have three charts of $SPX with intervals of 1 minute, 5, minutes and 10 minutes. Apply the formula to one of the charts, go to the "Edit Studies" option and enter "True" for vEditing. This just tells the formula that all the data for the lines and labels (and line formatting) will come from this particular chart's inputs. Then add a couple of lines and labels by entering the desired price for Line 1 etc. Apply the same formula to the other two charts and you will see the same lines and labels drawn on those charts of $SPX. If you change any of the data for the lines in your main chart, you will need to right-click and reload the formula on the other charts. You can then apply this same formula to another group of charts with a different symbol and share those lines and labels independently of the lines and labels of the $SPX charts.
Download File:
LinesLabels.efs
EFS Code:
/***************************************************************** Provided By : eSignal. (c) Copyright 2003 Study: Lines and Labels Version: 2.0 2.0 Updates - 12/18/2003 *Added FunctionParameter class for user inputs. *Changed naming convention for the global variables associated with vEditing to be symbol specific. This allows the formula to be used with multiple sets of charts using different symbols. Only charts with the same symbol will share the same price levels for the lines. *Added setShowTitleParameters(false) to hide formula parameters from the study title. *Added function parameter, Display Labels, to toggle the display of the labels to ON/OFF. *Added function parameter, Label Position, to set labels to appear on the left side of the chart or to the right. If set to right, the labels will appear on bar index 2 just right of the current bar. *Added sharing of the main chart's formatting options for, Thickness, Color, Display and Position. Notes: *Formula requires version 7.5. *Draws up to 30 Horizontal Lines with optional labels. *vEditing option allows the main chart where the price levels for the lines are set to be shared with additional charts using the same symbol. The additional charts only need to have this formula running. The price levels only need to be set once from the main chart. To enable this feature, set vEditing to true in the main chart. After making subsequent changes in the main chart, the other charts' LinesLabel *****************************************************************/ function preMain() { setPriceStudy(true); setStudyTitle("Line and Labels "); setShowCursorLabel(false); setShowTitleParameters(false); var fpA1 = new FunctionParameter("vEditing", FunctionParameter.STRING); fpA1.setName("vEditing (share lines w/ other charts)"); fpA1.addOption("true"); fpA1.addOption("false"); fpA1.setDefault("false"); var fpA2 = new FunctionParameter("nThickness", FunctionParameter.NUMBER); fpA2.setName("Line Thickness"); fpA2.setLowerLimit(1); fpA2.setDefault(1); var fpA3 = new FunctionParameter("nColor", FunctionParameter.COLOR); fpA3.setName("Line COLOR"); fpA3.setDefault(Color.navy); var fpA4 = new FunctionParameter("bLDisplay", FunctionParameter.STRING); fpA4.setName("Display Labels"); fpA4.addOption("ON"); fpA4.addOption("OFF"); fpA4.setDefault("ON"); var fpA5 = new FunctionParameter("sLabelPos", FunctionParameter.STRING); fpA5.setName("Label Position"); fpA5.addOption("Left"); fpA5.addOption("Right"); fpA5.setDefault("Left"); var afp1 = new Array(31); afp1[0] = ""; var afp2 = new Array(31); afp2[0] = ""; var i = 1; for (i = 1; i < 31; ++i) { var L = "L"+i; afp1[i] = new FunctionParameter(L, FunctionParameter.NUMBER); afp1[i].setName("Line " + i); var Ll = "L"+i+"label"; afp2[i] = new FunctionParameter(Ll, FunctionParameter.STRING); afp2[i].setName("Line " + i + " Label"); afp2[i].setDefault(" "); } } var vLoaded = false; var vEdit = null; var vSym = null; var bGlobals = false; var vThi = null; var vCol = null; var vDis = null; var vPos = null; function main(vEditing, nThickness, nColor, bLDisplay, sLabelPos, L1, L1label, L2, L2label, L3, L3label, L4, L4label, L5, L5label, L6, L6label, L7, L7label, L8, L8label, L9, L9label, L10, L10label, L11, L11label, L12, L12label, L13, L13label, L14, L14label, L15, L15label, L16, L16label, L17, L17label, L18, L18label, L19, L19label, L20, L20label, L21, L21label, L22, L22label, L23, L23label, L24, L24label, L25, L25label, L26, L26label, L27, L27label, L28, L28label, L29, L29label, L30, L30label) { var sTextFlags = null; var nTextX = 0; if (vSym == null) vSym = getSymbol(); if (vLoaded == false) { if (vEditing == "true") { vEdit = true; } else if (vEditing == "false") { vEdit = false; } else { vEdit = false; } if (vEdit == true) { // share formatting options setGlobalValue(vSym + "gThickness", nThickness); setGlobalValue(vSym + "gColor", nColor); setGlobalValue(vSym + "gLDisplay", bLDisplay); setGlobalValue(vSym + "gLabelPos", sLabelPos); } for (i = 1; i <= 30; ++i) { var vData = "L" + i; var vDataLabel = "L" + i + "label"; var gData = getGlobalValue(vSym + "g" + vData); var gDataLabel = getGlobalValue(vSym + "g" + vDataLabel); if (eval(vData) != null) { if (vEdit == true) { // Current Chart is sharing inputs. setGlobalValue(vSym + "gL"+i, eval(vData)); if (eval(vDataLabel) == null) { setGlobalValue(vSym + "gL"+i+"label", "null"); } else { setGlobalValue(vSym + "gL"+i+"label", eval(vDataLabel)); } } addBand(eval(vData), PS_SOLID, nThickness, nColor, vDataLabel); if (bLDisplay == "ON") { if (sLabelPos == "Right") { sTextFlags = "Text.LEFT|Text.ONTOP|Text.VCENTER|Text.Bold|Text.FRAME"; nTextX = 2; } else { sTextFlags = "Text.RELATIVETOLEFT|Text.ONTOP|Text.VCENTER|Text.Bold|Text.FRAME"; nTextX = 0; } drawTextAbsolute(nTextX, eval(vData), " " + eval(vDataLabel) + " ", Color.white, nColor, eval(sTextFlags), null, 10, vDataLabel); } } else if (vEdit == true) { removeText(vDataLabel); removeBand(vDataLabel); removeGlobalValue(vSym + "gL"+i); removeGlobalValue(vSym + "gL"+i+"label"); } // Current chart is not sharing but another chart is. if (vEdit == false && eval(vData) == null && getGlobalValue(vSym + "gL"+i) != null) { if (bGlobals == false) { vThi = getGlobalValue(vSym + "gThickness"); if (vThi == null) vThi = nThickness; vCol = getGlobalValue(vSym + "gColor"); if (vCol == null) vCol = nColor; vDis = getGlobalValue(vSym + "gLDisplay"); if (vDis == null) vDis = bLDisplay; vPos = getGlobalValue(vSym + "gLabelPos"); if (vPos == null) vPos = sLabelPos; bGlobals = true; } addBand(gData, PS_SOLID, vThi, vCol, gDataLabel); if (vDis == "ON") { if (vPos == "Right") { sTextFlags = "Text.LEFT|Text.ONTOP|Text.VCENTER|Text.Bold|Text.FRAME"; nTextX = 2; } else { sTextFlags = "Text.RELATIVETOLEFT|Text.ONTOP|Text.VCENTER|Text.Bold|Text.FRAME"; nTextX = 0; } drawTextAbsolute(nTextX, gData, " " + gDataLabel + " ", Color.white, vCol, eval(sTextFlags), null, 10, vDataLabel); } } } vLoaded = true; } return; }