{"version":3,"sources":["highcharts.src.js","proj4js-combined.js","SelectedRegionSummaryView.js","SelectedRegionTableView.js","HardcodedLabelPositions.js","LabelEngine.js","MapConfig.js","MapVizRouter.js","ChoroplethMapType.js","PolygonManager.js","DataResponseModel.js","ChartRenderer.js","gmaps.extensions.js","MapUtil.js","GoogleMapView.js","LegendView.js","MapPopupView.js","NYCSummaryView.js","NYCTableView.js","OverlayView.js","SelectorsView.js","SelectRegionPromptView.js"],"names":["noop","UNDEFINED","Renderer","garbageBin","defaultOptions","dateFormat","globalAnimation","pathAnim","timeUnits","makeTime","getMinutes","getHours","getDay","getDate","getMonth","getFullYear","setMinutes","setHours","setDate","setMonth","setFullYear","$","doc","document","win","window","math","Math","mathRound","round","mathFloor","floor","mathCeil","ceil","mathMax","max","mathMin","min","mathAbs","abs","mathCos","cos","mathSin","sin","mathPI","PI","deg2rad","userAgent","navigator","isOpera","opera","isIE","test","docMode8","documentMode","isWebKit","isFirefox","isTouchDevice","SVG_NS","hasSVG","createElementNS","createSVGRect","hasBidiBug","parseInt","split","useCanVG","createElement","getContext","hasTouch","documentElement","ontouchstart","symbolSizes","idCounter","charts","DIV","ABSOLUTE","RELATIVE","HIDDEN","PREFIX","VISIBLE","PX","NONE","M","L","TRACKER_FILL","HOVER_STATE","SELECT_STATE","MILLISECOND","SECOND","MINUTE","HOUR","DAY","WEEK","MONTH","YEAR","FILL","LINEAR_GRADIENT","STOPS","STROKE","STROKE_WIDTH","seriesTypes","extend","a","b","n","hash","i","args","arguments","length","obj","pInt","s","mag","isString","isObject","_typeof","isArray","Object","prototype","toString","call","isNumber","log2lin","num","log","LN10","lin2log","pow","erase","arr","item","splice","defined","attr","elem","prop","value","key","ret","setAttribute","getAttribute","splat","pick","arg","css","el","styles","opacity","filter","style","tag","attribs","parent","nopad","padding","border","margin","appendChild","extendClass","members","object","numberFormat","number","decimals","decPoint","thousandsSep","lang","c","indexOf","getDecimals","isNaN","d","undefined","decimalPoint","t","String","toFixed","j","substr","replace","slice","pad","Array","join","normalizeTickInterval","interval","multiples","magnitude","options","normalized","allowDecimals","normalizeTimeTickInterval","tickInterval","unitsOption","units","unit","unitRange","count","unitName","getTimeTicks","normalizedInterval","startOfWeek","minYear","tickPositions","higherRanks","useUTC","global","minDate","Date","setMilliseconds","setSeconds","getSeconds","time","getTime","minMonth","minDateDate","timezoneOffset","getTimezoneOffset","push","info","totalRange","ChartCounters","this","color","symbol","stableSort","sortFunction","sortValue","ss_i","sort","arrayMin","data","arrayMax","destroyObjectProperties","except","destroy","discardElement","element","innerHTML","error","code","stop","msg","console","correctFloat","parseFloat","toPrecision","setAnimation","animation","chart","Highcharts","format","timestamp","capitalize","date","hours","day","dayOfMonth","month","fullYear","langWeekdays","weekdays","replacements","A","e","shortMonths","B","months","m","y","Y","H","I","l","p","P","S","toUpperCase","wrapColor","wrapSymbol","init","fromD","toD","sixify","endLength","startBaseLine","endBaseLine","shift","bezier","numParams","start","end","concat","isArea","step","pos","complete","startVal","jQuery","HighchartsAdapter","dSetter","Fx","fx","Step","Tween","propHooks","easing","easeOutQuad","x","each","fn","base","now","apply","ends","started","set","forEach","len","getScript","inArray","adapterRun","method","grep","map","results","merge","offset","addEvent","event","bind","removeEvent","eventType","handler","func","removeEventListener","unbind","fireEvent","type","eventArguments","defaultFunction","defaultPrevented","Event","detachedType","layerX","layerY","trigger","isDefaultPrevented","washMouseEvent","originalEvent","pageX","pageY","animate","params","$el","globalAdapter","adapter","defaultLabelOptions","enabled","align","fontSize","lineHeight","defaultPlotOptions","colors","symbols","loading","numericSymbols","resetZoom","resetZoomTitle","canvasToolsURL","VMLRadialGradientURL","borderColor","borderRadius","defaultSeriesType","ignoreHiddenSeries","spacingTop","spacingRight","spacingBottom","spacingLeft","fontFamily","backgroundColor","plotBorderColor","resetZoomButton","theme","zIndex","position","title","text","subtitle","plotOptions","line","allowPointSelect","showCheckbox","duration","events","lineWidth","shadow","marker","radius","lineColor","states","hover","select","fillColor","point","dataLabels","formatter","verticalAlign","cropThreshold","pointRange","showInLegend","stickyTracking","labels","legend","layout","labelFormatter","name","borderWidth","navigation","activeColor","inactiveColor","itemStyle","cursor","itemHoverStyle","itemHiddenStyle","itemCheckboxStyle","width","height","symbolWidth","symbolPadding","labelStyle","fontWeight","top","textAlign","tooltip","dateTimeLabelFormats","millisecond","second","minute","hour","week","year","headerFormat","pointFormat","shared","snap","whiteSpace","credits","href","defaultSeriesOptions","setTimeMethods","GET","SET","UTC","minutes","seconds","Color","input","result","rgba","exec","get","brighten","alpha","setOpacity","SVGElement","renderer","nodeName","attrSetters","animOptions","val","child","skipAttr","titleNode","hasSetSymbolSize","doTransform","wrapper","toLowerCase","shadows","childNodes","rotation","rx","ry","left","center","right","getElementsByTagName","textContent","forExport","symbolName","symbolAttr","cutHeight","updateTransform","textStr","bBox","added","buildText","clip","clipRect","url","id","crisp","strokeWidth","normalizer","values","hyphenate","elemWrapper","textWidth","serializedCss","fill","on","preventDefault","setRadialReference","coordinates","radialReference","translate","translateX","translateY","invert","inverted","htmlCss","tagName","htmlGetBBox","offsetLeft","offsetTop","offsetWidth","offsetHeight","htmlUpdateTransform","alignCorrection","nonLeft","marginLeft","marginTop","invertChild","baseline","quad","radians","costheta","sintheta","xCorr","yCorr","currentTextTransform","rotationStyle","cTT","isSVG","transform","elemWidth","elemHeight","innerText","display","fontMetrics","alignOnAdd","toFront","parentNode","alignOptions","alignByTranslate","box","alignedObjects","vAlign","bottom","middle","placed","alignAttr","getBBox","rad","namespaceURI","show","visibility","hide","add","otherElement","otherZIndex","inserted","parentWrapper","parentGroup","parentInverted","handleZ","insertBefore","safeRemoveChild","removeChild","onclick","onmouseout","onmouseover","onmousemove","clipPath","stops","empty","shadowOptions","group","cutOff","shadowWidth","shadowElementOpacity","offsetX","offsetY","cloneNode","isShadow","stroke","stroke-opacity","stroke-width","SVGRenderer","VMLRenderer","CanVGRenderer","CanVGController","deferredRenderCalls","Element","container","boxWrapper","subPixelFix","rect","loc","location","xmlns","version","defs","gradients","setSize","getBoundingClientRect","isHidden","rendererDefs","draw","lastLine","textNode","lines","styleRegex","hrefRegex","parentX","textStyles","textLineHeight","GET_COMPUTED_STYLE","linePositions","pop","lineNo","spans","spanNo","span","spanStyle","attributes","tspan","match","createTextNode","dx","getPropertyValue","h","getLineHeightByBBox","actualWidth","words","rest","firstChild","unshift","dy","button","callback","normalState","hoverState","pressedState","stateOptions","stateStyle","normalStyle","hoverStyle","pressedStyle","label","curState","STYLE","verticalGradient","x1","y1","x2","y2","setState","state","crispLine","points","path","circle","r","arc","innerR","g","class","image","src","preserveAspectRatio","setAttributeNS","imageSrc","imageSize","centerImage","symbolFn","imageRegex","img","size","onload","w","cpw","square","triangle","triangle-down","diamond","innerRadius","open","cosStart","sinStart","cosEnd","sinEnd","longArc","colorObject","gradName","gradAttr","gradientObject","stopColor","stopOpacity","regexRgba","linearGradient","radialGradient","gradientUnits","cx","cy","stopObject","stop-color","stop-opacity","removeAttribute","str","useHTML","defaultChartStyle","fakeSVG","html","svgGroupWrapper","htmlGroup","parents","div","reverse","htmlGroupStyle","className","shape","anchorX","anchorY","wrapperX","wrapperY","baselineOffset","needsBox","alignFactor","crispAdjust","deferredAttr","updateBoxSize","boxY","updateTextPadding","boxAttr","getSizeAfterAdd","baseCss","VMLElement","markup","prepVML","deferUpdateTransform","elemStyle","strokeweight","convertedPath","cutOffPath","updateClipping","stroked","dashstyle","filled","clipMembers","cssRet","destroyClip","getCSS","node","evt","target","srcElement","modifiedPath","cssText","VMLRendererExtension","isIE8","namespaces","hcv","createStyleSheet","isObj","member","fillType","opacity1","opacity2","color1","color2","firstStop","lastStop","gradient","fillAttr","addFillNode","atan","sizex","sizey","applyRadialGradient","strokeNodes","vmlStyle","coordsize","parentStyle","flip","circleCorrection","innerCorrection","drawDeferred","callIndex","callLength","Tick","axis","isNew","addLabel","PlotLineOrBand","StackItem","isNegative","stackOption","stacking","stack","percent","Axis","Tooltip","crosshairs","MouseTracker","zoomType","zoomX","zoomY","Legend","Chart","scriptLocation","dateTimeLabelFormat","tick","horiz","categories","labelOptions","staggerLines","plotWidth","isFirst","isLast","tickPositionInfo","isDatetimeAxis","isLog","labelGroup","getLabelSize","labelBBox","getLabelSides","leftSide","handleOverflow","index","xy","reversed","sides","rightSide","plotLeft","plotRight","neighbour","ticks","neighbourEdge","getPosition","tickmarkOffset","old","cHeight","oldChartHeight","chartHeight","transB","opposite","oldChartWidth","chartWidth","getLabelPosition","transA","getMarkPath","tickLength","tickWidth","render","gridLinePath","markPath","gridLine","gridPrefix","tickPrefix","gridLineWidth","gridLineColor","dashStyle","tickColor","tickPosition","mark","getPlotLinePath","gridGroup","axisGroup","showFirstLabel","showLastLabel","overflow","xs","ys","plotLine","halfPointRange","optionsLabel","to","from","isBand","svgElem","getPlotBandPath","onGetPath","plotLinesAndBands","endOnTick","setTotal","total","cum","setOffset","xOffset","xWidth","neg","yZero","xAxis","plotHeight","stackBox","crop","isInsidePlot","minPadding","maxPadding","minorGridLineColor","minorGridLineWidth","minorTickColor","minorTickLength","minorTickPosition","startOnTick","tickmarkPlacement","tickPixelInterval","defaultYAxisOptions","stackLabels","defaultLeftAxisOptions","defaultRightAxisOptions","defaultBottomAxisOptions","defaultTopAxisOptions","userOptions","isXAxis","isX","xOrY","side","setOptions","defaultLabelFormatter","minPixelPadding","isLinked","linkedTo","minorTicks","alternateBands","minRange","userMinRange","maxZoom","range","stacks","axes","series","removePlotBand","removePlotBandOrLine","removePlotLine","addPlotBand","addPlotBandOrLine","addPlotLine","val2lin","lin2val","multi","numericSymbolDetector","getSeriesExtremes","posStack","negStack","hasVisibleSeries","dataMin","dataMax","visible","posPointStack","negPointStack","stackKey","negKey","xData","yData","yDataLength","seriesOptions","threshold","activeYData","activeCounter","pointStack","cropped","xExtremes","getExtremes","hasModifyValue","modifyValue","usePercentage","processedXData","processedYData","ignoreMinPadding","ignoreMaxPadding","backwards","cvsCoord","handleLog","pointPlacementBetween","returnValue","axisLength","sign","cvsOffset","localA","oldTransA","localMin","oldMin","postTranslate","ordinal","skip","axisLeft","axisTop","translatedValue","cWidth","toPath","getLinearTickPositions","lastPos","roundedMin","roundedMax","getLogTickPositions","minor","positions","_minorAutoInterval","intermediate","break2","realMin","realMax","tickIntervalOption","filteredTickIntervalOption","tickPixelIntervalOption","totalPixelLength","getMinorTickPositions","minorTickInterval","minorTickPositions","adjustForMinRange","zoomOffset","closestDataRange","distance","loopLength","minArgs","maxArgs","spaceAvailable","xIncrement","setAxisTranslation","closestPointRange","minPointOffset","pointRangePadding","linkedParent","seriesPointRange","pointPlacement","seriesClosestPointRange","noSharedTooltip","translationSlope","setTickPositions","secondPass","linkedParentExtremes","tickPositioner","minTickIntervalOption","minTickInterval","userMin","userMax","processData","oldMax","beforeSetTickPositions","postProcessTickInterval","getNonLinearTimeTicks","ordinalPositions","setMaxTicks","maxTicks","alignTicks","adjustTickAmount","tickAmount","oldTickAmount","calculatedTickAmount","isDirty","setScale","isDirtyData","isDirtyAxisLength","oldAxisLength","setAxisSize","oldUserMin","oldUserMax","setExtremes","newMin","newMax","redraw","isDirtyExtremes","zoom","offsetRight","plotTop","getThreshold","getOffset","hasData","showAxis","titleOffsetOption","titleOffset","titleMargin","axisTitleOptions","labelOffset","axisOffset","directionFactor","showEmpty","gridZIndex","1","3","axisTitle","low","high","axisTitleMargin","getLinePath","lineLeft","lineTop","getTitlePosition","alongAxis","offAxis","linePath","stackLabelOptions","alternateGridColor","slideInTicks","hasRendered","isActive","_addedPlotLB","plotLines","plotBands","plotLineOptions","coll","axisLine","oneStack","stackCategory","stackTotalGroup","setTitle","newTitleOptions","tracker","resetTracker","setCategories","newCategories","doRedraw","setTooltipPoints","crosshair","move","clearTimeout","tooltipTimeout","setTimeout","hoverPoints","hideCrosshairs","getAnchor","mouseEvent","yAxis","plotX","plotY","tooltipPos","plotLow","plotHigh","chartY","boxWidth","boxHeight","alignedRight","pointX","pointY","refresh","anchor","placedTooltipPoint","currentSeries","textConfig","pointConfig","items","tooltipHeaderFormatter","tooltipFormatter","tooltipOptions","footerFormat","crosshairsOptions","getLabelConfig","category","isCartesian","tooltipOutsidePlot","positioner","stackY","normalizeMouseEvent","chartPosition","chartX","ePos","touches","getMouseCoordinates","isHorizontal","getIndex","mouseTracker","hoverPoint","hoverSeries","enableMouseTracking","tooltipPoints","_dist","tooltipPosName","hoverX","onMouseOver","allowMove","onMouseOut","setDOMEvents","hasDragged","zoomHor","zoomVert","drop","selectionMarker","runZoom","selectionData","selectionBox","selectionLeft","selectionTop","zoomEnabled","selectionMin","selectionMax","cancelClick","mouseIsDown","hideTooltipOnMouseMove","hideTooltipOnMouseLeave","onmousedown","mouseDownX","mouseDownY","mouseMove","isOutsidePlot","runTrackerClick","runChartClick","sqrt","clickedInside","hasCartesianSeries","selectionMarkerFill","xSize","ySize","panning","pan","ontouchmove","ontouchend","cancelBubble","firePointEvent","trackerGroup","clearInterval","itemMarginTop","initialItemX","initialItemY","maxItemWidth","itemHeight","lastLineHeight","positionCheckboxes","colorizeItem","legendItem","legendLine","legendSymbol","hiddenColor","textColor","symbolColor","markerOptions","convertAttribs","positionItem","ltr","rtl","legendItemPos","_legendItemPos","itemX","itemY","checkbox","legendGroup","legendWidth","destroyItem","scrollOffset","clipHeight","legendHeight","allItems","legendItemWidth","renderItem","itemWidth","horizontal","widthOption","itemMarginBottom","li","itemOptions","scrollGroup","drawLegendSymbol","fnLegendItemClick","setVisible","strLegendItemClick","browserEvent","checked","selected","defaultChecked","lastItemY","legendBorderWidth","legendBackgroundColor","contentGroup","serie","legendItems","legendType","legendIndex","spacingBox","isResizing","optionsY","alignTop","spaceHeight","maxHeight","navOptions","arrowSize","nav","pageCount","currentPage","fullHeight","up","scroll","pager","down","scrollBy","optionsChart","optionsMargin","optionsMarginTop","optionsMarginRight","marginRight","optionsMarginBottom","marginBottom","optionsMarginLeft","chartEvents","click","showAxes","reflow","initReflow","pointCount","counters","firstRender","initSeries","addSeries","isDirtyLegend","adjustTickAmounts","hasStackedSeries","redrawLegend","isDirtyBox","seriesLength","isHiddenChart","afterRedraw","cloneRenderTo","getMargins","drawChartBox","showLoading","loadingDiv","loadingOptions","loadingSpan","loadingShown","showDuration","hideLoading","hideDuration","getAxes","optionsArray","xAxisOptions","yAxisOptions","axisOptions","getSelectedPoints","getSelectedSeries","showResetZoom","btnOptions","alignTo","relativeTo","zoomOut","resetSelection","hasZoomed","axisData","extremes","titleOptions","subtitleOptions","chartTitleOptions","chartSubtitleOptions","getChartSize","renderTo","renderToClone","containerWidth","containerHeight","revert","clone","body","getContainer","oldChartIndex","containerId","indexAttrName","getElementById","create","legendOptions","legendMargin","legendX","legendY","resetMargins","floating","extraBottomMargin","extraTopMargin","setChartSize","reflowTimeout","hasUserSize","fireEndResize","chartTitle","chartSubtitle","plotBorderWidth","plotSizeX","plotSizeY","plotBox","clipBox","mgn","bgAttr","chartBackground","plotBackground","plotBorder","plotBGImage","chartBorderWidth","chartBackgroundColor","plotBackgroundColor","plotBackgroundImage","plotShadow","propFromSeries","klass","creditsHref","seriesGroup","isReadyToRender","readyState","canvg","attachEvent","detachEvent","RangeSelector","rangeSelector","serieOptions","Scroller","scrollbar","scroller","callbacks","Point","defaultColors","applyOptions","pointAttr","colorByPoint","optionsType","config","_hasPointLabels","_hasPointMarkers","autoIncrement","graphic","dataLabel","destroyElements","props","percentage","stackTotal","accumulate","loopPoint","replacement","repOptionKey","parts","seriesTooltipOptions","splitter","cfg","close","valuePrefix","yPrefix","valueDecimals","yDecimals","valueSuffix","ySuffix","hasOwnProperty","update","dataLength","getAttribs","toYData","remove","eventArgs","importEvents","ctrlKey","metaKey","shiftKey","hasImportedEvents","normalDisabled","markerStateOptions","stateDisabled","stateMarkerGraphic","markerGroup","Series","pointClass","sorted","requireSorting","pointAttrToOptions","bindAxes","getColor","getSymbol","setData","AXIS","pointStart","pointInterval","getSegments","lastNull","segments","pointsLength","connectNulls","chartOptions","typeOptions","seriesMarkerOption","defaultSymbols","legendItemGroup","addPoint","graph","area","currentShift","dataOptions","proto","generatePoints","oldData","initialColor","firstPoint","pointProto","pt","turboThreshold","pointArrayMap","valueCount","isRemoving","force","cropStart","cropEnd","forceCrop","processedDataLength","hasGroupedData","isBottomSeries","allStackSeries","placeBetween","pointStackTotal","xValue","yValue","yBottom","clientX","renew","tooltipLen","segment","xDateFormat","isDateTime","mouseOver","mouseOut","markerClipRect","sharedClipKey","animationTimeout","afterAnimate","drawPoints","isImage","pointMarkerOptions","isInside","seriesMarkerOptions","base1","base2","base3","option","conversion","pointStateOptionsHover","hasPointSpecificOptions","normalOptions","stateOptionsHover","seriesColor","normalDefaults","seriesPointAttr","brightness","issue134","drawDataLabels","pointOptions","generalOptions","dataLabelsGroup","dlProcessOptions","plotGroup","alignDataLabel","getSegmentPath","segmentPath","lastPoint","getPointSpline","getGraphPath","graphPath","singlePoints","drawGraph","invertGroups","setInvert","groupName","doAnimation","chartSeriesGroup","drawTracker","wasDirtyData","vis","showOrHide","seriesTracker","oldVisibility","otherSeries","singlePoint","trackByArea","trackerPath","areaPath","trackerPathLength","isTracker","stroke-linejoin","LineSeries","AreaSeries","areaSegmentPath","closedStacks","closeSegment","translatedThreshold","fillOpacity","spline","SplineSeries","leftContX","leftContY","rightContX","rightContY","nextPoint","correction","lastX","lastY","nextX","nextY","smoothing","areaspline","areaProto","AreaSplineSeries","column","groupPadding","pointPadding","minPointLength","ColumnSeries","columnIndex","columnCount","reversedXAxis","stackGroups","grouping","otherOptions","categoryWidth","ordinalSlope","pointOffsetWidth","optionPointWidth","pointWidth","barW","pointXOffset","shapeArgs","barX","barY","barH","shapeType","trackerArgs","rel","validPlotY","trackerLabel","relatedTarget","fromElement","_i","toElement","below","inside","bar","BarSeries","scatter","ScatterSeries","_hasTracking","pie","slicedOffset","PieSeries","toggleSlice","connector","shadowGroup","ignoreHiddenPoint","sliced","translation","slicedTranslation","startAngleRad","getCenter","innerSize","smallestSize","angle","fraction","radiusX","radiusY","cumulative","connectorOffset","startAngle","circ","labelDistance","getX","asin","half","labelPos","groupTranslation","sortByAngle","connectorPath","labelHeight","rankArr","connectorPadding","connectorWidth","softConnector","distanceOption","seriesCenter","centerY","outside","halves","slotsLength","slotIndex","slots","usedSlots","rank","slotI","closest","slot","naturalY","justify","moved","connectorColor","getOptions","wrap","proceed","svg","canvas","vml","product","Proj4js","defaultDatum","source","dest","readyToUse","reportError","srsCode","datum","datum_type","common","PJD_3PARAM","PJD_7PARAM","datumCode","wgs84","WGS84","adjust_axis","projName","D2R","to_meter","inverse","from_greenwich","datum_transform","R2D","forward","compare_datums","PJD_NODATUM","es","geodetic_to_geocentric","geocentric_to_wgs84","geocentric_from_wgs84","geocentric_to_geodetic","crs","denorm","v","xin","yin","zin","z","alert","destination","property","Class","initialize","extended","newArgs","scriptName","defsLookupService","libPath","getScriptLocation","scriptNameLen","scripts","lastIndexOf","loadScript","onfail","loadCheck","script","defer","onerror","onreadystatechange","checkReadyState","phi4z","eccent","e0","e1","e2","e3","phi","sinphi","sin2ph","ml","mlp","dphi","tan","e4fn","con","com","Proj","x0","y0","localCS","queue","srsCodeInput","parseWKT","deriveConstants","loadProjCode","urn","srsAuth","srsProjNumber","substring","loadProjDefinition","defsLoaded","loadFromService","checkDefsLoaded","defsFailed","parseDefs","initTransforms","loadProjCodeSuccess","loadProjCodeFailure","checkCodeLoaded","dependsOn","wktRE","wkt","wktMatch","wktName","wktObject","wktTemp","wktArray","bkCount","token","charAt","geocsCode","wktProjections","datumName","ellps","rf","unitsPerMeter","k0","long0","lat0","datum_params","paramName","paramVal","defData","paramArray","nagrids","lat1","lat2","lat_ts","longc","R_A","zone","utmSouth","PrimeMeridian","legalAxis","datumDef","Datum","towgs84","ellipse","Ellipsoid","EPSLN","sphere","a2","b2","SIXTH","RA4","RA6","ep2","longlat","identity","EPSG:4326","EPSG:4269","EPSG:3875","HALF_PI","TWO_PI","FORTPI","SEC_TO_RAD","MAX_ITER","COS_67P5","AD_C","PJD_UNKNOWN","PJD_GRIDSHIFT","PJD_WGS84","SRS_WGS84_SEMIMAJOR","RV4","RV6","msfnz","cosphi","tsfnz","phi2z","ts","eccnth","qsfnz","asinz","e0fn","e1fn","e2fn","e3fn","mlfn","srat","esinp","exp","adjust_lon","adjust_lat","latiso","Number","NaN","POSITIVE_INFINITY","fL","invlatiso","Iphi","sinh","cosh","tanh","asinh","acosh","atanh","gN","temp","pj_enfn","en","C00","C02","C04","C06","C08","C22","C44","C46","C48","C66","C68","C88","pj_mlfn","sphi","cphi","pj_inv_mlfn","k","proj","X","Z","Rn","Sin_Lat","Sin2_Lat","Cos_Lat","Longitude","Latitude","Height","RR","CT","ST","RX","RK","RN","CPHI0","SPHI0","CPHI","SPHI","SDPHI","iter","genau","atan2","geocentric_to_geodetic_noniter","W","W2","T0","T1","S0","S1","Sin_B0","Sin3_B0","Cos_B0","Sin_p1","Cos_p1","Sum","At_Pole","Dx_BF","Dy_BF","Dz_BF","Rx_BF","Ry_BF","Rz_BF","M_BF","x_out","y_out","z_out","x_tmp","y_tmp","z_tmp","coords","toShortString","greenwich","lisbon","paris","bogota","madrid","rome","bern","jakarta","ferro","brussels","stockholm","athens","oslo","MERIT","ellipseName","SGS85","GRS80","IAU76","airy","APL4.","NWL9D","mod_airy","andrae","aust_SA","GRS67","bessel","bess_nam","clrk66","clrk80","CPM","delmbr","engelis","evrst30","evrst48","evrst56","evrst69","evrstSS","fschr60","fschr60m","fschr68","helmert","hough","intl","kaula","lerch","mprts","new_intl","plessis","krass","SEasia","walbeck","WGS60","WGS66","WGS72","GGRS87","NAD83","NAD27","nadgrids","potsdam","carthage","hermannskogel","ire65","nzgd49","OSGB36","Lambert Tangential Conformal Conic Projection","Mercator","Popular Visualisation Pseudo Mercator","Mercator_1SP","Transverse_Mercator","Transverse Mercator","Lambert Azimuthal Equal Area","Universal Transverse Mercator System","aea","sin_po","cos_po","t1","ms1","qs1","t2","ms2","qs2","t3","qs0","ns0","rh","lon","lat","sin_phi","cos_phi","qs","rh1","theta","phi1z","eccnts","sterea","rc","sinc0","phic0","cosc0","R2","sinc","cosc","cosl","rho","poly","ml0","ms","al","iflg","equi","dlon","merc","utm","eqdc","mode","ml1","ml2","ns","phi3z","tmerc","delta_lon","acos","als","tq","delta_phi","f","tan_phi","cs","ds","gstmerc","lc","rs","sinz","pc","sinzpc","cp","n2","Ls","Ls1","LC","ortho","sin_p14","cos_p14","coslon","cosz","krovak","s45","s90","fi0","alfa","uq","u0","k1","n0","s0","ro0","ad","gfi","u","deltav","eps","ro","czech","fi1","ok","tmp","somerc","phy0","lambda0","sinPhy0","semiMajorAxis","flattening","R","b0","K","Sa1","Sa2","rotI","rotB","lambda","phy","prevPhy","iteration","stere","ssfn_","phit","eccen","TOL","NITER","CONV","S_POLE","N_POLE","OBLIQ","EQUIT","phits","akm1","sinX1","cosX1","sinph0","cosph0","coslam","sinlam","sinX","cosX","Xt","tp","phi_l","halfe","pi2","phi0","nzmg","iterations","B_re","B_im","C_re","C_im","D","delta_lat","d_phi","d_lambda","d_phi_n","d_psi","th_n_im1","th_re","th_im","th_n_re","th_n_im","z_re","z_im","z_n_im1","delta_x","z_n_re","z_n_im","num_re","num_im","den_re","den_im","den2","d_psi_n","mill","gnom","infinity_dist","sinu","C_y","C_x","V","vandg","asq","sinth","costh","gsq","msq","xx","yy","xys","c1","c2","c3","a1","m1","th1","cea","eqc","dlat","cass","m0","C1","C2","C3","C4","C5","lam","tn","dd","ph1","d2","gauss","C","ratexp","omerc","lon1","lon2","sin_p20","cos_p20","bl","gama","singam","cosgam","sinaz","cosaz","at1","ts1","ts2","gam","q","us","vl","ul","vs","lcc","sin1","cos1","sin2","cos2","ts0","f0","laea","qp","mmf","apa","authset","rq","xmf","ymf","sinb1","cosb1","sinb","cosb","cCe","sCe","ab","authlat","P00","P01","P02","P10","P11","P20","APA","beta","aeqd","sin_p12","cos_p12","ksp","moll","delta_theta","_","nspace","SelectedRegionSummaryView","Backbone","View","templateSelector","sparklineContainerId","initialRenderPromise","Deferred","chartAnimationComplete","bindAll","dataResponseModel","model","debounce","getInitialRenderPromise","loadTemplate","template","$tmpl","initialRender","$name","$dataSummary","$rank","$rankSubtext","$trendContainer","renderChart","xAxisCategories","dataSeries","displayValues","self","ccc","viz","util","ChartRenderer","renderSparkline","resolve","updateChart","timeFramesById","dataInfo","tfName","timeFrameId","isFinite","displayValue","$chart","getCurrentFips","isRendered","fips","when","getDataResponse","done","is","fadeIn","response","array","tfId","allYearsData","dataByFips","find","yearData","locationsByFips","displayVals","locationName","rankSubtext","fadeables","summary","views","instances","SelectorsView","getDataSummaryByPropertyNames","isBlank","indicatorGroupName","isUninhabited","overrideDisplayValues","tfIds","Set","warn","arrowImgPath","SelectedRegionTableView","arrowUrls","bad","good","neutral","noChange","preloadArrows","entry","Image","currentLocation","getSummaryFunc","summary1","currentDistributionName","templateData","dataSummary1","dataSummary2","previousTfName","previousTimeFrameName","dataForFips","tableDataByFips","characteristicId","characteristicsById","Fips","NYC","changeDisplayValue","change","changeValue","upDown","altText","goodBad","largerValuesAre","changeAltText","changeImgUrl","outerHeight","hardcodedPositionsByOverlayTypeAndFips","5","7","8","10","11","12","13","14","16","15","18","19","20","21","22","23","25","26","27","28","29","30","31","32","33","34","38","41","44","46","49","50","51","53","58","59","61","62","64","65","68","71","73","76","77","79","81","82","84","85","9","17","35","37","39","42","45","47","63","69","75","100","105","110","113","114","115","4","36","CCCLabelEngine","labelGun","labelgun","default","labelObject","classList","renderLabels","overlayMarkers","beforeTask","afterTask","Function","debug","delayLength","cb","reset","labelDiv","labelDiv_","bottomLeft","point2LatLng","google","maps","topRight","boundingBox","lng","performance","ingestLabel","random","labelContent","getProjection","fromLatLngToPoint","getBounds","getNorthEast","getSouthWest","scale","getZoom","worldPoint","fromPointToLatLng","resetAndUpdateLabels","MapConfig","serviceUrl","dataUrl","noDataColor","themeColors","getThemeColorString","getNumBreaks","minZoom","mouseoverPolygonStyle","strokeColor","strokeWeight","selectedPolygonInnerStyle","clickable","selectedPolygonOuterStyle","strokeOpacity","nycLocationId","nycFips","sharedNs","MapVizRouter","routers","VizRouterBase","routes","",":indicatorId",":indicatorId/:characteristicId",":indicatorId/:characteristicId/:locationTypeId",":indicatorId/:characteristicId/:locationTypeId/:dataFormatId",":indicatorId/:characteristicId/:locationTypeId/:dataFormatId/:timeFrameId",":indicatorId/:characteristicId/:locationTypeId/:dataFormatId/:timeFrameId/:selectedFips",":indicatorId/:characteristicId/:locationTypeId/:dataFormatId/:timeFrameId/:selectedFips/:overlays","initializeViews","indicatorId","locationTypeId","dataFormatId","selectedFips","overlays","getValue","raw","selectorsModel","models","SelectorsModel","silent","dataModel","DataResponseModel","dispatcher","loadingSpinner","LoadingSpinnerView","selectedRegionSummaryView","nycSummaryView","NYCSummaryView","selectedRegionTableView","nycTableView","NYCTableView","selectRegionPromptView","SelectRegionPromptView","mapView","GoogleMapView","legendView","LegendView","sourceDefinitionNotesView","SourceDefinitionNotesView","overlayView","OverlayView","mapPopupView","MapPopupView","selectorsView","indicatorGroupId","completeRouterInitialization","routeUrlParts","velir","ChoroplethMapType","projection","filterString","_projection","_filterString","_pendingTileUrls","_overlays","tileSize","Size","getTile","coord","ownerDocument","$container","$img","overlay","removePending","getTileUrl","appendTo","imgElement","releaseTile","zfactor","bot","bbox","collections","NameValueCollection","parms","UrlParams","layersParam","toQueryString","startsWith","sprintf","protocol","host","port","slash","PolygonManager","polygonsByLocType","VizApp","loadingDeferreds","loadPolygons","deferred","ajax","isSimplified","success","polygons","wktPolygon","polygon","MapUtil","wktToGooglePolygon","clonePolygon","Polygon","setPaths","getPaths","getPolygonByFips","onSuccessCallback","parsePolygon","paths","rings","trim","regExes","parenComma","ring","trimParens","getPolygonLatLngs","parseMultiPolygon","doubleParenComma","polyPaths","pairs","latLngs","LatLng","findPolygon","latLng","contains","getDataResponseOnChange","changed","getFilterString","filterStringNvc","indicator","timeFrame","locationType","dataFormat","characteristic","getDataParams","numBreaks","chartContainer","onAnimationCompleteCallback","labelWidth","bounds","LatLngBounds","getLength","getAt","inPoly","numPaths","numPoints","vertex1","vertex2","wgs84Coords","epsg3857Coords","typeStr","fromPositionToRelativePixels","gmap","worldXY","worldEdge","worldPosition","epsg3857ToWgs84","wgs84ToEpsg3857","googlePoint","matches","polygonManager","layers","currentMouseover","initializeMap","preLoadPolygons","drawSelectedRegion","setMap","mapOptions","mapTypeId","MapTypeId","ROADMAP","panControl","mapTypeControl","scaleControl","streetViewControl","overviewMapControl","zoomControlOptions","ControlPosition","RIGHT_CENTER","scrollwheel","featureType","elementType","stylers","lightness","weight","saturation","gmapLoading","Map","labelEngine","addListenerOnce","addListener","findAndDrawPolygon","selectRegion","takeScreenshot","addLoadingLabelsTask","updateLabelsTaskDone","triggerScreenshot","updateChoropleth","removeOverlayMarkers","setLabelTimeout","getOverlayLabels","labelClasslist","overlayTypeIds","hardcodedPositions","tokens","overlayType","noIcon","SymbolPath","CIRCLE","labelXOffset","labelAnchor","MarkerWithLabel","icon","labelClass","fail","err","overlayMapTypes","removeAt","choroplethOverlay","locTypeId","polygonInfo","removePrevious","debounceExploreMapClicks","dataLayer","eventCategory","eventAction","eventLabel","pathname","selectedPolygonInfo","innerPolygon","outerPolygon","$content","isClosed","removeClass","slideDown","slideUp","addClass","_index","radio","$hiddenRadio","radioVal","overlayVals","stopPropagation","overlayId","legendInfo","prepend","hidePopup","showPopup","swatchColor","dataPoint","ranges","minValue","maxValue","dp","findThemeColor","pixels","outerWidth","__super__","toggle","selectorNs","initializeView","updateDataSummary","initializeSelectors","allSelectors","breakdownSelectorView","BreakdownSelectorView","locationTypeSelectorView","LocationTypeSelectorView","dataTypeSelectorView","DataTypeSelectorView","getSelectorInfoFunc","getSelectorInfoOrThrow","timeFrameSelectorView","TimeFrameSelectorView","getIndicatorSpecificSelectors","getDataSummary","once"],"mappings":"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","file":"map-generated.js","sourcesContent":["// ==ClosureCompiler==\r\n// @compilation_level SIMPLE_OPTIMIZATIONS\r\n\r\n/**\r\n * @license Highcharts JS v2.3.5 (2012-12-19)\r\n *\r\n * (c) 2009-2012 Torstein Hønsi\r\n *\r\n * License: www.highcharts.com/license\r\n */\r\n\r\n// JSLint options:\r\n/*global Highcharts, document, window, navigator, setInterval, clearInterval, clearTimeout, setTimeout, location, jQuery, $, console */\r\n\r\n(function() {\r\n // encapsulated variables\r\n var UNDEFINED,\r\n doc = document,\r\n win = window,\r\n math = Math,\r\n mathRound = math.round,\r\n mathFloor = math.floor,\r\n mathCeil = math.ceil,\r\n mathMax = math.max,\r\n mathMin = math.min,\r\n mathAbs = math.abs,\r\n mathCos = math.cos,\r\n mathSin = math.sin,\r\n mathPI = math.PI,\r\n deg2rad = (mathPI * 2) / 360,\r\n // some variables\r\n userAgent = navigator.userAgent,\r\n isOpera = win.opera,\r\n isIE = /msie/i.test(userAgent) && !isOpera,\r\n docMode8 = doc.documentMode === 8,\r\n isWebKit = /AppleWebKit/.test(userAgent),\r\n isFirefox = /Firefox/.test(userAgent),\r\n isTouchDevice = /(Mobile|Android|Windows Phone)/.test(userAgent),\r\n SVG_NS = \"http://www.w3.org/2000/svg\",\r\n hasSVG =\r\n !!doc.createElementNS &&\r\n !!doc.createElementNS(SVG_NS, \"svg\").createSVGRect,\r\n hasBidiBug = isFirefox && parseInt(userAgent.split(\"Firefox/\")[1], 10) < 4, // issue #38\r\n useCanVG = !hasSVG && !isIE && !!doc.createElement(\"canvas\").getContext,\r\n Renderer,\r\n hasTouch = doc.documentElement.ontouchstart !== UNDEFINED,\r\n symbolSizes = {},\r\n idCounter = 0,\r\n garbageBin,\r\n defaultOptions,\r\n dateFormat, // function\r\n globalAnimation,\r\n pathAnim,\r\n timeUnits,\r\n noop = function() {},\r\n charts = [],\r\n // some constants for frequently used strings\r\n DIV = \"div\",\r\n ABSOLUTE = \"absolute\",\r\n RELATIVE = \"relative\",\r\n HIDDEN = \"hidden\",\r\n PREFIX = \"highcharts-\",\r\n VISIBLE = \"visible\",\r\n PX = \"px\",\r\n NONE = \"none\",\r\n M = \"M\",\r\n L = \"L\",\r\n /*\r\n * Empirical lowest possible opacities for TRACKER_FILL\r\n * IE6: 0.002\r\n * IE7: 0.002\r\n * IE8: 0.002\r\n * IE9: 0.00000000001 (unlimited)\r\n * IE10: 0.0001 (exporting only)\r\n * FF: 0.00000000001 (unlimited)\r\n * Chrome: 0.000001\r\n * Safari: 0.000001\r\n * Opera: 0.00000000001 (unlimited)\r\n */\r\n TRACKER_FILL = \"rgba(192,192,192,\" + (hasSVG ? 0.0001 : 0.002) + \")\", // invisible but clickable\r\n //TRACKER_FILL = 'rgba(192,192,192,0.5)',\r\n NORMAL_STATE = \"\",\r\n HOVER_STATE = \"hover\",\r\n SELECT_STATE = \"select\",\r\n MILLISECOND = \"millisecond\",\r\n SECOND = \"second\",\r\n MINUTE = \"minute\",\r\n HOUR = \"hour\",\r\n DAY = \"day\",\r\n WEEK = \"week\",\r\n MONTH = \"month\",\r\n YEAR = \"year\",\r\n // constants for attributes\r\n FILL = \"fill\",\r\n LINEAR_GRADIENT = \"linearGradient\",\r\n STOPS = \"stops\",\r\n STROKE = \"stroke\",\r\n STROKE_WIDTH = \"stroke-width\",\r\n // time methods, changed based on whether or not UTC is used\r\n makeTime,\r\n getMinutes,\r\n getHours,\r\n getDay,\r\n getDate,\r\n getMonth,\r\n getFullYear,\r\n setMinutes,\r\n setHours,\r\n setDate,\r\n setMonth,\r\n setFullYear,\r\n // lookup over the types and the associated classes\r\n seriesTypes = {};\r\n\r\n // The Highcharts namespace\r\n win.Highcharts = {};\r\n\r\n /**\r\n * Extend an object with the members of another\r\n * @param {Object} a The object to be extended\r\n * @param {Object} b The object to add to the first one\r\n */\r\n function extend(a, b) {\r\n var n;\r\n if (!a) {\r\n a = {};\r\n }\r\n for (n in b) {\r\n a[n] = b[n];\r\n }\r\n return a;\r\n }\r\n\r\n /**\r\n * Take an array and turn into a hash with even number arguments as keys and odd numbers as\r\n * values. Allows creating constants for commonly used style properties, attributes etc.\r\n * Avoid it in performance critical situations like looping\r\n */\r\n function hash() {\r\n var i = 0,\r\n args = arguments,\r\n length = args.length,\r\n obj = {};\r\n for (; i < length; i++) {\r\n obj[args[i++]] = args[i];\r\n }\r\n return obj;\r\n }\r\n\r\n /**\r\n * Shortcut for parseInt\r\n * @param {Object} s\r\n * @param {Number} mag Magnitude\r\n */\r\n function pInt(s, mag) {\r\n return parseInt(s, mag || 10);\r\n }\r\n\r\n /**\r\n * Check for string\r\n * @param {Object} s\r\n */\r\n function isString(s) {\r\n return typeof s === \"string\";\r\n }\r\n\r\n /**\r\n * Check for object\r\n * @param {Object} obj\r\n */\r\n function isObject(obj) {\r\n return typeof obj === \"object\";\r\n }\r\n\r\n /**\r\n * Check for array\r\n * @param {Object} obj\r\n */\r\n function isArray(obj) {\r\n return Object.prototype.toString.call(obj) === \"[object Array]\";\r\n }\r\n\r\n /**\r\n * Check for number\r\n * @param {Object} n\r\n */\r\n function isNumber(n) {\r\n return typeof n === \"number\";\r\n }\r\n\r\n function log2lin(num) {\r\n return math.log(num) / math.LN10;\r\n }\r\n function lin2log(num) {\r\n return math.pow(10, num);\r\n }\r\n\r\n /**\r\n * Remove last occurence of an item from an array\r\n * @param {Array} arr\r\n * @param {Mixed} item\r\n */\r\n function erase(arr, item) {\r\n var i = arr.length;\r\n while (i--) {\r\n if (arr[i] === item) {\r\n arr.splice(i, 1);\r\n break;\r\n }\r\n }\r\n //return arr;\r\n }\r\n\r\n /**\r\n * Returns true if the object is not null or undefined. Like MooTools' $.defined.\r\n * @param {Object} obj\r\n */\r\n function defined(obj) {\r\n return obj !== UNDEFINED && obj !== null;\r\n }\r\n\r\n /**\r\n * Set or get an attribute or an object of attributes. Can't use jQuery attr because\r\n * it attempts to set expando properties on the SVG element, which is not allowed.\r\n *\r\n * @param {Object} elem The DOM element to receive the attribute(s)\r\n * @param {String|Object} prop The property or an abject of key-value pairs\r\n * @param {String} value The value if a single property is set\r\n */\r\n function attr(elem, prop, value) {\r\n var key,\r\n setAttribute = \"setAttribute\",\r\n ret;\r\n\r\n // if the prop is a string\r\n if (isString(prop)) {\r\n // set the value\r\n if (defined(value)) {\r\n elem[setAttribute](prop, value);\r\n\r\n // get the value\r\n }\r\n else if (elem && elem.getAttribute) {\r\n // elem not defined when printing pie demo...\r\n ret = elem.getAttribute(prop);\r\n }\r\n\r\n // else if prop is defined, it is a hash of key/value pairs\r\n }\r\n else if (defined(prop) && isObject(prop)) {\r\n for (key in prop) {\r\n elem[setAttribute](key, prop[key]);\r\n }\r\n }\r\n return ret;\r\n }\r\n /**\r\n * Check if an element is an array, and if not, make it into an array. Like\r\n * MooTools' $.splat.\r\n */\r\n function splat(obj) {\r\n return isArray(obj) ? obj : [obj];\r\n }\r\n\r\n /**\r\n * Return the first value that is defined. Like MooTools' $.pick.\r\n */\r\n function pick() {\r\n var args = arguments,\r\n i,\r\n arg,\r\n length = args.length;\r\n for (i = 0; i < length; i++) {\r\n arg = args[i];\r\n if (typeof arg !== \"undefined\" && arg !== null) {\r\n return arg;\r\n }\r\n }\r\n }\r\n\r\n /**\r\n * Set CSS on a given element\r\n * @param {Object} el\r\n * @param {Object} styles Style object with camel case property names\r\n */\r\n function css(el, styles) {\r\n if (isIE) {\r\n if (styles && styles.opacity !== UNDEFINED) {\r\n styles.filter = \"alpha(opacity=\" + styles.opacity * 100 + \")\";\r\n }\r\n }\r\n extend(el.style, styles);\r\n }\r\n\r\n /**\r\n * Utility function to create element with attributes and styles\r\n * @param {Object} tag\r\n * @param {Object} attribs\r\n * @param {Object} styles\r\n * @param {Object} parent\r\n * @param {Object} nopad\r\n */\r\n function createElement(tag, attribs, styles, parent, nopad) {\r\n var el = doc.createElement(tag);\r\n if (attribs) {\r\n extend(el, attribs);\r\n }\r\n if (nopad) {\r\n css(el, { padding: 0, border: NONE, margin: 0 });\r\n }\r\n if (styles) {\r\n css(el, styles);\r\n }\r\n if (parent) {\r\n parent.appendChild(el);\r\n }\r\n return el;\r\n }\r\n\r\n /**\r\n * Extend a prototyped class by new members\r\n * @param {Object} parent\r\n * @param {Object} members\r\n */\r\n function extendClass(parent, members) {\r\n var object = function() {};\r\n object.prototype = new parent();\r\n extend(object.prototype, members);\r\n return object;\r\n }\r\n\r\n /**\r\n * How many decimals are there in a number\r\n */\r\n function getDecimals(number) {\r\n number = (number || 0).toString();\r\n\r\n return number.indexOf(\".\") > -1 ? number.split(\".\")[1].length : 0;\r\n }\r\n\r\n /**\r\n * Format a number and return a string based on input settings\r\n * @param {Number} number The input number to format\r\n * @param {Number} decimals The amount of decimals\r\n * @param {String} decPoint The decimal point, defaults to the one given in the lang options\r\n * @param {String} thousandsSep The thousands separator, defaults to the one given in the lang options\r\n */\r\n function numberFormat(number, decimals, decPoint, thousandsSep) {\r\n var lang = defaultOptions.lang,\r\n // http://kevin.vanzonneveld.net/techblog/article/javascript_equivalent_for_phps_number_format/\r\n n = number,\r\n c =\r\n decimals === -1\r\n ? getDecimals(number)\r\n : isNaN((decimals = mathAbs(decimals)))\r\n ? 2\r\n : decimals,\r\n d = decPoint === undefined ? lang.decimalPoint : decPoint,\r\n t = thousandsSep === undefined ? lang.thousandsSep : thousandsSep,\r\n s = n < 0 ? \"-\" : \"\",\r\n i = String(pInt((n = mathAbs(+n || 0).toFixed(c)))),\r\n j = i.length > 3 ? i.length % 3 : 0;\r\n\r\n return (\r\n s +\r\n (j ? i.substr(0, j) + t : \"\") +\r\n i.substr(j).replace(/(\\d{3})(?=\\d)/g, \"$1\" + t) +\r\n (c\r\n ? d +\r\n mathAbs(n - i)\r\n .toFixed(c)\r\n .slice(2)\r\n : \"\")\r\n );\r\n }\r\n\r\n /**\r\n * Pad a string to a given length by adding 0 to the beginning\r\n * @param {Number} number\r\n * @param {Number} length\r\n */\r\n function pad(number, length) {\r\n // Create an array of the remaining length +1 and join it with 0's\r\n return (\r\n new Array((length || 2) + 1 - String(number).length).join(0) + number\r\n );\r\n }\r\n\r\n /**\r\n * Wrap a method with extended functionality, preserving the original function\r\n * @param {Object} obj The context object that the method belongs to\r\n * @param {String} method The name of the method to extend\r\n * @param {Function} func A wrapper function callback. This function is called with the same arguments\r\n * as the original function, except that the original function is unshifted and passed as the first\r\n * argument.\r\n */\r\n function wrap(obj, method, func) {\r\n var proceed = obj[method];\r\n obj[method] = function() {\r\n var args = Array.prototype.slice.call(arguments);\r\n args.unshift(proceed);\r\n return func.apply(this, args);\r\n };\r\n }\r\n\r\n /**\r\n * Based on http://www.php.net/manual/en/function.strftime.php\r\n * @param {String} format\r\n * @param {Number} timestamp\r\n * @param {Boolean} capitalize\r\n */\r\n dateFormat = function(format, timestamp, capitalize) {\r\n if (!defined(timestamp) || isNaN(timestamp)) {\r\n return \"Invalid date\";\r\n }\r\n format = pick(format, \"%Y-%m-%d %H:%M:%S\");\r\n\r\n var date = new Date(timestamp),\r\n key, // used in for constuct below\r\n // get the basic time values\r\n hours = date[getHours](),\r\n day = date[getDay](),\r\n dayOfMonth = date[getDate](),\r\n month = date[getMonth](),\r\n fullYear = date[getFullYear](),\r\n lang = defaultOptions.lang,\r\n langWeekdays = lang.weekdays,\r\n /* // uncomment this and the 'W' format key below to enable week numbers\r\n\t\tweekNumber = function () {\r\n\t\t\tvar clone = new Date(date.valueOf()),\r\n\t\t\t\tday = clone[getDay]() == 0 ? 7 : clone[getDay](),\r\n\t\t\t\tdayNumber;\r\n\t\t\tclone.setDate(clone[getDate]() + 4 - day);\r\n\t\t\tdayNumber = mathFloor((clone.getTime() - new Date(clone[getFullYear](), 0, 1, -6)) / 86400000);\r\n\t\t\treturn 1 + mathFloor(dayNumber / 7);\r\n\t\t},\r\n\t\t*/\r\n\r\n // list all format keys\r\n replacements = {\r\n // Day\r\n a: langWeekdays[day].substr(0, 3), // Short weekday, like 'Mon'\r\n A: langWeekdays[day], // Long weekday, like 'Monday'\r\n d: pad(dayOfMonth), // Two digit day of the month, 01 to 31\r\n e: dayOfMonth, // Day of the month, 1 through 31\r\n\r\n // Week (none implemented)\r\n //'W': weekNumber(),\r\n\r\n // Month\r\n b: lang.shortMonths[month], // Short month, like 'Jan'\r\n B: lang.months[month], // Long month, like 'January'\r\n m: pad(month + 1), // Two digit month number, 01 through 12\r\n\r\n // Year\r\n y: fullYear.toString().substr(2, 2), // Two digits year, like 09 for 2009\r\n Y: fullYear, // Four digits year, like 2009\r\n\r\n // Time\r\n H: pad(hours), // Two digits hours in 24h format, 00 through 23\r\n I: pad(hours % 12 || 12), // Two digits hours in 12h format, 00 through 11\r\n l: hours % 12 || 12, // Hours in 12h format, 1 through 12\r\n M: pad(date[getMinutes]()), // Two digits minutes, 00 through 59\r\n p: hours < 12 ? \"AM\" : \"PM\", // Upper case AM or PM\r\n P: hours < 12 ? \"am\" : \"pm\", // Lower case AM or PM\r\n S: pad(date.getSeconds()), // Two digits seconds, 00 through 59\r\n L: pad(mathRound(timestamp % 1000), 3) // Milliseconds (naming from Ruby)\r\n };\r\n\r\n // do the replaces\r\n for (key in replacements) {\r\n while (format.indexOf(\"%\" + key) !== -1) {\r\n // regex would do it in one line, but this is faster\r\n format = format.replace(\"%\" + key, replacements[key]);\r\n }\r\n }\r\n\r\n // Optionally capitalize the string and return\r\n return capitalize\r\n ? format.substr(0, 1).toUpperCase() + format.substr(1)\r\n : format;\r\n };\r\n\r\n /**\r\n * Take an interval and normalize it to multiples of 1, 2, 2.5 and 5\r\n * @param {Number} interval\r\n * @param {Array} multiples\r\n * @param {Number} magnitude\r\n * @param {Object} options\r\n */\r\n function normalizeTickInterval(interval, multiples, magnitude, options) {\r\n var normalized, i;\r\n\r\n // round to a tenfold of 1, 2, 2.5 or 5\r\n magnitude = pick(magnitude, 1);\r\n normalized = interval / magnitude;\r\n\r\n // multiples for a linear scale\r\n if (!multiples) {\r\n multiples = [1, 2, 2.5, 5, 10];\r\n\r\n // the allowDecimals option\r\n if (options && options.allowDecimals === false) {\r\n if (magnitude === 1) {\r\n multiples = [1, 2, 5, 10];\r\n }\r\n else if (magnitude <= 0.1) {\r\n multiples = [1 / magnitude];\r\n }\r\n }\r\n }\r\n\r\n // normalize the interval to the nearest multiple\r\n for (i = 0; i < multiples.length; i++) {\r\n interval = multiples[i];\r\n if (\r\n normalized <=\r\n (multiples[i] + (multiples[i + 1] || multiples[i])) / 2\r\n ) {\r\n break;\r\n }\r\n }\r\n\r\n // multiply back to the correct magnitude\r\n interval *= magnitude;\r\n\r\n return interval;\r\n }\r\n\r\n /**\r\n * Get a normalized tick interval for dates. Returns a configuration object with\r\n * unit range (interval), count and name. Used to prepare data for getTimeTicks.\r\n * Previously this logic was part of getTimeTicks, but as getTimeTicks now runs\r\n * of segments in stock charts, the normalizing logic was extracted in order to\r\n * prevent it for running over again for each segment having the same interval.\r\n * #662, #697.\r\n */\r\n function normalizeTimeTickInterval(tickInterval, unitsOption) {\r\n var units = unitsOption || [\r\n [\r\n MILLISECOND, // unit name\r\n [1, 2, 5, 10, 20, 25, 50, 100, 200, 500] // allowed multiples\r\n ],\r\n [SECOND, [1, 2, 5, 10, 15, 30]],\r\n [MINUTE, [1, 2, 5, 10, 15, 30]],\r\n [HOUR, [1, 2, 3, 4, 6, 8, 12]],\r\n [DAY, [1, 2]],\r\n [WEEK, [1, 2]],\r\n [MONTH, [1, 2, 3, 4, 6]],\r\n [YEAR, null]\r\n ],\r\n unit = units[units.length - 1], // default unit is years\r\n interval = timeUnits[unit[0]],\r\n multiples = unit[1],\r\n count,\r\n i;\r\n\r\n // loop through the units to find the one that best fits the tickInterval\r\n for (i = 0; i < units.length; i++) {\r\n unit = units[i];\r\n interval = timeUnits[unit[0]];\r\n multiples = unit[1];\r\n\r\n if (units[i + 1]) {\r\n // lessThan is in the middle between the highest multiple and the next unit.\r\n var lessThan =\r\n (interval * multiples[multiples.length - 1] +\r\n timeUnits[units[i + 1][0]]) /\r\n 2;\r\n\r\n // break and keep the current unit\r\n if (tickInterval <= lessThan) {\r\n break;\r\n }\r\n }\r\n }\r\n\r\n // prevent 2.5 years intervals, though 25, 250 etc. are allowed\r\n if (interval === timeUnits[YEAR] && tickInterval < 5 * interval) {\r\n multiples = [1, 2, 5];\r\n }\r\n\r\n // prevent 2.5 years intervals, though 25, 250 etc. are allowed\r\n if (interval === timeUnits[YEAR] && tickInterval < 5 * interval) {\r\n multiples = [1, 2, 5];\r\n }\r\n\r\n // get the count\r\n count = normalizeTickInterval(tickInterval / interval, multiples);\r\n\r\n return {\r\n unitRange: interval,\r\n count: count,\r\n unitName: unit[0]\r\n };\r\n }\r\n\r\n /**\r\n * Set the tick positions to a time unit that makes sense, for example\r\n * on the first of each month or on every Monday. Return an array\r\n * with the time positions. Used in datetime axes as well as for grouping\r\n * data on a datetime axis.\r\n *\r\n * @param {Object} normalizedInterval The interval in axis values (ms) and the count\r\n * @param {Number} min The minimum in axis values\r\n * @param {Number} max The maximum in axis values\r\n * @param {Number} startOfWeek\r\n */\r\n function getTimeTicks(normalizedInterval, min, max, startOfWeek) {\r\n var tickPositions = [],\r\n i,\r\n higherRanks = {},\r\n useUTC = defaultOptions.global.useUTC,\r\n minYear, // used in months and years as a basis for Date.UTC()\r\n minDate = new Date(min),\r\n interval = normalizedInterval.unitRange,\r\n count = normalizedInterval.count;\r\n\r\n if (defined(min)) {\r\n // #1300\r\n if (interval >= timeUnits[SECOND]) {\r\n // second\r\n minDate.setMilliseconds(0);\r\n minDate.setSeconds(\r\n interval >= timeUnits[MINUTE]\r\n ? 0\r\n : count * mathFloor(minDate.getSeconds() / count)\r\n );\r\n }\r\n\r\n if (interval >= timeUnits[MINUTE]) {\r\n // minute\r\n minDate[setMinutes](\r\n interval >= timeUnits[HOUR]\r\n ? 0\r\n : count * mathFloor(minDate[getMinutes]() / count)\r\n );\r\n }\r\n\r\n if (interval >= timeUnits[HOUR]) {\r\n // hour\r\n minDate[setHours](\r\n interval >= timeUnits[DAY]\r\n ? 0\r\n : count * mathFloor(minDate[getHours]() / count)\r\n );\r\n }\r\n\r\n if (interval >= timeUnits[DAY]) {\r\n // day\r\n minDate[setDate](\r\n interval >= timeUnits[MONTH]\r\n ? 1\r\n : count * mathFloor(minDate[getDate]() / count)\r\n );\r\n }\r\n\r\n if (interval >= timeUnits[MONTH]) {\r\n // month\r\n minDate[setMonth](\r\n interval >= timeUnits[YEAR]\r\n ? 0\r\n : count * mathFloor(minDate[getMonth]() / count)\r\n );\r\n minYear = minDate[getFullYear]();\r\n }\r\n\r\n if (interval >= timeUnits[YEAR]) {\r\n // year\r\n minYear -= minYear % count;\r\n minDate[setFullYear](minYear);\r\n }\r\n\r\n // week is a special case that runs outside the hierarchy\r\n if (interval === timeUnits[WEEK]) {\r\n // get start of current week, independent of count\r\n minDate[setDate](\r\n minDate[getDate]() - minDate[getDay]() + pick(startOfWeek, 1)\r\n );\r\n }\r\n\r\n // get tick positions\r\n i = 1;\r\n minYear = minDate[getFullYear]();\r\n var time = minDate.getTime(),\r\n minMonth = minDate[getMonth](),\r\n minDateDate = minDate[getDate](),\r\n timezoneOffset = useUTC\r\n ? 0\r\n : (24 * 3600 * 1000 + minDate.getTimezoneOffset() * 60 * 1000) %\r\n (24 * 3600 * 1000); // #950\r\n\r\n // iterate and add tick positions at appropriate values\r\n while (time < max) {\r\n tickPositions.push(time);\r\n\r\n // if the interval is years, use Date.UTC to increase years\r\n if (interval === timeUnits[YEAR]) {\r\n time = makeTime(minYear + i * count, 0);\r\n\r\n // if the interval is months, use Date.UTC to increase months\r\n }\r\n else if (interval === timeUnits[MONTH]) {\r\n time = makeTime(minYear, minMonth + i * count);\r\n\r\n // if we're using global time, the interval is not fixed as it jumps\r\n // one hour at the DST crossover\r\n }\r\n else if (\r\n !useUTC &&\r\n (interval === timeUnits[DAY] || interval === timeUnits[WEEK])\r\n ) {\r\n time = makeTime(\r\n minYear,\r\n minMonth,\r\n minDateDate + i * count * (interval === timeUnits[DAY] ? 1 : 7)\r\n );\r\n\r\n // else, the interval is fixed and we use simple addition\r\n }\r\n else {\r\n time += interval * count;\r\n\r\n // mark new days if the time is dividable by day\r\n if (\r\n interval <= timeUnits[HOUR] &&\r\n time % timeUnits[DAY] === timezoneOffset\r\n ) {\r\n higherRanks[time] = DAY;\r\n }\r\n }\r\n\r\n i++;\r\n }\r\n\r\n // push the last time\r\n tickPositions.push(time);\r\n }\r\n\r\n // record information on the chosen unit - for dynamic label formatter\r\n tickPositions.info = extend(normalizedInterval, {\r\n higherRanks: higherRanks,\r\n totalRange: interval * count\r\n });\r\n\r\n return tickPositions;\r\n }\r\n\r\n /**\r\n * Helper class that contains variuos counters that are local to the chart.\r\n */\r\n function ChartCounters() {\r\n this.color = 0;\r\n this.symbol = 0;\r\n }\r\n\r\n ChartCounters.prototype = {\r\n /**\r\n * Wraps the color counter if it reaches the specified length.\r\n */\r\n wrapColor: function(length) {\r\n if (this.color >= length) {\r\n this.color = 0;\r\n }\r\n },\r\n\r\n /**\r\n * Wraps the symbol counter if it reaches the specified length.\r\n */\r\n wrapSymbol: function(length) {\r\n if (this.symbol >= length) {\r\n this.symbol = 0;\r\n }\r\n }\r\n };\r\n\r\n /**\r\n * Utility method that sorts an object array and keeping the order of equal items.\r\n * ECMA script standard does not specify the behaviour when items are equal.\r\n */\r\n function stableSort(arr, sortFunction) {\r\n var length = arr.length,\r\n sortValue,\r\n i;\r\n\r\n // Add index to each item\r\n for (i = 0; i < length; i++) {\r\n arr[i].ss_i = i; // stable sort index\r\n }\r\n\r\n arr.sort(function(a, b) {\r\n sortValue = sortFunction(a, b);\r\n return sortValue === 0 ? a.ss_i - b.ss_i : sortValue;\r\n });\r\n\r\n // Remove index from items\r\n for (i = 0; i < length; i++) {\r\n delete arr[i].ss_i; // stable sort index\r\n }\r\n }\r\n\r\n /**\r\n * Non-recursive method to find the lowest member of an array. Math.min raises a maximum\r\n * call stack size exceeded error in Chrome when trying to apply more than 150.000 points. This\r\n * method is slightly slower, but safe.\r\n */\r\n function arrayMin(data) {\r\n var i = data.length,\r\n min = data[0];\r\n\r\n while (i--) {\r\n if (data[i] < min) {\r\n min = data[i];\r\n }\r\n }\r\n return min;\r\n }\r\n\r\n /**\r\n * Non-recursive method to find the lowest member of an array. Math.min raises a maximum\r\n * call stack size exceeded error in Chrome when trying to apply more than 150.000 points. This\r\n * method is slightly slower, but safe.\r\n */\r\n function arrayMax(data) {\r\n var i = data.length,\r\n max = data[0];\r\n\r\n while (i--) {\r\n if (data[i] > max) {\r\n max = data[i];\r\n }\r\n }\r\n return max;\r\n }\r\n\r\n /**\r\n * Utility method that destroys any SVGElement or VMLElement that are properties on the given object.\r\n * It loops all properties and invokes destroy if there is a destroy method. The property is\r\n * then delete'ed.\r\n * @param {Object} The object to destroy properties on\r\n * @param {Object} Exception, do not destroy this property, only delete it.\r\n */\r\n function destroyObjectProperties(obj, except) {\r\n var n;\r\n for (n in obj) {\r\n // If the object is non-null and destroy is defined\r\n if (obj[n] && obj[n] !== except && obj[n].destroy) {\r\n // Invoke the destroy\r\n obj[n].destroy();\r\n }\r\n\r\n // Delete the property from the object.\r\n delete obj[n];\r\n }\r\n }\r\n\r\n /**\r\n * Discard an element by moving it to the bin and delete\r\n * @param {Object} The HTML node to discard\r\n */\r\n function discardElement(element) {\r\n // create a garbage bin element, not part of the DOM\r\n if (!garbageBin) {\r\n garbageBin = createElement(DIV);\r\n }\r\n\r\n // move the node and empty bin\r\n if (element) {\r\n garbageBin.appendChild(element);\r\n }\r\n garbageBin.innerHTML = \"\";\r\n }\r\n\r\n /**\r\n * Provide error messages for debugging, with links to online explanation\r\n */\r\n function error(code, stop) {\r\n var msg =\r\n \"Highcharts error #\" + code + \": www.highcharts.com/errors/\" + code;\r\n if (stop) {\r\n throw msg;\r\n }\r\n else if (win.console) {\r\n console.log(msg);\r\n }\r\n }\r\n\r\n /**\r\n * Fix JS round off float errors\r\n * @param {Number} num\r\n */\r\n function correctFloat(num) {\r\n return parseFloat(num.toPrecision(14));\r\n }\r\n\r\n /**\r\n * Set the global animation to either a given value, or fall back to the\r\n * given chart's animation option\r\n * @param {Object} animation\r\n * @param {Object} chart\r\n */\r\n function setAnimation(animation, chart) {\r\n globalAnimation = pick(animation, chart.animation);\r\n }\r\n\r\n /**\r\n * The time unit lookup\r\n */\r\n /*jslint white: true*/\r\n timeUnits = hash(\r\n MILLISECOND,\r\n 1,\r\n SECOND,\r\n 1000,\r\n MINUTE,\r\n 60000,\r\n HOUR,\r\n 3600000,\r\n DAY,\r\n 24 * 3600000,\r\n WEEK,\r\n 7 * 24 * 3600000,\r\n MONTH,\r\n 31 * 24 * 3600000,\r\n YEAR,\r\n 31556952000\r\n );\r\n /*jslint white: false*/\r\n /**\r\n * Path interpolation algorithm used across adapters\r\n */\r\n pathAnim = {\r\n /**\r\n * Prepare start and end values so that the path can be animated one to one\r\n */\r\n init: function(elem, fromD, toD) {\r\n fromD = fromD || \"\";\r\n var shift = elem.shift,\r\n bezier = fromD.indexOf(\"C\") > -1,\r\n numParams = bezier ? 7 : 3,\r\n endLength,\r\n slice,\r\n i,\r\n start = fromD.split(\" \"),\r\n end = [].concat(toD), // copy\r\n startBaseLine,\r\n endBaseLine,\r\n sixify = function(arr) {\r\n // in splines make move points have six parameters like bezier curves\r\n i = arr.length;\r\n while (i--) {\r\n if (arr[i] === M) {\r\n arr.splice(\r\n i + 1,\r\n 0,\r\n arr[i + 1],\r\n arr[i + 2],\r\n arr[i + 1],\r\n arr[i + 2]\r\n );\r\n }\r\n }\r\n };\r\n\r\n if (bezier) {\r\n sixify(start);\r\n sixify(end);\r\n }\r\n\r\n // pull out the base lines before padding\r\n if (elem.isArea) {\r\n startBaseLine = start.splice(start.length - 6, 6);\r\n endBaseLine = end.splice(end.length - 6, 6);\r\n }\r\n\r\n // if shifting points, prepend a dummy point to the end path\r\n if (shift <= end.length / numParams) {\r\n while (shift--) {\r\n end = []\r\n .concat(end)\r\n .splice(0, numParams)\r\n .concat(end);\r\n }\r\n }\r\n elem.shift = 0; // reset for following animations\r\n\r\n // copy and append last point until the length matches the end length\r\n if (start.length) {\r\n endLength = end.length;\r\n while (start.length < endLength) {\r\n //bezier && sixify(start);\r\n slice = [].concat(start).splice(start.length - numParams, numParams);\r\n if (bezier) {\r\n // disable first control point\r\n slice[numParams - 6] = slice[numParams - 2];\r\n slice[numParams - 5] = slice[numParams - 1];\r\n }\r\n start = start.concat(slice);\r\n }\r\n }\r\n\r\n if (startBaseLine) {\r\n // append the base lines for areas\r\n start = start.concat(startBaseLine);\r\n end = end.concat(endBaseLine);\r\n }\r\n return [start, end];\r\n },\r\n\r\n /**\r\n * Interpolate each value of the path and return the array\r\n */\r\n step: function(start, end, pos, complete) {\r\n var ret = [],\r\n i = start.length,\r\n startVal;\r\n\r\n if (pos === 1) {\r\n // land on the final path without adjustment points appended in the ends\r\n ret = complete;\r\n }\r\n else if (i === end.length && pos < 1) {\r\n while (i--) {\r\n startVal = parseFloat(start[i]);\r\n ret[i] = isNaN(startVal) // a letter instruction like M or L\r\n ? start[i]\r\n : pos * parseFloat(end[i] - startVal) + startVal;\r\n }\r\n }\r\n else {\r\n // if animation is finished or length not matching, land on right value\r\n ret = end;\r\n }\r\n return ret;\r\n }\r\n };\r\n\r\n (function($) {\r\n /**\r\n * The default HighchartsAdapter for jQuery\r\n */\r\n win.HighchartsAdapter =\r\n win.HighchartsAdapter ||\r\n ($ && {\r\n /**\r\n * Initialize the adapter by applying some extensions to jQuery\r\n */\r\n init: function(pathAnim) {\r\n // extend the animate function to allow SVG animations\r\n var Fx = $.fx,\r\n Step = Fx.step,\r\n dSetter,\r\n Tween = $.Tween,\r\n propHooks =\r\n Tween &&\r\n Tween.propHooks; /* allow unused param x in this function */\r\n\r\n /*jslint unparam: true*/ $.extend($.easing, {\r\n easeOutQuad: function(x, t, b, c, d) {\r\n return -c * (t /= d) * (t - 2) + b;\r\n }\r\n });\r\n /*jslint unparam: false*/\r\n\r\n // extend some methods to check for elem.attr, which means it is a Highcharts SVG object\r\n $.each([\"cur\", \"_default\", \"width\", \"height\"], function(i, fn) {\r\n var obj = Step,\r\n base,\r\n elem;\r\n\r\n // Handle different parent objects\r\n if (fn === \"cur\") {\r\n obj = Fx.prototype; // 'cur', the getter, relates to Fx.prototype\r\n }\r\n else if (fn === \"_default\" && Tween) {\r\n // jQuery 1.8 model\r\n obj = propHooks[fn];\r\n fn = \"set\";\r\n }\r\n\r\n // Overwrite the method\r\n base = obj[fn];\r\n if (base) {\r\n // step.width and step.height don't exist in jQuery < 1.7\r\n\r\n // create the extended function replacement\r\n obj[fn] = function(fx) {\r\n // Fx.prototype.cur does not use fx argument\r\n fx = i ? fx : this;\r\n\r\n // shortcut\r\n elem = fx.elem;\r\n\r\n // Fx.prototype.cur returns the current value. The other ones are setters\r\n // and returning a value has no effect.\r\n return elem.attr // is SVG element wrapper\r\n ? elem.attr(fx.prop, fn === \"cur\" ? UNDEFINED : fx.now) // apply the SVG wrapper's method\r\n : base.apply(this, arguments); // use jQuery's built-in method\r\n };\r\n }\r\n });\r\n\r\n // Define the setter function for d (path definitions)\r\n dSetter = function(fx) {\r\n var elem = fx.elem,\r\n ends;\r\n\r\n // Normally start and end should be set in state == 0, but sometimes,\r\n // for reasons unknown, this doesn't happen. Perhaps state == 0 is skipped\r\n // in these cases\r\n if (!fx.started) {\r\n ends = pathAnim.init(elem, elem.d, elem.toD);\r\n fx.start = ends[0];\r\n fx.end = ends[1];\r\n fx.started = true;\r\n }\r\n\r\n // interpolate each value of the path\r\n elem.attr(\"d\", pathAnim.step(fx.start, fx.end, fx.pos, elem.toD));\r\n };\r\n\r\n // jQuery 1.8 style\r\n if (Tween) {\r\n propHooks.d = {\r\n set: dSetter\r\n };\r\n // pre 1.8\r\n }\r\n else {\r\n // animate paths\r\n Step.d = dSetter;\r\n }\r\n\r\n /**\r\n * Utility for iterating over an array. Parameters are reversed compared to jQuery.\r\n * @param {Array} arr\r\n * @param {Function} fn\r\n */\r\n this.each = Array.prototype.forEach\r\n ? function(arr, fn) {\r\n // modern browsers\r\n return Array.prototype.forEach.call(arr, fn);\r\n }\r\n : function(arr, fn) {\r\n // legacy\r\n var i = 0,\r\n len = arr.length;\r\n for (; i < len; i++) {\r\n if (fn.call(arr[i], arr[i], i, arr) === false) {\r\n return i;\r\n }\r\n }\r\n };\r\n\r\n // Register Highcharts as a jQuery plugin\r\n // TODO: MooTools and prototype as well?\r\n // TODO: StockChart\r\n /*$.fn.highcharts = function(options, callback) {\r\n\t\t options.chart = merge(options.chart, { renderTo: this[0] });\r\n\t\t this.chart = new Chart(options, callback);\r\n\t\t return this;\r\n\t\t };*/\r\n },\r\n\r\n /**\r\n * Downloads a script and executes a callback when done.\r\n * @param {String} scriptLocation\r\n * @param {Function} callback\r\n */\r\n getScript: $.getScript,\r\n\r\n /**\r\n * Return the index of an item in an array, or -1 if not found\r\n */\r\n inArray: $.inArray,\r\n\r\n /**\r\n * A direct link to jQuery methods. MooTools and Prototype adapters must be implemented for each case of method.\r\n * @param {Object} elem The HTML element\r\n * @param {String} method Which method to run on the wrapped element\r\n */\r\n adapterRun: function(elem, method) {\r\n return $(elem)[method]();\r\n },\r\n\r\n /**\r\n * Filter an array\r\n */\r\n grep: $.grep,\r\n\r\n /**\r\n * Map an array\r\n * @param {Array} arr\r\n * @param {Function} fn\r\n */\r\n map: function(arr, fn) {\r\n //return jQuery.map(arr, fn);\r\n var results = [],\r\n i = 0,\r\n len = arr.length;\r\n for (; i < len; i++) {\r\n results[i] = fn.call(arr[i], arr[i], i, arr);\r\n }\r\n return results;\r\n },\r\n\r\n /**\r\n * Deep merge two objects and return a third object\r\n */\r\n merge: function() {\r\n var args = arguments;\r\n return $.extend(true, null, args[0], args[1], args[2], args[3]);\r\n },\r\n\r\n /**\r\n * Get the position of an element relative to the top left of the page\r\n */\r\n offset: function(el) {\r\n return $(el).offset();\r\n },\r\n\r\n /**\r\n * Add an event listener\r\n * @param {Object} el A HTML element or custom object\r\n * @param {String} event The event type\r\n * @param {Function} fn The event handler\r\n */\r\n addEvent: function(el, event, fn) {\r\n $(el).bind(event, fn);\r\n },\r\n\r\n /**\r\n * Remove event added with addEvent\r\n * @param {Object} el The object\r\n * @param {String} eventType The event type. Leave blank to remove all events.\r\n * @param {Function} handler The function to remove\r\n */\r\n removeEvent: function(el, eventType, handler) {\r\n // workaround for jQuery issue with unbinding custom events:\r\n // http://forum.jQuery.com/topic/javascript-error-when-unbinding-a-custom-event-using-jQuery-1-4-2\r\n var func = doc.removeEventListener\r\n ? \"removeEventListener\"\r\n : \"detachEvent\";\r\n if (doc[func] && !el[func]) {\r\n el[func] = function() {};\r\n }\r\n\r\n $(el).unbind(eventType, handler);\r\n },\r\n\r\n /**\r\n * Fire an event on a custom object\r\n * @param {Object} el\r\n * @param {String} type\r\n * @param {Object} eventArguments\r\n * @param {Function} defaultFunction\r\n */\r\n fireEvent: function(el, type, eventArguments, defaultFunction) {\r\n var event = $.Event(type),\r\n detachedType = \"detached\" + type,\r\n defaultPrevented;\r\n\r\n // Remove warnings in Chrome when accessing layerX and layerY. Although Highcharts\r\n // never uses these properties, Chrome includes them in the default click event and\r\n // raises the warning when they are copied over in the extend statement below.\r\n //\r\n // To avoid problems in IE (see #1010) where we cannot delete the properties and avoid\r\n // testing if they are there (warning in chrome) the only option is to test if running IE.\r\n if (!isIE && eventArguments) {\r\n delete eventArguments.layerX;\r\n delete eventArguments.layerY;\r\n }\r\n\r\n extend(event, eventArguments);\r\n\r\n // Prevent jQuery from triggering the object method that is named the\r\n // same as the event. For example, if the event is 'select', jQuery\r\n // attempts calling el.select and it goes into a loop.\r\n if (el[type]) {\r\n el[detachedType] = el[type];\r\n el[type] = null;\r\n }\r\n\r\n // Wrap preventDefault and stopPropagation in try/catch blocks in\r\n // order to prevent JS errors when cancelling events on non-DOM\r\n // objects. #615.\r\n /*jslint unparam: true*/\r\n $.each([\"preventDefault\", \"stopPropagation\"], function(i, fn) {\r\n var base = event[fn];\r\n event[fn] = function() {\r\n try {\r\n base.call(event);\r\n }\r\n catch (e) {\r\n if (fn === \"preventDefault\") {\r\n defaultPrevented = true;\r\n }\r\n }\r\n };\r\n });\r\n /*jslint unparam: false*/\r\n\r\n // trigger it\r\n $(el).trigger(event);\r\n\r\n // attach the method\r\n if (el[detachedType]) {\r\n el[type] = el[detachedType];\r\n el[detachedType] = null;\r\n }\r\n\r\n if (\r\n defaultFunction &&\r\n !event.isDefaultPrevented() &&\r\n !defaultPrevented\r\n ) {\r\n defaultFunction(event);\r\n }\r\n },\r\n\r\n /**\r\n * Extension method needed for MooTools\r\n */\r\n washMouseEvent: function(e) {\r\n var ret = e.originalEvent || e;\r\n\r\n // computed by jQuery, needed by IE8\r\n if (ret.pageX === UNDEFINED) {\r\n // #1236\r\n ret.pageX = e.pageX;\r\n ret.pageY = e.pageY;\r\n }\r\n\r\n return ret;\r\n },\r\n\r\n /**\r\n * Animate a HTML element or SVG element wrapper\r\n * @param {Object} el\r\n * @param {Object} params\r\n * @param {Object} options jQuery-like animation options: duration, easing, callback\r\n */\r\n animate: function(el, params, options) {\r\n var $el = $(el);\r\n if (params.d) {\r\n el.toD = params.d; // keep the array form for paths, used in $.fx.step.d\r\n params.d = 1; // because in jQuery, animating to an array has a different meaning\r\n }\r\n\r\n $el.stop();\r\n $el.animate(params, options);\r\n },\r\n /**\r\n * Stop running animation\r\n */\r\n stop: function(el) {\r\n $(el).stop();\r\n }\r\n });\r\n })(win.jQuery);\r\n\r\n // check for a custom HighchartsAdapter defined prior to this file\r\n var globalAdapter = win.HighchartsAdapter,\r\n adapter = globalAdapter || {};\r\n\r\n // Initialize the adapter\r\n if (globalAdapter) {\r\n globalAdapter.init.call(globalAdapter, pathAnim);\r\n }\r\n\r\n // Utility functions. If the HighchartsAdapter is not defined, adapter is an empty object\r\n // and all the utility functions will be null. In that case they are populated by the\r\n // default adapters below.\r\n var adapterRun = adapter.adapterRun,\r\n getScript = adapter.getScript,\r\n inArray = adapter.inArray,\r\n each = adapter.each,\r\n grep = adapter.grep,\r\n offset = adapter.offset,\r\n map = adapter.map,\r\n merge = adapter.merge,\r\n addEvent = adapter.addEvent,\r\n removeEvent = adapter.removeEvent,\r\n fireEvent = adapter.fireEvent,\r\n washMouseEvent = adapter.washMouseEvent,\r\n animate = adapter.animate,\r\n stop = adapter.stop;\r\n\r\n /* ****************************************************************************\r\n * Handle the options *\r\n *****************************************************************************/\r\n var defaultLabelOptions = {\r\n enabled: true,\r\n // rotation: 0,\r\n align: \"center\",\r\n x: 0,\r\n y: 15,\r\n /*formatter: function () {\r\n\t\treturn this.value;\r\n\t},*/\r\n style: {\r\n color: \"#666\",\r\n fontSize: \"11px\",\r\n lineHeight: \"14px\"\r\n }\r\n };\r\n\r\n defaultOptions = {\r\n colors: [\r\n \"#4572A7\",\r\n \"#AA4643\",\r\n \"#89A54E\",\r\n \"#80699B\",\r\n \"#3D96AE\",\r\n \"#DB843D\",\r\n \"#92A8CD\",\r\n \"#A47D7C\",\r\n \"#B5CA92\"\r\n ],\r\n symbols: [\"circle\", \"diamond\", \"square\", \"triangle\", \"triangle-down\"],\r\n lang: {\r\n loading: \"Loading...\",\r\n months: [\r\n \"January\",\r\n \"February\",\r\n \"March\",\r\n \"April\",\r\n \"May\",\r\n \"June\",\r\n \"July\",\r\n \"August\",\r\n \"September\",\r\n \"October\",\r\n \"November\",\r\n \"December\"\r\n ],\r\n shortMonths: [\r\n \"Jan\",\r\n \"Feb\",\r\n \"Mar\",\r\n \"Apr\",\r\n \"May\",\r\n \"Jun\",\r\n \"Jul\",\r\n \"Aug\",\r\n \"Sep\",\r\n \"Oct\",\r\n \"Nov\",\r\n \"Dec\"\r\n ],\r\n weekdays: [\r\n \"Sunday\",\r\n \"Monday\",\r\n \"Tuesday\",\r\n \"Wednesday\",\r\n \"Thursday\",\r\n \"Friday\",\r\n \"Saturday\"\r\n ],\r\n decimalPoint: \".\",\r\n numericSymbols: [\"k\", \"M\", \"G\", \"T\", \"P\", \"E\"], // SI prefixes used in axis labels\r\n resetZoom: \"Reset zoom\",\r\n resetZoomTitle: \"Reset zoom level 1:1\",\r\n thousandsSep: \",\"\r\n },\r\n global: {\r\n useUTC: true,\r\n canvasToolsURL:\r\n \"http://code.highcharts.com/2.3.5/modules/canvas-tools.js\",\r\n VMLRadialGradientURL:\r\n \"http://code.highcharts.com/2.3.5/gfx/vml-radial-gradient.png\"\r\n },\r\n chart: {\r\n //animation: true,\r\n //alignTicks: false,\r\n //reflow: true,\r\n //className: null,\r\n //events: { load, selection },\r\n //margin: [null],\r\n //marginTop: null,\r\n //marginRight: null,\r\n //marginBottom: null,\r\n //marginLeft: null,\r\n borderColor: \"#4572A7\",\r\n //borderWidth: 0,\r\n borderRadius: 5,\r\n defaultSeriesType: \"line\",\r\n ignoreHiddenSeries: true,\r\n //inverted: false,\r\n //shadow: false,\r\n spacingTop: 10,\r\n spacingRight: 10,\r\n spacingBottom: 15,\r\n spacingLeft: 10,\r\n style: {\r\n fontFamily:\r\n '\"Lucida Grande\", \"Lucida Sans Unicode\", Verdana, Arial, Helvetica, sans-serif', // default font\r\n fontSize: \"12px\"\r\n },\r\n backgroundColor: \"#FFFFFF\",\r\n //plotBackgroundColor: null,\r\n plotBorderColor: \"#C0C0C0\",\r\n //plotBorderWidth: 0,\r\n //plotShadow: false,\r\n //zoomType: ''\r\n resetZoomButton: {\r\n theme: {\r\n zIndex: 20\r\n },\r\n position: {\r\n align: \"right\",\r\n x: -10,\r\n //verticalAlign: 'top',\r\n y: 10\r\n }\r\n // relativeTo: 'plot'\r\n }\r\n },\r\n title: {\r\n text: \"Chart title\",\r\n align: \"center\",\r\n // floating: false,\r\n // margin: 15,\r\n // x: 0,\r\n // verticalAlign: 'top',\r\n y: 15,\r\n style: {\r\n color: \"#3E576F\",\r\n fontSize: \"16px\"\r\n }\r\n },\r\n subtitle: {\r\n text: \"\",\r\n align: \"center\",\r\n // floating: false\r\n // x: 0,\r\n // verticalAlign: 'top',\r\n y: 30,\r\n style: {\r\n color: \"#6D869F\"\r\n }\r\n },\r\n\r\n plotOptions: {\r\n line: {\r\n // base series options\r\n allowPointSelect: false,\r\n showCheckbox: false,\r\n animation: {\r\n duration: 1000\r\n },\r\n //connectNulls: false,\r\n //cursor: 'default',\r\n //clip: true,\r\n //dashStyle: null,\r\n //enableMouseTracking: true,\r\n events: {},\r\n //legendIndex: 0,\r\n lineWidth: 2,\r\n shadow: true,\r\n // stacking: null,\r\n marker: {\r\n enabled: true,\r\n //symbol: null,\r\n lineWidth: 0,\r\n radius: 4,\r\n lineColor: \"#FFFFFF\",\r\n //fillColor: null,\r\n states: {\r\n // states for a single point\r\n hover: {\r\n enabled: true\r\n //radius: base + 2\r\n },\r\n select: {\r\n fillColor: \"#FFFFFF\",\r\n lineColor: \"#000000\",\r\n lineWidth: 2\r\n }\r\n }\r\n },\r\n point: {\r\n events: {}\r\n },\r\n dataLabels: merge(defaultLabelOptions, {\r\n enabled: false,\r\n formatter: function() {\r\n return this.y;\r\n },\r\n verticalAlign: \"bottom\", // above singular point\r\n y: 0\r\n // backgroundColor: undefined,\r\n // borderColor: undefined,\r\n // borderRadius: undefined,\r\n // borderWidth: undefined,\r\n // padding: 3,\r\n // shadow: false\r\n }),\r\n cropThreshold: 300, // draw points outside the plot area when the number of points is less than this\r\n pointRange: 0,\r\n //pointStart: 0,\r\n //pointInterval: 1,\r\n showInLegend: true,\r\n states: {\r\n // states for the entire series\r\n hover: {\r\n //enabled: false,\r\n //lineWidth: base + 1,\r\n marker: {\r\n // lineWidth: base + 1,\r\n // radius: base + 1\r\n }\r\n },\r\n select: {\r\n marker: {}\r\n }\r\n },\r\n stickyTracking: true\r\n //tooltip: {\r\n //pointFormat: '{series.name}: {point.y}'\r\n //valueDecimals: null,\r\n //xDateFormat: '%A, %b %e, %Y',\r\n //valuePrefix: '',\r\n //ySuffix: ''\r\n //}\r\n // turboThreshold: 1000\r\n // zIndex: null\r\n }\r\n },\r\n labels: {\r\n //items: [],\r\n style: {\r\n //font: defaultFont,\r\n position: ABSOLUTE,\r\n color: \"#3E576F\"\r\n }\r\n },\r\n legend: {\r\n enabled: true,\r\n align: \"center\",\r\n //floating: false,\r\n layout: \"horizontal\",\r\n labelFormatter: function() {\r\n return this.name;\r\n },\r\n borderWidth: 1,\r\n borderColor: \"#909090\",\r\n borderRadius: 5,\r\n navigation: {\r\n // animation: true,\r\n activeColor: \"#3E576F\",\r\n // arrowSize: 12\r\n inactiveColor: \"#CCC\"\r\n // style: {} // text styles\r\n },\r\n // margin: 10,\r\n // reversed: false,\r\n shadow: false,\r\n // backgroundColor: null,\r\n /*style: {\r\n\t\t\tpadding: '5px'\r\n\t\t},*/\r\n itemStyle: {\r\n cursor: \"pointer\",\r\n color: \"#3E576F\",\r\n fontSize: \"12px\"\r\n },\r\n itemHoverStyle: {\r\n //cursor: 'pointer', removed as of #601\r\n color: \"#000\"\r\n },\r\n itemHiddenStyle: {\r\n color: \"#CCC\"\r\n },\r\n itemCheckboxStyle: {\r\n position: ABSOLUTE,\r\n width: \"13px\", // for IE precision\r\n height: \"13px\"\r\n },\r\n // itemWidth: undefined,\r\n symbolWidth: 16,\r\n symbolPadding: 5,\r\n verticalAlign: \"bottom\",\r\n // width: undefined,\r\n x: 0,\r\n y: 0\r\n },\r\n\r\n loading: {\r\n // hideDuration: 100,\r\n labelStyle: {\r\n fontWeight: \"bold\",\r\n position: RELATIVE,\r\n top: \"1em\"\r\n },\r\n // showDuration: 0,\r\n style: {\r\n position: ABSOLUTE,\r\n backgroundColor: \"white\",\r\n opacity: 0.5,\r\n textAlign: \"center\"\r\n }\r\n },\r\n\r\n tooltip: {\r\n enabled: true,\r\n //crosshairs: null,\r\n backgroundColor: \"rgba(255, 255, 255, .85)\",\r\n borderWidth: 2,\r\n borderRadius: 5,\r\n dateTimeLabelFormats: {\r\n millisecond: \"%A, %b %e, %H:%M:%S.%L\",\r\n second: \"%A, %b %e, %H:%M:%S\",\r\n minute: \"%A, %b %e, %H:%M\",\r\n hour: \"%A, %b %e, %H:%M\",\r\n day: \"%A, %b %e, %Y\",\r\n week: \"Week from %A, %b %e, %Y\",\r\n month: \"%B %Y\",\r\n year: \"%Y\"\r\n },\r\n //formatter: defaultFormatter,\r\n headerFormat: '{point.key}
',\r\n pointFormat:\r\n '{series.name}: {point.y}
',\r\n shadow: true,\r\n shared: useCanVG,\r\n snap: isTouchDevice ? 25 : 10,\r\n style: {\r\n color: \"#333333\",\r\n fontSize: \"12px\",\r\n padding: \"5px\",\r\n whiteSpace: \"nowrap\"\r\n }\r\n //xDateFormat: '%A, %b %e, %Y',\r\n //valueDecimals: null,\r\n //valuePrefix: '',\r\n //valueSuffix: ''\r\n },\r\n\r\n credits: {\r\n enabled: true,\r\n text: \"Highcharts.com\",\r\n href: \"http://www.highcharts.com\",\r\n position: {\r\n align: \"right\",\r\n x: -10,\r\n verticalAlign: \"bottom\",\r\n y: -5\r\n },\r\n style: {\r\n cursor: \"pointer\",\r\n color: \"#909090\",\r\n fontSize: \"10px\"\r\n }\r\n }\r\n };\r\n\r\n // Series defaults\r\n var defaultPlotOptions = defaultOptions.plotOptions,\r\n defaultSeriesOptions = defaultPlotOptions.line;\r\n\r\n // set the default time methods\r\n setTimeMethods();\r\n\r\n /**\r\n * Set the time methods globally based on the useUTC option. Time method can be either\r\n * local time or UTC (default).\r\n */\r\n function setTimeMethods() {\r\n var useUTC = defaultOptions.global.useUTC,\r\n GET = useUTC ? \"getUTC\" : \"get\",\r\n SET = useUTC ? \"setUTC\" : \"set\";\r\n\r\n makeTime = useUTC\r\n ? Date.UTC\r\n : function(year, month, date, hours, minutes, seconds) {\r\n return new Date(\r\n year,\r\n month,\r\n pick(date, 1),\r\n pick(hours, 0),\r\n pick(minutes, 0),\r\n pick(seconds, 0)\r\n ).getTime();\r\n };\r\n getMinutes = GET + \"Minutes\";\r\n getHours = GET + \"Hours\";\r\n getDay = GET + \"Day\";\r\n getDate = GET + \"Date\";\r\n getMonth = GET + \"Month\";\r\n getFullYear = GET + \"FullYear\";\r\n setMinutes = SET + \"Minutes\";\r\n setHours = SET + \"Hours\";\r\n setDate = SET + \"Date\";\r\n setMonth = SET + \"Month\";\r\n setFullYear = SET + \"FullYear\";\r\n }\r\n\r\n /**\r\n * Merge the default options with custom options and return the new options structure\r\n * @param {Object} options The new custom options\r\n */\r\n function setOptions(options) {\r\n // Pull out axis options and apply them to the respective default axis options\r\n /*defaultXAxisOptions = merge(defaultXAxisOptions, options.xAxis);\r\n\tdefaultYAxisOptions = merge(defaultYAxisOptions, options.yAxis);\r\n\toptions.xAxis = options.yAxis = UNDEFINED;*/\r\n\r\n // Merge in the default options\r\n defaultOptions = merge(defaultOptions, options);\r\n\r\n // Apply UTC\r\n setTimeMethods();\r\n\r\n return defaultOptions;\r\n }\r\n\r\n /**\r\n * Get the updated default options. Merely exposing defaultOptions for outside modules\r\n * isn't enough because the setOptions method creates a new object.\r\n */\r\n function getOptions() {\r\n return defaultOptions;\r\n }\r\n\r\n /**\r\n * Handle color operations. The object methods are chainable.\r\n * @param {String} input The input color in either rbga or hex format\r\n */\r\n var Color = function(input) {\r\n // declare variables\r\n var rgba = [],\r\n result;\r\n\r\n /**\r\n * Parse the input color to rgba array\r\n * @param {String} input\r\n */\r\n function init(input) {\r\n // rgba\r\n result = /rgba\\(\\s*([0-9]{1,3})\\s*,\\s*([0-9]{1,3})\\s*,\\s*([0-9]{1,3})\\s*,\\s*([0-9]?(?:\\.[0-9]+)?)\\s*\\)/.exec(\r\n input\r\n );\r\n if (result) {\r\n rgba = [\r\n pInt(result[1]),\r\n pInt(result[2]),\r\n pInt(result[3]),\r\n parseFloat(result[4], 10)\r\n ];\r\n }\r\n else {\r\n // hex\r\n result = /#([a-fA-F0-9]{2})([a-fA-F0-9]{2})([a-fA-F0-9]{2})/.exec(\r\n input\r\n );\r\n if (result) {\r\n rgba = [\r\n pInt(result[1], 16),\r\n pInt(result[2], 16),\r\n pInt(result[3], 16),\r\n 1\r\n ];\r\n }\r\n }\r\n }\r\n /**\r\n * Return the color a specified format\r\n * @param {String} format\r\n */\r\n function get(format) {\r\n var ret;\r\n\r\n // it's NaN if gradient colors on a column chart\r\n if (rgba && !isNaN(rgba[0])) {\r\n if (format === \"rgb\") {\r\n ret = \"rgb(\" + rgba[0] + \",\" + rgba[1] + \",\" + rgba[2] + \")\";\r\n }\r\n else if (format === \"a\") {\r\n ret = rgba[3];\r\n }\r\n else {\r\n ret = \"rgba(\" + rgba.join(\",\") + \")\";\r\n }\r\n }\r\n else {\r\n ret = input;\r\n }\r\n return ret;\r\n }\r\n\r\n /**\r\n * Brighten the color\r\n * @param {Number} alpha\r\n */\r\n function brighten(alpha) {\r\n if (isNumber(alpha) && alpha !== 0) {\r\n var i;\r\n for (i = 0; i < 3; i++) {\r\n rgba[i] += pInt(alpha * 255);\r\n\r\n if (rgba[i] < 0) {\r\n rgba[i] = 0;\r\n }\r\n if (rgba[i] > 255) {\r\n rgba[i] = 255;\r\n }\r\n }\r\n }\r\n return this;\r\n }\r\n /**\r\n * Set the color's opacity to a given alpha value\r\n * @param {Number} alpha\r\n */\r\n function setOpacity(alpha) {\r\n rgba[3] = alpha;\r\n return this;\r\n }\r\n\r\n // initialize: parse the input\r\n init(input);\r\n\r\n // public methods\r\n return {\r\n get: get,\r\n brighten: brighten,\r\n setOpacity: setOpacity\r\n };\r\n };\r\n\r\n /**\r\n * A wrapper object for SVG elements\r\n */\r\n function SVGElement() {}\r\n\r\n SVGElement.prototype = {\r\n /**\r\n * Initialize the SVG renderer\r\n * @param {Object} renderer\r\n * @param {String} nodeName\r\n */\r\n init: function(renderer, nodeName) {\r\n var wrapper = this;\r\n wrapper.element =\r\n nodeName === \"span\"\r\n ? createElement(nodeName)\r\n : doc.createElementNS(SVG_NS, nodeName);\r\n wrapper.renderer = renderer;\r\n /**\r\n * A collection of attribute setters. These methods, if defined, are called right before a certain\r\n * attribute is set on an element wrapper. Returning false prevents the default attribute\r\n * setter to run. Returning a value causes the default setter to set that value. Used in\r\n * Renderer.label.\r\n */\r\n wrapper.attrSetters = {};\r\n },\r\n /**\r\n * Animate a given attribute\r\n * @param {Object} params\r\n * @param {Number} options The same options as in jQuery animation\r\n * @param {Function} complete Function to perform at the end of animation\r\n */\r\n animate: function(params, options, complete) {\r\n var animOptions = pick(options, globalAnimation, true);\r\n stop(this); // stop regardless of animation actually running, or reverting to .attr (#607)\r\n if (animOptions) {\r\n animOptions = merge(animOptions);\r\n if (complete) {\r\n // allows using a callback with the global animation without overwriting it\r\n animOptions.complete = complete;\r\n }\r\n animate(this, params, animOptions);\r\n }\r\n else {\r\n this.attr(params);\r\n if (complete) {\r\n complete();\r\n }\r\n }\r\n },\r\n /**\r\n * Set or get a given attribute\r\n * @param {Object|String} hash\r\n * @param {Mixed|Undefined} val\r\n */\r\n attr: function(hash, val) {\r\n var wrapper = this,\r\n key,\r\n value,\r\n result,\r\n i,\r\n child,\r\n element = wrapper.element,\r\n nodeName = element.nodeName.toLowerCase(), // Android2 requires lower for \"text\"\r\n renderer = wrapper.renderer,\r\n skipAttr,\r\n titleNode,\r\n attrSetters = wrapper.attrSetters,\r\n shadows = wrapper.shadows,\r\n hasSetSymbolSize,\r\n doTransform,\r\n ret = wrapper;\r\n\r\n // single key-value pair\r\n if (isString(hash) && defined(val)) {\r\n key = hash;\r\n hash = {};\r\n hash[key] = val;\r\n }\r\n\r\n // used as a getter: first argument is a string, second is undefined\r\n if (isString(hash)) {\r\n key = hash;\r\n if (nodeName === \"circle\") {\r\n key = { x: \"cx\", y: \"cy\" }[key] || key;\r\n }\r\n else if (key === \"strokeWidth\") {\r\n key = \"stroke-width\";\r\n }\r\n ret = attr(element, key) || wrapper[key] || 0;\r\n\r\n if (key !== \"d\" && key !== \"visibility\") {\r\n // 'd' is string in animation step\r\n ret = parseFloat(ret);\r\n }\r\n\r\n // setter\r\n }\r\n else {\r\n for (key in hash) {\r\n skipAttr = false; // reset\r\n value = hash[key];\r\n\r\n // check for a specific attribute setter\r\n result =\r\n attrSetters[key] && attrSetters[key].call(wrapper, value, key);\r\n\r\n if (result !== false) {\r\n if (result !== UNDEFINED) {\r\n value = result; // the attribute setter has returned a new value to set\r\n }\r\n\r\n // paths\r\n if (key === \"d\") {\r\n if (value && value.join) {\r\n // join path\r\n value = value.join(\" \");\r\n }\r\n if (/(NaN| {2}|^$)/.test(value)) {\r\n value = \"M 0 0\";\r\n }\r\n //wrapper.d = value; // shortcut for animations\r\n\r\n // update child tspans x values\r\n }\r\n else if (key === \"x\" && nodeName === \"text\") {\r\n for (i = 0; i < element.childNodes.length; i++) {\r\n child = element.childNodes[i];\r\n // if the x values are equal, the tspan represents a linebreak\r\n if (attr(child, \"x\") === attr(element, \"x\")) {\r\n //child.setAttribute('x', value);\r\n attr(child, \"x\", value);\r\n }\r\n }\r\n\r\n if (wrapper.rotation) {\r\n attr(\r\n element,\r\n \"transform\",\r\n \"rotate(\" +\r\n wrapper.rotation +\r\n \" \" +\r\n value +\r\n \" \" +\r\n pInt(hash.y || attr(element, \"y\")) +\r\n \")\"\r\n );\r\n }\r\n\r\n // apply gradients\r\n }\r\n else if (key === \"fill\") {\r\n value = renderer.color(value, element, key);\r\n\r\n // circle x and y\r\n }\r\n else if (nodeName === \"circle\" && (key === \"x\" || key === \"y\")) {\r\n key = { x: \"cx\", y: \"cy\" }[key] || key;\r\n\r\n // rectangle border radius\r\n }\r\n else if (nodeName === \"rect\" && key === \"r\") {\r\n attr(element, {\r\n rx: value,\r\n ry: value\r\n });\r\n skipAttr = true;\r\n\r\n // translation and text rotation\r\n }\r\n else if (\r\n key === \"translateX\" ||\r\n key === \"translateY\" ||\r\n key === \"rotation\" ||\r\n key === \"verticalAlign\"\r\n ) {\r\n doTransform = true;\r\n skipAttr = true;\r\n\r\n // apply opacity as subnode (required by legacy WebKit and Batik)\r\n }\r\n else if (key === \"stroke\") {\r\n value = renderer.color(value, element, key);\r\n\r\n // emulate VML's dashstyle implementation\r\n }\r\n else if (key === \"dashstyle\") {\r\n key = \"stroke-dasharray\";\r\n value = value && value.toLowerCase();\r\n if (value === \"solid\") {\r\n value = NONE;\r\n }\r\n else if (value) {\r\n value = value\r\n .replace(\"shortdashdotdot\", \"3,1,1,1,1,1,\")\r\n .replace(\"shortdashdot\", \"3,1,1,1\")\r\n .replace(\"shortdot\", \"1,1,\")\r\n .replace(\"shortdash\", \"3,1,\")\r\n .replace(\"longdash\", \"8,3,\")\r\n .replace(/dot/g, \"1,3,\")\r\n .replace(\"dash\", \"4,3,\")\r\n .replace(/,$/, \"\")\r\n .split(\",\"); // ending comma\r\n\r\n i = value.length;\r\n while (i--) {\r\n value[i] = pInt(value[i]) * hash[\"stroke-width\"];\r\n }\r\n value = value.join(\",\");\r\n }\r\n\r\n // special\r\n }\r\n else if (key === \"isTracker\") {\r\n wrapper[key] = value;\r\n\r\n // IE9/MooTools combo: MooTools returns objects instead of numbers and IE9 Beta 2\r\n // is unable to cast them. Test again with final IE9.\r\n }\r\n else if (key === \"width\") {\r\n value = pInt(value);\r\n\r\n // Text alignment\r\n }\r\n else if (key === \"align\") {\r\n key = \"text-anchor\";\r\n value = { left: \"start\", center: \"middle\", right: \"end\" }[value];\r\n\r\n // Title requires a subnode, #431\r\n }\r\n else if (key === \"title\") {\r\n titleNode = element.getElementsByTagName(\"title\")[0];\r\n if (!titleNode) {\r\n titleNode = doc.createElementNS(SVG_NS, \"title\");\r\n element.appendChild(titleNode);\r\n }\r\n titleNode.textContent = value;\r\n }\r\n\r\n // jQuery animate changes case\r\n if (key === \"strokeWidth\") {\r\n key = \"stroke-width\";\r\n }\r\n\r\n // Chrome/Win < 6 bug (http://code.google.com/p/chromium/issues/detail?id=15461), #1369\r\n if (\r\n key === \"stroke-width\" &&\r\n value === 0 &&\r\n (isWebKit || renderer.forExport)\r\n ) {\r\n value = 0.000001;\r\n }\r\n\r\n // symbols\r\n if (\r\n wrapper.symbolName &&\r\n /^(x|y|width|height|r|start|end|innerR|anchorX|anchorY)/.test(key)\r\n ) {\r\n if (!hasSetSymbolSize) {\r\n wrapper.symbolAttr(hash);\r\n hasSetSymbolSize = true;\r\n }\r\n skipAttr = true;\r\n }\r\n\r\n // let the shadow follow the main element\r\n if (\r\n shadows &&\r\n /^(width|height|visibility|x|y|d|transform)$/.test(key)\r\n ) {\r\n i = shadows.length;\r\n while (i--) {\r\n attr(\r\n shadows[i],\r\n key,\r\n key === \"height\"\r\n ? mathMax(value - (shadows[i].cutHeight || 0), 0)\r\n : value\r\n );\r\n }\r\n }\r\n\r\n // validate heights\r\n if (\r\n (key === \"width\" || key === \"height\") &&\r\n nodeName === \"rect\" &&\r\n value < 0\r\n ) {\r\n value = 0;\r\n }\r\n\r\n // Record for animation and quick access without polling the DOM\r\n wrapper[key] = value;\r\n\r\n // Update transform\r\n if (doTransform) {\r\n wrapper.updateTransform();\r\n }\r\n\r\n if (key === \"text\") {\r\n // Delete bBox memo when the text changes\r\n if (value !== wrapper.textStr) {\r\n delete wrapper.bBox;\r\n }\r\n wrapper.textStr = value;\r\n if (wrapper.added) {\r\n renderer.buildText(wrapper);\r\n }\r\n }\r\n else if (!skipAttr) {\r\n attr(element, key, value);\r\n }\r\n }\r\n }\r\n }\r\n\r\n return ret;\r\n },\r\n\r\n /**\r\n * If one of the symbol size affecting parameters are changed,\r\n * check all the others only once for each call to an element's\r\n * .attr() method\r\n * @param {Object} hash\r\n */\r\n symbolAttr: function(hash) {\r\n var wrapper = this;\r\n\r\n each(\r\n [\r\n \"x\",\r\n \"y\",\r\n \"r\",\r\n \"start\",\r\n \"end\",\r\n \"width\",\r\n \"height\",\r\n \"innerR\",\r\n \"anchorX\",\r\n \"anchorY\"\r\n ],\r\n function(key) {\r\n wrapper[key] = pick(hash[key], wrapper[key]);\r\n }\r\n );\r\n\r\n wrapper.attr({\r\n d: wrapper.renderer.symbols[wrapper.symbolName](\r\n wrapper.x,\r\n wrapper.y,\r\n wrapper.width,\r\n wrapper.height,\r\n wrapper\r\n )\r\n });\r\n },\r\n\r\n /**\r\n * Apply a clipping path to this object\r\n * @param {String} id\r\n */\r\n clip: function(clipRect) {\r\n return this.attr(\r\n \"clip-path\",\r\n clipRect ? \"url(\" + this.renderer.url + \"#\" + clipRect.id + \")\" : NONE\r\n );\r\n },\r\n\r\n /**\r\n * Calculate the coordinates needed for drawing a rectangle crisply and return the\r\n * calculated attributes\r\n * @param {Number} strokeWidth\r\n * @param {Number} x\r\n * @param {Number} y\r\n * @param {Number} width\r\n * @param {Number} height\r\n */\r\n crisp: function(strokeWidth, x, y, width, height) {\r\n var wrapper = this,\r\n key,\r\n attribs = {},\r\n values = {},\r\n normalizer;\r\n\r\n strokeWidth =\r\n strokeWidth ||\r\n wrapper.strokeWidth ||\r\n (wrapper.attr && wrapper.attr(\"stroke-width\")) ||\r\n 0;\r\n normalizer = (mathRound(strokeWidth) % 2) / 2; // mathRound because strokeWidth can sometimes have roundoff errors\r\n\r\n // normalize for crisp edges\r\n values.x = mathFloor(x || wrapper.x || 0) + normalizer;\r\n values.y = mathFloor(y || wrapper.y || 0) + normalizer;\r\n values.width = mathFloor((width || wrapper.width || 0) - 2 * normalizer);\r\n values.height = mathFloor(\r\n (height || wrapper.height || 0) - 2 * normalizer\r\n );\r\n values.strokeWidth = strokeWidth;\r\n\r\n for (key in values) {\r\n if (wrapper[key] !== values[key]) {\r\n // only set attribute if changed\r\n wrapper[key] = attribs[key] = values[key];\r\n }\r\n }\r\n\r\n return attribs;\r\n },\r\n\r\n /**\r\n * Set styles for the element\r\n * @param {Object} styles\r\n */\r\n css: function(styles) {\r\n /*jslint unparam: true*/ /* allow unused param a in the regexp function below */\r\n var elemWrapper = this,\r\n elem = elemWrapper.element,\r\n textWidth =\r\n styles && styles.width && elem.nodeName.toLowerCase() === \"text\",\r\n n,\r\n serializedCss = \"\",\r\n hyphenate = function(a, b) {\r\n return \"-\" + b.toLowerCase();\r\n };\r\n /*jslint unparam: false*/\r\n\r\n // convert legacy\r\n if (styles && styles.color) {\r\n styles.fill = styles.color;\r\n }\r\n\r\n // Merge the new styles with the old ones\r\n styles = extend(elemWrapper.styles, styles);\r\n\r\n // store object\r\n elemWrapper.styles = styles;\r\n\r\n // Don't handle line wrap on canvas\r\n if (useCanVG && textWidth) {\r\n delete styles.width;\r\n }\r\n\r\n // serialize and set style attribute\r\n if (isIE && !hasSVG) {\r\n // legacy IE doesn't support setting style attribute\r\n if (textWidth) {\r\n delete styles.width;\r\n }\r\n css(elemWrapper.element, styles);\r\n }\r\n else {\r\n for (n in styles) {\r\n serializedCss +=\r\n n.replace(/([A-Z])/g, hyphenate) + \":\" + styles[n] + \";\";\r\n }\r\n elemWrapper.attr({\r\n style: serializedCss\r\n });\r\n }\r\n\r\n // re-build text\r\n if (textWidth && elemWrapper.added) {\r\n elemWrapper.renderer.buildText(elemWrapper);\r\n }\r\n\r\n return elemWrapper;\r\n },\r\n\r\n /**\r\n * Add an event listener\r\n * @param {String} eventType\r\n * @param {Function} handler\r\n */\r\n on: function(eventType, handler) {\r\n // touch\r\n if (hasTouch && eventType === \"click\") {\r\n this.element.ontouchstart = function(e) {\r\n e.preventDefault();\r\n handler();\r\n };\r\n }\r\n // simplest possible event model for internal use\r\n this.element[\"on\" + eventType] = handler;\r\n return this;\r\n },\r\n\r\n /**\r\n * Set the coordinates needed to draw a consistent radial gradient across\r\n * pie slices regardless of positioning inside the chart. The format is\r\n * [centerX, centerY, diameter] in pixels.\r\n */\r\n setRadialReference: function(coordinates) {\r\n this.element.radialReference = coordinates;\r\n return this;\r\n },\r\n\r\n /**\r\n * Move an object and its children by x and y values\r\n * @param {Number} x\r\n * @param {Number} y\r\n */\r\n translate: function(x, y) {\r\n return this.attr({\r\n translateX: x,\r\n translateY: y\r\n });\r\n },\r\n\r\n /**\r\n * Invert a group, rotate and flip\r\n */\r\n invert: function() {\r\n var wrapper = this;\r\n wrapper.inverted = true;\r\n wrapper.updateTransform();\r\n return wrapper;\r\n },\r\n\r\n /**\r\n * Apply CSS to HTML elements. This is used in text within SVG rendering and\r\n * by the VML renderer\r\n */\r\n htmlCss: function(styles) {\r\n var wrapper = this,\r\n element = wrapper.element,\r\n textWidth = styles && element.tagName === \"SPAN\" && styles.width;\r\n\r\n if (textWidth) {\r\n delete styles.width;\r\n wrapper.textWidth = textWidth;\r\n wrapper.updateTransform();\r\n }\r\n\r\n wrapper.styles = extend(wrapper.styles, styles);\r\n css(wrapper.element, styles);\r\n\r\n return wrapper;\r\n },\r\n\r\n /**\r\n * VML and useHTML method for calculating the bounding box based on offsets\r\n * @param {Boolean} refresh Whether to force a fresh value from the DOM or to\r\n * use the cached value\r\n *\r\n * @return {Object} A hash containing values for x, y, width and height\r\n */\r\n\r\n htmlGetBBox: function() {\r\n var wrapper = this,\r\n element = wrapper.element,\r\n bBox = wrapper.bBox;\r\n\r\n // faking getBBox in exported SVG in legacy IE\r\n if (!bBox) {\r\n // faking getBBox in exported SVG in legacy IE (is this a duplicate of the fix for #1079?)\r\n if (element.nodeName === \"text\") {\r\n element.style.position = ABSOLUTE;\r\n }\r\n\r\n bBox = wrapper.bBox = {\r\n x: element.offsetLeft,\r\n y: element.offsetTop,\r\n width: element.offsetWidth,\r\n height: element.offsetHeight\r\n };\r\n }\r\n\r\n return bBox;\r\n },\r\n\r\n /**\r\n * VML override private method to update elements based on internal\r\n * properties based on SVG transform\r\n */\r\n htmlUpdateTransform: function() {\r\n // aligning non added elements is expensive\r\n if (!this.added) {\r\n this.alignOnAdd = true;\r\n return;\r\n }\r\n\r\n var wrapper = this,\r\n renderer = wrapper.renderer,\r\n elem = wrapper.element,\r\n translateX = wrapper.translateX || 0,\r\n translateY = wrapper.translateY || 0,\r\n x = wrapper.x || 0,\r\n y = wrapper.y || 0,\r\n align = wrapper.textAlign || \"left\",\r\n alignCorrection = { left: 0, center: 0.5, right: 1 }[align],\r\n nonLeft = align && align !== \"left\",\r\n shadows = wrapper.shadows;\r\n\r\n // apply translate\r\n if (translateX || translateY) {\r\n css(elem, {\r\n marginLeft: translateX,\r\n marginTop: translateY\r\n });\r\n if (shadows) {\r\n // used in labels/tooltip\r\n each(shadows, function(shadow) {\r\n css(shadow, {\r\n marginLeft: translateX + 1,\r\n marginTop: translateY + 1\r\n });\r\n });\r\n }\r\n }\r\n\r\n // apply inversion\r\n if (wrapper.inverted) {\r\n // wrapper is a group\r\n each(elem.childNodes, function(child) {\r\n renderer.invertChild(child, elem);\r\n });\r\n }\r\n\r\n if (elem.tagName === \"SPAN\") {\r\n var width,\r\n height,\r\n rotation = wrapper.rotation,\r\n baseline,\r\n radians = 0,\r\n costheta = 1,\r\n sintheta = 0,\r\n quad,\r\n textWidth = pInt(wrapper.textWidth),\r\n xCorr = wrapper.xCorr || 0,\r\n yCorr = wrapper.yCorr || 0,\r\n currentTextTransform = [\r\n rotation,\r\n align,\r\n elem.innerHTML,\r\n wrapper.textWidth\r\n ].join(\",\"),\r\n rotationStyle = {},\r\n cssTransformKey;\r\n\r\n if (currentTextTransform !== wrapper.cTT) {\r\n // do the calculations and DOM access only if properties changed\r\n\r\n if (defined(rotation)) {\r\n if (renderer.isSVG) {\r\n // #916\r\n cssTransformKey = isIE\r\n ? \"-ms-transform\"\r\n : isWebKit\r\n ? \"-webkit-transform\"\r\n : isFirefox\r\n ? \"MozTransform\"\r\n : isOpera\r\n ? \"-o-transform\"\r\n : \"\";\r\n rotationStyle[cssTransformKey] = rotationStyle.transform =\r\n \"rotate(\" + rotation + \"deg)\";\r\n }\r\n else {\r\n radians = rotation * deg2rad; // deg to rad\r\n costheta = mathCos(radians);\r\n sintheta = mathSin(radians);\r\n\r\n // Adjust for alignment and rotation. Rotation of useHTML content is not yet implemented\r\n // but it can probably be implemented for Firefox 3.5+ on user request. FF3.5+\r\n // has support for CSS3 transform. The getBBox method also needs to be updated\r\n // to compensate for the rotation, like it currently does for SVG.\r\n // Test case: http://highcharts.com/tests/?file=text-rotation\r\n rotationStyle.filter = rotation\r\n ? [\r\n \"progid:DXImageTransform.Microsoft.Matrix(M11=\",\r\n costheta,\r\n \", M12=\",\r\n -sintheta,\r\n \", M21=\",\r\n sintheta,\r\n \", M22=\",\r\n costheta,\r\n \", sizingMethod='auto expand')\"\r\n ].join(\"\")\r\n : NONE;\r\n }\r\n css(elem, rotationStyle);\r\n }\r\n\r\n width = pick(wrapper.elemWidth, elem.offsetWidth);\r\n height = pick(wrapper.elemHeight, elem.offsetHeight);\r\n\r\n // update textWidth\r\n if (\r\n width > textWidth &&\r\n /[ \\-]/.test(elem.textContent || elem.innerText)\r\n ) {\r\n // #983, #1254\r\n css(elem, {\r\n width: textWidth + PX,\r\n display: \"block\",\r\n whiteSpace: \"normal\"\r\n });\r\n width = textWidth;\r\n }\r\n\r\n // correct x and y\r\n baseline = renderer.fontMetrics(elem.style.fontSize).b;\r\n xCorr = costheta < 0 && -width;\r\n yCorr = sintheta < 0 && -height;\r\n\r\n // correct for baseline and corners spilling out after rotation\r\n quad = costheta * sintheta < 0;\r\n xCorr +=\r\n sintheta *\r\n baseline *\r\n (quad ? 1 - alignCorrection : alignCorrection);\r\n yCorr -=\r\n costheta *\r\n baseline *\r\n (rotation ? (quad ? alignCorrection : 1 - alignCorrection) : 1);\r\n\r\n // correct for the length/height of the text\r\n if (nonLeft) {\r\n xCorr -= width * alignCorrection * (costheta < 0 ? -1 : 1);\r\n if (rotation) {\r\n yCorr -= height * alignCorrection * (sintheta < 0 ? -1 : 1);\r\n }\r\n css(elem, {\r\n textAlign: align\r\n });\r\n }\r\n\r\n // record correction\r\n wrapper.xCorr = xCorr;\r\n wrapper.yCorr = yCorr;\r\n }\r\n\r\n // apply position with correction\r\n css(elem, {\r\n left: x + xCorr + PX,\r\n top: y + yCorr + PX\r\n });\r\n\r\n // force reflow in webkit to apply the left and top on useHTML element (#1249)\r\n if (isWebKit) {\r\n height = elem.offsetHeight; // assigned to height for JSLint purpose\r\n }\r\n\r\n // record current text transform\r\n wrapper.cTT = currentTextTransform;\r\n }\r\n },\r\n\r\n /**\r\n * Private method to update the transform attribute based on internal\r\n * properties\r\n */\r\n updateTransform: function() {\r\n var wrapper = this,\r\n translateX = wrapper.translateX || 0,\r\n translateY = wrapper.translateY || 0,\r\n inverted = wrapper.inverted,\r\n rotation = wrapper.rotation,\r\n transform = [];\r\n\r\n // flipping affects translate as adjustment for flipping around the group's axis\r\n if (inverted) {\r\n translateX += wrapper.attr(\"width\");\r\n translateY += wrapper.attr(\"height\");\r\n }\r\n\r\n // apply translate\r\n if (translateX || translateY) {\r\n transform.push(\"translate(\" + translateX + \",\" + translateY + \")\");\r\n }\r\n\r\n // apply rotation\r\n if (inverted) {\r\n transform.push(\"rotate(90) scale(-1,1)\");\r\n }\r\n else if (rotation) {\r\n // text rotation\r\n transform.push(\r\n \"rotate(\" +\r\n rotation +\r\n \" \" +\r\n (wrapper.x || 0) +\r\n \" \" +\r\n (wrapper.y || 0) +\r\n \")\"\r\n );\r\n }\r\n\r\n if (transform.length) {\r\n attr(wrapper.element, \"transform\", transform.join(\" \"));\r\n }\r\n },\r\n /**\r\n * Bring the element to the front\r\n */\r\n toFront: function() {\r\n var element = this.element;\r\n element.parentNode.appendChild(element);\r\n return this;\r\n },\r\n\r\n /**\r\n * Break down alignment options like align, verticalAlign, x and y\r\n * to x and y relative to the chart.\r\n *\r\n * @param {Object} alignOptions\r\n * @param {Boolean} alignByTranslate\r\n * @param {Object} box The box to align to, needs a width and height\r\n *\r\n */\r\n align: function(alignOptions, alignByTranslate, box) {\r\n var elemWrapper = this;\r\n\r\n if (!alignOptions) {\r\n // called on resize\r\n alignOptions = elemWrapper.alignOptions;\r\n alignByTranslate = elemWrapper.alignByTranslate;\r\n }\r\n else {\r\n // first call on instanciate\r\n elemWrapper.alignOptions = alignOptions;\r\n elemWrapper.alignByTranslate = alignByTranslate;\r\n if (!box) {\r\n // boxes other than renderer handle this internally\r\n elemWrapper.renderer.alignedObjects.push(elemWrapper);\r\n }\r\n }\r\n\r\n box = pick(box, elemWrapper.renderer);\r\n\r\n var align = alignOptions.align,\r\n vAlign = alignOptions.verticalAlign,\r\n x = (box.x || 0) + (alignOptions.x || 0), // default: left align\r\n y = (box.y || 0) + (alignOptions.y || 0), // default: top align\r\n attribs = {};\r\n\r\n // align\r\n if (align === \"right\" || align === \"center\") {\r\n x +=\r\n (box.width - (alignOptions.width || 0)) /\r\n { right: 1, center: 2 }[align];\r\n }\r\n attribs[alignByTranslate ? \"translateX\" : \"x\"] = mathRound(x);\r\n\r\n // vertical align\r\n if (vAlign === \"bottom\" || vAlign === \"middle\") {\r\n y +=\r\n (box.height - (alignOptions.height || 0)) /\r\n ({ bottom: 1, middle: 2 }[vAlign] || 1);\r\n }\r\n attribs[alignByTranslate ? \"translateY\" : \"y\"] = mathRound(y);\r\n\r\n // animate only if already placed\r\n elemWrapper[elemWrapper.placed ? \"animate\" : \"attr\"](attribs);\r\n elemWrapper.placed = true;\r\n elemWrapper.alignAttr = attribs;\r\n\r\n return elemWrapper;\r\n },\r\n\r\n /**\r\n * Get the bounding box (width, height, x and y) for the element\r\n */\r\n getBBox: function() {\r\n var wrapper = this,\r\n bBox = wrapper.bBox,\r\n renderer = wrapper.renderer,\r\n width,\r\n height,\r\n rotation = wrapper.rotation,\r\n element = wrapper.element,\r\n styles = wrapper.styles,\r\n rad = rotation * deg2rad;\r\n\r\n if (!bBox) {\r\n // SVG elements\r\n if (element.namespaceURI === SVG_NS || renderer.forExport) {\r\n try {\r\n // Fails in Firefox if the container has display: none.\r\n\r\n bBox = element.getBBox\r\n ? // SVG: use extend because IE9 is not allowed to change width and height in case\r\n // of rotation (below)\r\n extend({}, element.getBBox())\r\n : // Canvas renderer and legacy IE in export mode\r\n {\r\n width: element.offsetWidth,\r\n height: element.offsetHeight\r\n };\r\n }\r\n catch (e) {}\r\n\r\n // If the bBox is not set, the try-catch block above failed. The other condition\r\n // is for Opera that returns a width of -Infinity on hidden elements.\r\n if (!bBox || bBox.width < 0) {\r\n bBox = { width: 0, height: 0 };\r\n }\r\n\r\n // VML Renderer or useHTML within SVG\r\n }\r\n else {\r\n bBox = wrapper.htmlGetBBox();\r\n }\r\n\r\n // True SVG elements as well as HTML elements in modern browsers using the .useHTML option\r\n // need to compensated for rotation\r\n if (renderer.isSVG) {\r\n width = bBox.width;\r\n height = bBox.height;\r\n\r\n // Workaround for wrong bounding box in IE9 and IE10 (#1101)\r\n if (\r\n isIE &&\r\n styles &&\r\n styles.fontSize === \"11px\" &&\r\n height === 22.700000762939453\r\n ) {\r\n bBox.height = height = 14;\r\n }\r\n\r\n // Adjust for rotated text\r\n if (rotation) {\r\n bBox.width =\r\n mathAbs(height * mathSin(rad)) + mathAbs(width * mathCos(rad));\r\n bBox.height =\r\n mathAbs(height * mathCos(rad)) + mathAbs(width * mathSin(rad));\r\n }\r\n }\r\n\r\n wrapper.bBox = bBox;\r\n }\r\n return bBox;\r\n },\r\n\r\n /**\r\n * Show the element\r\n */\r\n show: function() {\r\n return this.attr({ visibility: VISIBLE });\r\n },\r\n\r\n /**\r\n * Hide the element\r\n */\r\n hide: function() {\r\n return this.attr({ visibility: HIDDEN });\r\n },\r\n\r\n /**\r\n * Add the element\r\n * @param {Object|Undefined} parent Can be an element, an element wrapper or undefined\r\n * to append the element to the renderer.box.\r\n */\r\n add: function(parent) {\r\n var renderer = this.renderer,\r\n parentWrapper = parent || renderer,\r\n parentNode = parentWrapper.element || renderer.box,\r\n childNodes = parentNode.childNodes,\r\n element = this.element,\r\n zIndex = attr(element, \"zIndex\"),\r\n otherElement,\r\n otherZIndex,\r\n i,\r\n inserted;\r\n\r\n if (parent) {\r\n this.parentGroup = parent;\r\n }\r\n\r\n // mark as inverted\r\n this.parentInverted = parent && parent.inverted;\r\n\r\n // build formatted text\r\n if (this.textStr !== undefined) {\r\n renderer.buildText(this);\r\n }\r\n\r\n // mark the container as having z indexed children\r\n if (zIndex) {\r\n parentWrapper.handleZ = true;\r\n zIndex = pInt(zIndex);\r\n }\r\n\r\n // insert according to this and other elements' zIndex\r\n if (parentWrapper.handleZ) {\r\n // this element or any of its siblings has a z index\r\n for (i = 0; i < childNodes.length; i++) {\r\n otherElement = childNodes[i];\r\n otherZIndex = attr(otherElement, \"zIndex\");\r\n if (\r\n otherElement !== element &&\r\n // insert before the first element with a higher zIndex\r\n (pInt(otherZIndex) > zIndex ||\r\n // if no zIndex given, insert before the first element with a zIndex\r\n (!defined(zIndex) && defined(otherZIndex)))\r\n ) {\r\n parentNode.insertBefore(element, otherElement);\r\n inserted = true;\r\n break;\r\n }\r\n }\r\n }\r\n\r\n // default: append at the end\r\n if (!inserted) {\r\n parentNode.appendChild(element);\r\n }\r\n\r\n // mark as added\r\n this.added = true;\r\n\r\n // fire an event for internal hooks\r\n fireEvent(this, \"add\");\r\n\r\n return this;\r\n },\r\n\r\n /**\r\n * Removes a child either by removeChild or move to garbageBin.\r\n * Issue 490; in VML removeChild results in Orphaned nodes according to sIEve, discardElement does not.\r\n */\r\n safeRemoveChild: function(element) {\r\n var parentNode = element.parentNode;\r\n if (parentNode) {\r\n parentNode.removeChild(element);\r\n }\r\n },\r\n\r\n /**\r\n * Destroy the element and element wrapper\r\n */\r\n destroy: function() {\r\n var wrapper = this,\r\n element = wrapper.element || {},\r\n shadows = wrapper.shadows,\r\n key,\r\n i;\r\n\r\n // remove events\r\n element.onclick = element.onmouseout = element.onmouseover = element.onmousemove = null;\r\n stop(wrapper); // stop running animations\r\n\r\n if (wrapper.clipPath) {\r\n wrapper.clipPath = wrapper.clipPath.destroy();\r\n }\r\n\r\n // Destroy stops in case this is a gradient object\r\n if (wrapper.stops) {\r\n for (i = 0; i < wrapper.stops.length; i++) {\r\n wrapper.stops[i] = wrapper.stops[i].destroy();\r\n }\r\n wrapper.stops = null;\r\n }\r\n\r\n // remove element\r\n wrapper.safeRemoveChild(element);\r\n\r\n // destroy shadows\r\n if (shadows) {\r\n each(shadows, function(shadow) {\r\n wrapper.safeRemoveChild(shadow);\r\n });\r\n }\r\n\r\n // remove from alignObjects\r\n erase(wrapper.renderer.alignedObjects, wrapper);\r\n\r\n for (key in wrapper) {\r\n delete wrapper[key];\r\n }\r\n\r\n return null;\r\n },\r\n\r\n /**\r\n * Empty a group element\r\n */\r\n empty: function() {\r\n var element = this.element,\r\n childNodes = element.childNodes,\r\n i = childNodes.length;\r\n\r\n while (i--) {\r\n element.removeChild(childNodes[i]);\r\n }\r\n },\r\n\r\n /**\r\n * Add a shadow to the element. Must be done after the element is added to the DOM\r\n * @param {Boolean|Object} shadowOptions\r\n */\r\n shadow: function(shadowOptions, group, cutOff) {\r\n var shadows = [],\r\n i,\r\n shadow,\r\n element = this.element,\r\n strokeWidth,\r\n shadowWidth,\r\n shadowElementOpacity,\r\n // compensate for inverted plot area\r\n transform;\r\n\r\n if (shadowOptions) {\r\n shadowWidth = pick(shadowOptions.width, 3);\r\n shadowElementOpacity = (shadowOptions.opacity || 0.15) / shadowWidth;\r\n transform = this.parentInverted\r\n ? \"(-1,-1)\"\r\n : \"(\" +\r\n pick(shadowOptions.offsetX, 1) +\r\n \", \" +\r\n pick(shadowOptions.offsetY, 1) +\r\n \")\";\r\n for (i = 1; i <= shadowWidth; i++) {\r\n shadow = element.cloneNode(0);\r\n strokeWidth = shadowWidth * 2 + 1 - 2 * i;\r\n attr(shadow, {\r\n isShadow: \"true\",\r\n stroke: shadowOptions.color || \"black\",\r\n \"stroke-opacity\": shadowElementOpacity * i,\r\n \"stroke-width\": strokeWidth,\r\n transform: \"translate\" + transform,\r\n fill: NONE\r\n });\r\n if (cutOff) {\r\n attr(\r\n shadow,\r\n \"height\",\r\n mathMax(attr(shadow, \"height\") - strokeWidth, 0)\r\n );\r\n shadow.cutHeight = strokeWidth;\r\n }\r\n\r\n if (group) {\r\n group.element.appendChild(shadow);\r\n }\r\n else {\r\n element.parentNode.insertBefore(shadow, element);\r\n }\r\n\r\n shadows.push(shadow);\r\n }\r\n\r\n this.shadows = shadows;\r\n }\r\n return this;\r\n }\r\n };\r\n\r\n /**\r\n * The default SVG renderer\r\n */\r\n var SVGRenderer = function() {\r\n this.init.apply(this, arguments);\r\n };\r\n SVGRenderer.prototype = {\r\n Element: SVGElement,\r\n\r\n /**\r\n * Initialize the SVGRenderer\r\n * @param {Object} container\r\n * @param {Number} width\r\n * @param {Number} height\r\n * @param {Boolean} forExport\r\n */\r\n init: function(container, width, height, forExport) {\r\n var renderer = this,\r\n loc = location,\r\n boxWrapper;\r\n\r\n boxWrapper = renderer.createElement(\"svg\").attr({\r\n xmlns: SVG_NS,\r\n version: \"1.1\"\r\n });\r\n container.appendChild(boxWrapper.element);\r\n\r\n // object properties\r\n renderer.isSVG = true;\r\n renderer.box = boxWrapper.element;\r\n renderer.boxWrapper = boxWrapper;\r\n renderer.alignedObjects = [];\r\n\r\n // Page url used for internal references. #24, #672, #1070\r\n renderer.url =\r\n (isFirefox || isWebKit) && doc.getElementsByTagName(\"base\").length\r\n ? loc.href\r\n .replace(/#.*?$/, \"\") // remove the hash\r\n .replace(/([\\('\\)])/g, \"\\\\$1\") // escape parantheses and quotes\r\n .replace(/ /g, \"%20\") // replace spaces (needed for Safari only)\r\n : \"\";\r\n\r\n renderer.defs = this.createElement(\"defs\").add();\r\n renderer.forExport = forExport;\r\n renderer.gradients = {}; // Object where gradient SvgElements are stored\r\n\r\n renderer.setSize(width, height, false);\r\n\r\n // Issue 110 workaround:\r\n // In Firefox, if a div is positioned by percentage, its pixel position may land\r\n // between pixels. The container itself doesn't display this, but an SVG element\r\n // inside this container will be drawn at subpixel precision. In order to draw\r\n // sharp lines, this must be compensated for. This doesn't seem to work inside\r\n // iframes though (like in jsFiddle).\r\n var subPixelFix, rect;\r\n if (isFirefox && container.getBoundingClientRect) {\r\n renderer.subPixelFix = subPixelFix = function() {\r\n css(container, { left: 0, top: 0 });\r\n rect = container.getBoundingClientRect();\r\n css(container, {\r\n left: mathCeil(rect.left) - rect.left + PX,\r\n top: mathCeil(rect.top) - rect.top + PX\r\n });\r\n };\r\n\r\n // run the fix now\r\n subPixelFix();\r\n\r\n // run it on resize\r\n addEvent(win, \"resize\", subPixelFix);\r\n }\r\n },\r\n\r\n /**\r\n * Detect whether the renderer is hidden. This happens when one of the parent elements\r\n * has display: none. #608.\r\n */\r\n isHidden: function() {\r\n return !this.boxWrapper.getBBox().width;\r\n },\r\n\r\n /**\r\n * Destroys the renderer and its allocated members.\r\n */\r\n destroy: function() {\r\n var renderer = this,\r\n rendererDefs = renderer.defs;\r\n renderer.box = null;\r\n renderer.boxWrapper = renderer.boxWrapper.destroy();\r\n\r\n // Call destroy on all gradient elements\r\n destroyObjectProperties(renderer.gradients || {});\r\n renderer.gradients = null;\r\n\r\n // Defs are null in VMLRenderer\r\n // Otherwise, destroy them here.\r\n if (rendererDefs) {\r\n renderer.defs = rendererDefs.destroy();\r\n }\r\n\r\n // Remove sub pixel fix handler\r\n // We need to check that there is a handler, otherwise all functions that are registered for event 'resize' are removed\r\n // See issue #982\r\n if (renderer.subPixelFix) {\r\n removeEvent(win, \"resize\", renderer.subPixelFix);\r\n }\r\n\r\n renderer.alignedObjects = null;\r\n\r\n return null;\r\n },\r\n\r\n /**\r\n * Create a wrapper for an SVG element\r\n * @param {Object} nodeName\r\n */\r\n createElement: function(nodeName) {\r\n var wrapper = new this.Element();\r\n wrapper.init(this, nodeName);\r\n return wrapper;\r\n },\r\n\r\n /**\r\n * Dummy function for use in canvas renderer\r\n */\r\n draw: function() {},\r\n\r\n /**\r\n * Parse a simple HTML string into SVG tspans\r\n *\r\n * @param {Object} textNode The parent text SVG node\r\n */\r\n buildText: function(wrapper) {\r\n var textNode = wrapper.element,\r\n lines = pick(wrapper.textStr, \"\")\r\n .toString()\r\n .replace(/<(b|strong)>/g, '')\r\n .replace(/<(i|em)>/g, '')\r\n .replace(//g, \"\")\r\n .split(//g),\r\n childNodes = textNode.childNodes,\r\n styleRegex = /style=\"([^\"]+)\"/,\r\n hrefRegex = /href=\"([^\"]+)\"/,\r\n parentX = attr(textNode, \"x\"),\r\n textStyles = wrapper.styles,\r\n width = textStyles && textStyles.width && pInt(textStyles.width),\r\n textLineHeight = textStyles && textStyles.lineHeight,\r\n lastLine,\r\n GET_COMPUTED_STYLE = \"getComputedStyle\",\r\n i = childNodes.length,\r\n linePositions = [];\r\n\r\n // Needed in IE9 because it doesn't report tspan's offsetHeight (#893)\r\n function getLineHeightByBBox(lineNo) {\r\n linePositions[lineNo] = textNode.getBBox\r\n ? textNode.getBBox().height\r\n : wrapper.renderer.fontMetrics(textNode.style.fontSize).h; // #990\r\n return mathRound(\r\n linePositions[lineNo] - (linePositions[lineNo - 1] || 0)\r\n );\r\n }\r\n\r\n // remove old text\r\n while (i--) {\r\n textNode.removeChild(childNodes[i]);\r\n }\r\n\r\n if (width && !wrapper.added) {\r\n this.box.appendChild(textNode); // attach it to the DOM to read offset width\r\n }\r\n\r\n // remove empty line at end\r\n if (lines[lines.length - 1] === \"\") {\r\n lines.pop();\r\n }\r\n\r\n // build the lines\r\n each(lines, function(line, lineNo) {\r\n var spans,\r\n spanNo = 0,\r\n lineHeight;\r\n\r\n line = line\r\n .replace(//g, \"|||\");\r\n spans = line.split(\"|||\");\r\n\r\n each(spans, function(span) {\r\n if (span !== \"\" || spans.length === 1) {\r\n var attributes = {},\r\n tspan = doc.createElementNS(SVG_NS, \"tspan\"),\r\n spanStyle; // #390\r\n if (styleRegex.test(span)) {\r\n spanStyle = span\r\n .match(styleRegex)[1]\r\n .replace(/(;| |^)color([ :])/, \"$1fill$2\");\r\n attr(tspan, \"style\", spanStyle);\r\n }\r\n if (hrefRegex.test(span)) {\r\n attr(\r\n tspan,\r\n \"onclick\",\r\n 'location.href=\"' + span.match(hrefRegex)[1] + '\"'\r\n );\r\n css(tspan, { cursor: \"pointer\" });\r\n }\r\n\r\n span = (span.replace(/<(.|\\n)*?>/g, \"\") || \" \")\r\n .replace(/</g, \"<\")\r\n .replace(/>/g, \">\");\r\n\r\n // issue #38 workaround.\r\n /*if (reverse) {\r\n\t\t\t\t\t\tarr = [];\r\n\t\t\t\t\t\ti = span.length;\r\n\t\t\t\t\t\twhile (i--) {\r\n\t\t\t\t\t\t\tarr.push(span.charAt(i));\r\n\t\t\t\t\t\t}\r\n\t\t\t\t\t\tspan = arr.join('');\r\n\t\t\t\t\t}*/\r\n\r\n // add the text node\r\n tspan.appendChild(doc.createTextNode(span));\r\n\r\n if (!spanNo) {\r\n // first span in a line, align it to the left\r\n attributes.x = parentX;\r\n }\r\n else {\r\n // Firefox ignores spaces at the front or end of the tspan\r\n attributes.dx = 3; // space\r\n }\r\n\r\n // first span on subsequent line, add the line height\r\n if (!spanNo) {\r\n if (lineNo) {\r\n // allow getting the right offset height in exporting in IE\r\n if (!hasSVG && wrapper.renderer.forExport) {\r\n css(tspan, { display: \"block\" });\r\n }\r\n\r\n // Webkit and opera sometimes return 'normal' as the line height. In that\r\n // case, webkit uses offsetHeight, while Opera falls back to 18\r\n lineHeight =\r\n win[GET_COMPUTED_STYLE] &&\r\n pInt(\r\n win[GET_COMPUTED_STYLE](lastLine, null).getPropertyValue(\r\n \"line-height\"\r\n )\r\n );\r\n\r\n if (!lineHeight || isNaN(lineHeight)) {\r\n lineHeight =\r\n textLineHeight ||\r\n lastLine.offsetHeight ||\r\n getLineHeightByBBox(lineNo) ||\r\n 18;\r\n }\r\n attr(tspan, \"dy\", lineHeight);\r\n }\r\n lastLine = tspan; // record for use in next line\r\n }\r\n\r\n // add attributes\r\n attr(tspan, attributes);\r\n\r\n // append it\r\n textNode.appendChild(tspan);\r\n\r\n spanNo++;\r\n\r\n // check width and apply soft breaks\r\n if (width) {\r\n var words = span.replace(/([^\\^])-/g, \"$1- \").split(\" \"), // #1273\r\n tooLong,\r\n actualWidth,\r\n rest = [];\r\n\r\n while (words.length || rest.length) {\r\n delete wrapper.bBox; // delete cache\r\n actualWidth = wrapper.getBBox().width;\r\n tooLong = actualWidth > width;\r\n if (!tooLong || words.length === 1) {\r\n // new line needed\r\n words = rest;\r\n rest = [];\r\n if (words.length) {\r\n tspan = doc.createElementNS(SVG_NS, \"tspan\");\r\n attr(tspan, {\r\n dy: textLineHeight || 16,\r\n x: parentX\r\n });\r\n if (spanStyle) {\r\n // #390\r\n attr(tspan, \"style\", spanStyle);\r\n }\r\n textNode.appendChild(tspan);\r\n\r\n if (actualWidth > width) {\r\n // a single word is pressing it out\r\n width = actualWidth;\r\n }\r\n }\r\n }\r\n else {\r\n // append to existing line tspan\r\n tspan.removeChild(tspan.firstChild);\r\n rest.unshift(words.pop());\r\n }\r\n if (words.length) {\r\n tspan.appendChild(\r\n doc.createTextNode(words.join(\" \").replace(/- /g, \"-\"))\r\n );\r\n }\r\n }\r\n }\r\n }\r\n });\r\n });\r\n },\r\n\r\n /**\r\n * Create a button with preset states\r\n * @param {String} text\r\n * @param {Number} x\r\n * @param {Number} y\r\n * @param {Function} callback\r\n * @param {Object} normalState\r\n * @param {Object} hoverState\r\n * @param {Object} pressedState\r\n */\r\n button: function(\r\n text,\r\n x,\r\n y,\r\n callback,\r\n normalState,\r\n hoverState,\r\n pressedState\r\n ) {\r\n var label = this.label(text, x, y),\r\n curState = 0,\r\n stateOptions,\r\n stateStyle,\r\n normalStyle,\r\n hoverStyle,\r\n pressedStyle,\r\n STYLE = \"style\",\r\n verticalGradient = { x1: 0, y1: 0, x2: 0, y2: 1 };\r\n\r\n // prepare the attributes\r\n /*jslint white: true*/\r\n normalState = merge(\r\n hash(\r\n STROKE_WIDTH,\r\n 1,\r\n STROKE,\r\n \"#999\",\r\n FILL,\r\n hash(LINEAR_GRADIENT, verticalGradient, STOPS, [\r\n [0, \"#FFF\"],\r\n [1, \"#DDD\"]\r\n ]),\r\n \"r\",\r\n 3,\r\n \"padding\",\r\n 3,\r\n STYLE,\r\n hash(\"color\", \"black\")\r\n ),\r\n normalState\r\n );\r\n /*jslint white: false*/\r\n normalStyle = normalState[STYLE];\r\n delete normalState[STYLE];\r\n\r\n /*jslint white: true*/\r\n hoverState = merge(\r\n normalState,\r\n hash(\r\n STROKE,\r\n \"#68A\",\r\n FILL,\r\n hash(LINEAR_GRADIENT, verticalGradient, STOPS, [\r\n [0, \"#FFF\"],\r\n [1, \"#ACF\"]\r\n ])\r\n ),\r\n hoverState\r\n );\r\n /*jslint white: false*/\r\n hoverStyle = hoverState[STYLE];\r\n delete hoverState[STYLE];\r\n\r\n /*jslint white: true*/\r\n pressedState = merge(\r\n normalState,\r\n hash(\r\n STROKE,\r\n \"#68A\",\r\n FILL,\r\n hash(LINEAR_GRADIENT, verticalGradient, STOPS, [\r\n [0, \"#9BD\"],\r\n [1, \"#CDF\"]\r\n ])\r\n ),\r\n pressedState\r\n );\r\n /*jslint white: false*/\r\n pressedStyle = pressedState[STYLE];\r\n delete pressedState[STYLE];\r\n\r\n // add the events\r\n addEvent(label.element, \"mouseenter\", function() {\r\n label.attr(hoverState).css(hoverStyle);\r\n });\r\n addEvent(label.element, \"mouseleave\", function() {\r\n stateOptions = [normalState, hoverState, pressedState][curState];\r\n stateStyle = [normalStyle, hoverStyle, pressedStyle][curState];\r\n label.attr(stateOptions).css(stateStyle);\r\n });\r\n\r\n label.setState = function(state) {\r\n curState = state;\r\n if (!state) {\r\n label.attr(normalState).css(normalStyle);\r\n }\r\n else if (state === 2) {\r\n label.attr(pressedState).css(pressedStyle);\r\n }\r\n };\r\n\r\n return label\r\n .on(\"click\", function() {\r\n callback.call(label);\r\n })\r\n .attr(normalState)\r\n .css(extend({ cursor: \"default\" }, normalStyle));\r\n },\r\n\r\n /**\r\n * Make a straight line crisper by not spilling out to neighbour pixels\r\n * @param {Array} points\r\n * @param {Number} width\r\n */\r\n crispLine: function(points, width) {\r\n // points format: [M, 0, 0, L, 100, 0]\r\n // normalize to a crisp line\r\n if (points[1] === points[4]) {\r\n // Substract due to #1129. Now bottom and left axis gridlines behave the same.\r\n points[1] = points[4] = mathRound(points[1]) - (width % 2) / 2;\r\n }\r\n if (points[2] === points[5]) {\r\n points[2] = points[5] = mathRound(points[2]) + (width % 2) / 2;\r\n }\r\n return points;\r\n },\r\n\r\n /**\r\n * Draw a path\r\n * @param {Array} path An SVG path in array form\r\n */\r\n path: function(path) {\r\n var attr = {\r\n fill: NONE\r\n };\r\n if (isArray(path)) {\r\n attr.d = path;\r\n }\r\n else if (isObject(path)) {\r\n // attributes\r\n extend(attr, path);\r\n }\r\n return this.createElement(\"path\").attr(attr);\r\n },\r\n\r\n /**\r\n * Draw and return an SVG circle\r\n * @param {Number} x The x position\r\n * @param {Number} y The y position\r\n * @param {Number} r The radius\r\n */\r\n circle: function(x, y, r) {\r\n var attr = isObject(x)\r\n ? x\r\n : {\r\n x: x,\r\n y: y,\r\n r: r\r\n };\r\n\r\n return this.createElement(\"circle\").attr(attr);\r\n },\r\n\r\n /**\r\n * Draw and return an arc\r\n * @param {Number} x X position\r\n * @param {Number} y Y position\r\n * @param {Number} r Radius\r\n * @param {Number} innerR Inner radius like used in donut charts\r\n * @param {Number} start Starting angle\r\n * @param {Number} end Ending angle\r\n */\r\n arc: function(x, y, r, innerR, start, end) {\r\n // arcs are defined as symbols for the ability to set\r\n // attributes in attr and animate\r\n\r\n if (isObject(x)) {\r\n y = x.y;\r\n r = x.r;\r\n innerR = x.innerR;\r\n start = x.start;\r\n end = x.end;\r\n x = x.x;\r\n }\r\n return this.symbol(\"arc\", x || 0, y || 0, r || 0, r || 0, {\r\n innerR: innerR || 0,\r\n start: start || 0,\r\n end: end || 0\r\n });\r\n },\r\n\r\n /**\r\n * Draw and return a rectangle\r\n * @param {Number} x Left position\r\n * @param {Number} y Top position\r\n * @param {Number} width\r\n * @param {Number} height\r\n * @param {Number} r Border corner radius\r\n * @param {Number} strokeWidth A stroke width can be supplied to allow crisp drawing\r\n */\r\n rect: function(x, y, width, height, r, strokeWidth) {\r\n r = isObject(x) ? x.r : r;\r\n\r\n var wrapper = this.createElement(\"rect\").attr({\r\n rx: r,\r\n ry: r,\r\n fill: NONE\r\n });\r\n return wrapper.attr(\r\n isObject(x)\r\n ? x\r\n : // do not crispify when an object is passed in (as in column charts)\r\n wrapper.crisp(\r\n strokeWidth,\r\n x,\r\n y,\r\n mathMax(width, 0),\r\n mathMax(height, 0)\r\n )\r\n );\r\n },\r\n\r\n /**\r\n * Resize the box and re-align all aligned elements\r\n * @param {Object} width\r\n * @param {Object} height\r\n * @param {Boolean} animate\r\n *\r\n */\r\n setSize: function(width, height, animate) {\r\n var renderer = this,\r\n alignedObjects = renderer.alignedObjects,\r\n i = alignedObjects.length;\r\n\r\n renderer.width = width;\r\n renderer.height = height;\r\n\r\n renderer.boxWrapper[pick(animate, true) ? \"animate\" : \"attr\"]({\r\n width: width,\r\n height: height\r\n });\r\n\r\n while (i--) {\r\n alignedObjects[i].align();\r\n }\r\n },\r\n\r\n /**\r\n * Create a group\r\n * @param {String} name The group will be given a class name of 'highcharts-{name}'.\r\n * This can be used for styling and scripting.\r\n */\r\n g: function(name) {\r\n var elem = this.createElement(\"g\");\r\n return defined(name) ? elem.attr({ class: PREFIX + name }) : elem;\r\n },\r\n\r\n /**\r\n * Display an image\r\n * @param {String} src\r\n * @param {Number} x\r\n * @param {Number} y\r\n * @param {Number} width\r\n * @param {Number} height\r\n */\r\n image: function(src, x, y, width, height) {\r\n var attribs = {\r\n preserveAspectRatio: NONE\r\n },\r\n elemWrapper;\r\n\r\n // optional properties\r\n if (arguments.length > 1) {\r\n extend(attribs, {\r\n x: x,\r\n y: y,\r\n width: width,\r\n height: height\r\n });\r\n }\r\n\r\n elemWrapper = this.createElement(\"image\").attr(attribs);\r\n\r\n // set the href in the xlink namespace\r\n if (elemWrapper.element.setAttributeNS) {\r\n elemWrapper.element.setAttributeNS(\r\n \"http://www.w3.org/1999/xlink\",\r\n \"href\",\r\n src\r\n );\r\n }\r\n else {\r\n // could be exporting in IE\r\n // using href throws \"not supported\" in ie7 and under, requries regex shim to fix later\r\n elemWrapper.element.setAttribute(\"hc-svg-href\", src);\r\n }\r\n\r\n return elemWrapper;\r\n },\r\n\r\n /**\r\n * Draw a symbol out of pre-defined shape paths from the namespace 'symbol' object.\r\n *\r\n * @param {Object} symbol\r\n * @param {Object} x\r\n * @param {Object} y\r\n * @param {Object} radius\r\n * @param {Object} options\r\n */\r\n symbol: function(symbol, x, y, width, height, options) {\r\n var obj,\r\n // get the symbol definition function\r\n symbolFn = this.symbols[symbol],\r\n // check if there's a path defined for this symbol\r\n path =\r\n symbolFn &&\r\n symbolFn(mathRound(x), mathRound(y), width, height, options),\r\n imageElement,\r\n imageRegex = /^url\\((.*?)\\)$/,\r\n imageSrc,\r\n imageSize,\r\n centerImage;\r\n\r\n if (path) {\r\n obj = this.path(path);\r\n // expando properties for use in animate and attr\r\n extend(obj, {\r\n symbolName: symbol,\r\n x: x,\r\n y: y,\r\n width: width,\r\n height: height\r\n });\r\n if (options) {\r\n extend(obj, options);\r\n }\r\n\r\n // image symbols\r\n }\r\n else if (imageRegex.test(symbol)) {\r\n // On image load, set the size and position\r\n centerImage = function(img, size) {\r\n if (img.element) {\r\n // it may be destroyed in the meantime (#1390)\r\n img.attr({\r\n width: size[0],\r\n height: size[1]\r\n });\r\n\r\n if (!img.alignByTranslate) {\r\n // #185\r\n img.translate(\r\n mathRound((width - size[0]) / 2), // #1378\r\n mathRound((height - size[1]) / 2)\r\n );\r\n }\r\n }\r\n };\r\n\r\n imageSrc = symbol.match(imageRegex)[1];\r\n imageSize = symbolSizes[imageSrc];\r\n\r\n // Ireate the image synchronously, add attribs async\r\n obj = this.image(imageSrc).attr({\r\n x: x,\r\n y: y\r\n });\r\n\r\n if (imageSize) {\r\n centerImage(obj, imageSize);\r\n }\r\n else {\r\n // Initialize image to be 0 size so export will still function if there's no cached sizes.\r\n //\r\n obj.attr({ width: 0, height: 0 });\r\n\r\n // Create a dummy JavaScript image to get the width and height. Due to a bug in IE < 8,\r\n // the created element must be assigned to a variable in order to load (#292).\r\n imageElement = createElement(\"img\", {\r\n onload: function() {\r\n centerImage(\r\n obj,\r\n (symbolSizes[imageSrc] = [this.width, this.height])\r\n );\r\n },\r\n src: imageSrc\r\n });\r\n }\r\n }\r\n\r\n return obj;\r\n },\r\n\r\n /**\r\n * An extendable collection of functions for defining symbol paths.\r\n */\r\n symbols: {\r\n circle: function(x, y, w, h) {\r\n var cpw = 0.166 * w;\r\n return [\r\n M,\r\n x + w / 2,\r\n y,\r\n \"C\",\r\n x + w + cpw,\r\n y,\r\n x + w + cpw,\r\n y + h,\r\n x + w / 2,\r\n y + h,\r\n \"C\",\r\n x - cpw,\r\n y + h,\r\n x - cpw,\r\n y,\r\n x + w / 2,\r\n y,\r\n \"Z\"\r\n ];\r\n },\r\n\r\n square: function(x, y, w, h) {\r\n return [M, x, y, L, x + w, y, x + w, y + h, x, y + h, \"Z\"];\r\n },\r\n\r\n triangle: function(x, y, w, h) {\r\n return [M, x + w / 2, y, L, x + w, y + h, x, y + h, \"Z\"];\r\n },\r\n\r\n \"triangle-down\": function(x, y, w, h) {\r\n return [M, x, y, L, x + w, y, x + w / 2, y + h, \"Z\"];\r\n },\r\n diamond: function(x, y, w, h) {\r\n return [\r\n M,\r\n x + w / 2,\r\n y,\r\n L,\r\n x + w,\r\n y + h / 2,\r\n x + w / 2,\r\n y + h,\r\n x,\r\n y + h / 2,\r\n \"Z\"\r\n ];\r\n },\r\n arc: function(x, y, w, h, options) {\r\n var start = options.start,\r\n radius = options.r || w || h,\r\n end = options.end - 0.000001, // to prevent cos and sin of start and end from becoming equal on 360 arcs\r\n innerRadius = options.innerR,\r\n open = options.open,\r\n cosStart = mathCos(start),\r\n sinStart = mathSin(start),\r\n cosEnd = mathCos(end),\r\n sinEnd = mathSin(end),\r\n longArc = options.end - start < mathPI ? 0 : 1;\r\n\r\n return [\r\n M,\r\n x + radius * cosStart,\r\n y + radius * sinStart,\r\n \"A\", // arcTo\r\n radius, // x radius\r\n radius, // y radius\r\n 0, // slanting\r\n longArc, // long or short arc\r\n 1, // clockwise\r\n x + radius * cosEnd,\r\n y + radius * sinEnd,\r\n open ? M : L,\r\n x + innerRadius * cosEnd,\r\n y + innerRadius * sinEnd,\r\n \"A\", // arcTo\r\n innerRadius, // x radius\r\n innerRadius, // y radius\r\n 0, // slanting\r\n longArc, // long or short arc\r\n 0, // clockwise\r\n x + innerRadius * cosStart,\r\n y + innerRadius * sinStart,\r\n\r\n open ? \"\" : \"Z\" // close\r\n ];\r\n }\r\n },\r\n\r\n /**\r\n * Define a clipping rectangle\r\n * @param {String} id\r\n * @param {Number} x\r\n * @param {Number} y\r\n * @param {Number} width\r\n * @param {Number} height\r\n */\r\n clipRect: function(x, y, width, height) {\r\n var wrapper,\r\n id = PREFIX + idCounter++,\r\n clipPath = this.createElement(\"clipPath\")\r\n .attr({\r\n id: id\r\n })\r\n .add(this.defs);\r\n\r\n wrapper = this.rect(x, y, width, height, 0).add(clipPath);\r\n wrapper.id = id;\r\n wrapper.clipPath = clipPath;\r\n\r\n return wrapper;\r\n },\r\n\r\n /**\r\n * Take a color and return it if it's a string, make it a gradient if it's a\r\n * gradient configuration object. Prior to Highstock, an array was used to define\r\n * a linear gradient with pixel positions relative to the SVG. In newer versions\r\n * we change the coordinates to apply relative to the shape, using coordinates\r\n * 0-1 within the shape. To preserve backwards compatibility, linearGradient\r\n * in this definition is an object of x1, y1, x2 and y2.\r\n *\r\n * @param {Object} color The color or config object\r\n */\r\n color: function(color, elem, prop) {\r\n var renderer = this,\r\n colorObject,\r\n regexRgba = /^rgba/,\r\n gradName,\r\n gradAttr,\r\n gradients,\r\n gradientObject,\r\n stops,\r\n stopColor,\r\n stopOpacity,\r\n radialReference,\r\n n,\r\n id,\r\n key = [];\r\n\r\n // Apply linear or radial gradients\r\n if (color && color.linearGradient) {\r\n gradName = \"linearGradient\";\r\n }\r\n else if (color && color.radialGradient) {\r\n gradName = \"radialGradient\";\r\n }\r\n\r\n if (gradName) {\r\n gradAttr = color[gradName];\r\n gradients = renderer.gradients;\r\n stops = color.stops;\r\n radialReference = elem.radialReference;\r\n\r\n // Keep < 2.2 kompatibility\r\n if (isArray(gradAttr)) {\r\n color[gradName] = gradAttr = {\r\n x1: gradAttr[0],\r\n y1: gradAttr[1],\r\n x2: gradAttr[2],\r\n y2: gradAttr[3],\r\n gradientUnits: \"userSpaceOnUse\"\r\n };\r\n }\r\n\r\n // Correct the radial gradient for the radial reference system\r\n if (\r\n gradName === \"radialGradient\" &&\r\n radialReference &&\r\n !defined(gradAttr.gradientUnits)\r\n ) {\r\n extend(gradAttr, {\r\n cx:\r\n radialReference[0] -\r\n radialReference[2] / 2 +\r\n gradAttr.cx * radialReference[2],\r\n cy:\r\n radialReference[1] -\r\n radialReference[2] / 2 +\r\n gradAttr.cy * radialReference[2],\r\n r: gradAttr.r * radialReference[2],\r\n gradientUnits: \"userSpaceOnUse\"\r\n });\r\n }\r\n\r\n // Build the unique key to detect whether we need to create a new element (#1282)\r\n for (n in gradAttr) {\r\n if (n !== \"id\") {\r\n key.push(n, gradAttr[n]);\r\n }\r\n }\r\n for (n in stops) {\r\n key.push(stops[n]);\r\n }\r\n key = key.join(\",\");\r\n\r\n // Check if a gradient object with the same config object is created within this renderer\r\n if (gradients[key]) {\r\n id = gradients[key].id;\r\n }\r\n else {\r\n // Set the id and create the element\r\n gradAttr.id = id = PREFIX + idCounter++;\r\n gradients[key] = gradientObject = renderer\r\n .createElement(gradName)\r\n .attr(gradAttr)\r\n .add(renderer.defs);\r\n\r\n // The gradient needs to keep a list of stops to be able to destroy them\r\n gradientObject.stops = [];\r\n each(stops, function(stop) {\r\n var stopObject;\r\n if (regexRgba.test(stop[1])) {\r\n colorObject = Color(stop[1]);\r\n stopColor = colorObject.get(\"rgb\");\r\n stopOpacity = colorObject.get(\"a\");\r\n }\r\n else {\r\n stopColor = stop[1];\r\n stopOpacity = 1;\r\n }\r\n stopObject = renderer\r\n .createElement(\"stop\")\r\n .attr({\r\n offset: stop[0],\r\n \"stop-color\": stopColor,\r\n \"stop-opacity\": stopOpacity\r\n })\r\n .add(gradientObject);\r\n\r\n // Add the stop element to the gradient\r\n gradientObject.stops.push(stopObject);\r\n });\r\n }\r\n\r\n // Return the reference to the gradient object\r\n return \"url(\" + renderer.url + \"#\" + id + \")\";\r\n\r\n // Webkit and Batik can't show rgba.\r\n }\r\n else if (regexRgba.test(color)) {\r\n colorObject = Color(color);\r\n attr(elem, prop + \"-opacity\", colorObject.get(\"a\"));\r\n\r\n return colorObject.get(\"rgb\");\r\n }\r\n else {\r\n // Remove the opacity attribute added above. Does not throw if the attribute is not there.\r\n elem.removeAttribute(prop + \"-opacity\");\r\n\r\n return color;\r\n }\r\n },\r\n\r\n /**\r\n * Add text to the SVG object\r\n * @param {String} str\r\n * @param {Number} x Left position\r\n * @param {Number} y Top position\r\n * @param {Boolean} useHTML Use HTML to render the text\r\n */\r\n text: function(str, x, y, useHTML) {\r\n // declare variables\r\n var renderer = this,\r\n defaultChartStyle = defaultOptions.chart.style,\r\n fakeSVG = useCanVG || (!hasSVG && renderer.forExport),\r\n wrapper;\r\n\r\n if (useHTML && !renderer.forExport) {\r\n return renderer.html(str, x, y);\r\n }\r\n\r\n x = mathRound(pick(x, 0));\r\n y = mathRound(pick(y, 0));\r\n\r\n wrapper = renderer\r\n .createElement(\"text\")\r\n .attr({\r\n x: x,\r\n y: y,\r\n text: str\r\n })\r\n .css({\r\n fontFamily: defaultChartStyle.fontFamily,\r\n fontSize: defaultChartStyle.fontSize\r\n });\r\n\r\n // Prevent wrapping from creating false offsetWidths in export in legacy IE (#1079, #1063)\r\n if (fakeSVG) {\r\n wrapper.css({\r\n position: ABSOLUTE\r\n });\r\n }\r\n\r\n wrapper.x = x;\r\n wrapper.y = y;\r\n return wrapper;\r\n },\r\n\r\n /**\r\n * Create HTML text node. This is used by the VML renderer as well as the SVG\r\n * renderer through the useHTML option.\r\n *\r\n * @param {String} str\r\n * @param {Number} x\r\n * @param {Number} y\r\n */\r\n html: function(str, x, y) {\r\n var defaultChartStyle = defaultOptions.chart.style,\r\n wrapper = this.createElement(\"span\"),\r\n attrSetters = wrapper.attrSetters,\r\n element = wrapper.element,\r\n renderer = wrapper.renderer;\r\n\r\n // Text setter\r\n attrSetters.text = function(value) {\r\n if (value !== element.innerHTML) {\r\n delete this.bBox;\r\n }\r\n element.innerHTML = value;\r\n return false;\r\n };\r\n\r\n // Various setters which rely on update transform\r\n attrSetters.x = attrSetters.y = attrSetters.align = function(value, key) {\r\n if (key === \"align\") {\r\n key = \"textAlign\"; // Do not overwrite the SVGElement.align method. Same as VML.\r\n }\r\n wrapper[key] = value;\r\n wrapper.htmlUpdateTransform();\r\n return false;\r\n };\r\n\r\n // Set the default attributes\r\n wrapper\r\n .attr({\r\n text: str,\r\n x: mathRound(x),\r\n y: mathRound(y)\r\n })\r\n .css({\r\n position: ABSOLUTE,\r\n whiteSpace: \"nowrap\",\r\n fontFamily: defaultChartStyle.fontFamily,\r\n fontSize: defaultChartStyle.fontSize\r\n });\r\n\r\n // Use the HTML specific .css method\r\n wrapper.css = wrapper.htmlCss;\r\n\r\n // This is specific for HTML within SVG\r\n if (renderer.isSVG) {\r\n wrapper.add = function(svgGroupWrapper) {\r\n var htmlGroup,\r\n container = renderer.box.parentNode,\r\n parentGroup,\r\n parents = [];\r\n\r\n // Create a mock group to hold the HTML elements\r\n if (svgGroupWrapper) {\r\n htmlGroup = svgGroupWrapper.div;\r\n if (!htmlGroup) {\r\n // Read the parent chain into an array and read from top down\r\n parentGroup = svgGroupWrapper;\r\n while (parentGroup) {\r\n parents.push(parentGroup);\r\n\r\n // Move up to the next parent group\r\n parentGroup = parentGroup.parentGroup;\r\n }\r\n\r\n // Ensure dynamically updating position when any parent is translated\r\n each(parents.reverse(), function(parentGroup) {\r\n var htmlGroupStyle;\r\n\r\n // Create a HTML div and append it to the parent div to emulate\r\n // the SVG group structure\r\n htmlGroup = parentGroup.div =\r\n parentGroup.div ||\r\n createElement(\r\n DIV,\r\n {\r\n className: attr(parentGroup.element, \"class\")\r\n },\r\n {\r\n position: ABSOLUTE,\r\n left: (parentGroup.translateX || 0) + PX,\r\n top: (parentGroup.translateY || 0) + PX\r\n },\r\n htmlGroup || container\r\n ); // the top group is appended to container\r\n\r\n // Shortcut\r\n htmlGroupStyle = htmlGroup.style;\r\n\r\n // Set listeners to update the HTML div's position whenever the SVG group\r\n // position is changed\r\n extend(parentGroup.attrSetters, {\r\n translateX: function(value) {\r\n htmlGroupStyle.left = value + PX;\r\n },\r\n translateY: function(value) {\r\n htmlGroupStyle.top = value + PX;\r\n },\r\n visibility: function(value, key) {\r\n htmlGroupStyle[key] = value;\r\n }\r\n });\r\n });\r\n }\r\n }\r\n else {\r\n htmlGroup = container;\r\n }\r\n\r\n htmlGroup.appendChild(element);\r\n\r\n // Shared with VML:\r\n wrapper.added = true;\r\n if (wrapper.alignOnAdd) {\r\n wrapper.htmlUpdateTransform();\r\n }\r\n\r\n return wrapper;\r\n };\r\n }\r\n return wrapper;\r\n },\r\n\r\n /**\r\n * Utility to return the baseline offset and total line height from the font size\r\n */\r\n fontMetrics: function(fontSize) {\r\n fontSize = pInt(fontSize || 11);\r\n\r\n // Empirical values found by comparing font size and bounding box height.\r\n // Applies to the default font family. http://jsfiddle.net/highcharts/7xvn7/\r\n var lineHeight = fontSize < 24 ? fontSize + 4 : mathRound(fontSize * 1.2),\r\n baseline = mathRound(lineHeight * 0.8);\r\n\r\n return {\r\n h: lineHeight,\r\n b: baseline\r\n };\r\n },\r\n\r\n /**\r\n * Add a label, a text item that can hold a colored or gradient background\r\n * as well as a border and shadow.\r\n * @param {string} str\r\n * @param {Number} x\r\n * @param {Number} y\r\n * @param {String} shape\r\n * @param {Number} anchorX In case the shape has a pointer, like a flag, this is the\r\n * coordinates it should be pinned to\r\n * @param {Number} anchorY\r\n * @param {Boolean} baseline Whether to position the label relative to the text baseline,\r\n * like renderer.text, or to the upper border of the rectangle.\r\n * @param {String} className Class name for the group\r\n */\r\n label: function(\r\n str,\r\n x,\r\n y,\r\n shape,\r\n anchorX,\r\n anchorY,\r\n useHTML,\r\n baseline,\r\n className\r\n ) {\r\n var renderer = this,\r\n wrapper = renderer.g(className),\r\n text = renderer.text(\"\", 0, 0, useHTML).attr({\r\n zIndex: 1\r\n }),\r\n //.add(wrapper),\r\n box,\r\n bBox,\r\n alignFactor = 0,\r\n padding = 3,\r\n width,\r\n height,\r\n wrapperX,\r\n wrapperY,\r\n crispAdjust = 0,\r\n deferredAttr = {},\r\n baselineOffset,\r\n attrSetters = wrapper.attrSetters,\r\n needsBox;\r\n\r\n /**\r\n * This function runs after the label is added to the DOM (when the bounding box is\r\n * available), and after the text of the label is updated to detect the new bounding\r\n * box and reflect it in the border box.\r\n */\r\n function updateBoxSize() {\r\n var boxY,\r\n style = text.element.style;\r\n\r\n bBox =\r\n (width === undefined ||\r\n height === undefined ||\r\n wrapper.styles.textAlign) &&\r\n text.getBBox();\r\n wrapper.width = (width || bBox.width || 0) + 2 * padding;\r\n wrapper.height = (height || bBox.height || 0) + 2 * padding;\r\n\r\n // update the label-scoped y offset\r\n baselineOffset =\r\n padding + renderer.fontMetrics(style && style.fontSize).b;\r\n\r\n if (needsBox) {\r\n // create the border box if it is not already present\r\n if (!box) {\r\n boxY = baseline ? -baselineOffset : 0;\r\n\r\n wrapper.box = box = shape\r\n ? renderer.symbol(\r\n shape,\r\n -alignFactor * padding,\r\n boxY,\r\n wrapper.width,\r\n wrapper.height\r\n )\r\n : renderer.rect(\r\n -alignFactor * padding,\r\n boxY,\r\n wrapper.width,\r\n wrapper.height,\r\n 0,\r\n deferredAttr[STROKE_WIDTH]\r\n );\r\n box.add(wrapper);\r\n }\r\n\r\n // apply the box attributes\r\n box.attr(\r\n merge(\r\n {\r\n width: wrapper.width,\r\n height: wrapper.height\r\n },\r\n deferredAttr\r\n )\r\n );\r\n deferredAttr = null;\r\n }\r\n }\r\n\r\n /**\r\n * This function runs after setting text or padding, but only if padding is changed\r\n */\r\n function updateTextPadding() {\r\n var styles = wrapper.styles,\r\n textAlign = styles && styles.textAlign,\r\n x = padding * (1 - alignFactor),\r\n y;\r\n\r\n // determin y based on the baseline\r\n y = baseline ? 0 : baselineOffset;\r\n\r\n // compensate for alignment\r\n if (\r\n defined(width) &&\r\n (textAlign === \"center\" || textAlign === \"right\")\r\n ) {\r\n x += { center: 0.5, right: 1 }[textAlign] * (width - bBox.width);\r\n }\r\n\r\n // update if anything changed\r\n if (x !== text.x || y !== text.y) {\r\n text.attr({\r\n x: x,\r\n y: y\r\n });\r\n }\r\n\r\n // record current values\r\n text.x = x;\r\n text.y = y;\r\n }\r\n\r\n /**\r\n * Set a box attribute, or defer it if the box is not yet created\r\n * @param {Object} key\r\n * @param {Object} value\r\n */\r\n function boxAttr(key, value) {\r\n if (box) {\r\n box.attr(key, value);\r\n }\r\n else {\r\n deferredAttr[key] = value;\r\n }\r\n }\r\n\r\n function getSizeAfterAdd() {\r\n text.add(wrapper);\r\n wrapper.attr({\r\n text: str, // alignment is available now\r\n x: x,\r\n y: y\r\n });\r\n\r\n if (box && defined(anchorX)) {\r\n wrapper.attr({\r\n anchorX: anchorX,\r\n anchorY: anchorY\r\n });\r\n }\r\n }\r\n\r\n /**\r\n * After the text element is added, get the desired size of the border box\r\n * and add it before the text in the DOM.\r\n */\r\n addEvent(wrapper, \"add\", getSizeAfterAdd);\r\n\r\n /*\r\n * Add specific attribute setters.\r\n */\r\n\r\n // only change local variables\r\n attrSetters.width = function(value) {\r\n width = value;\r\n return false;\r\n };\r\n attrSetters.height = function(value) {\r\n height = value;\r\n return false;\r\n };\r\n attrSetters.padding = function(value) {\r\n if (defined(value) && value !== padding) {\r\n padding = value;\r\n updateTextPadding();\r\n }\r\n\r\n return false;\r\n };\r\n\r\n // change local variable and set attribue as well\r\n attrSetters.align = function(value) {\r\n alignFactor = { left: 0, center: 0.5, right: 1 }[value];\r\n return false; // prevent setting text-anchor on the group\r\n };\r\n\r\n // apply these to the box and the text alike\r\n attrSetters.text = function(value, key) {\r\n text.attr(key, value);\r\n updateBoxSize();\r\n updateTextPadding();\r\n return false;\r\n };\r\n\r\n // apply these to the box but not to the text\r\n attrSetters[STROKE_WIDTH] = function(value, key) {\r\n needsBox = true;\r\n crispAdjust = (value % 2) / 2;\r\n boxAttr(key, value);\r\n return false;\r\n };\r\n attrSetters.stroke = attrSetters.fill = attrSetters.r = function(\r\n value,\r\n key\r\n ) {\r\n if (key === \"fill\") {\r\n needsBox = true;\r\n }\r\n boxAttr(key, value);\r\n return false;\r\n };\r\n attrSetters.anchorX = function(value, key) {\r\n anchorX = value;\r\n boxAttr(key, value + crispAdjust - wrapperX);\r\n return false;\r\n };\r\n attrSetters.anchorY = function(value, key) {\r\n anchorY = value;\r\n boxAttr(key, value - wrapperY);\r\n return false;\r\n };\r\n\r\n // rename attributes\r\n attrSetters.x = function(value) {\r\n wrapper.x = value; // for animation getter\r\n value -= alignFactor * ((width || bBox.width) + padding);\r\n wrapperX = mathRound(value);\r\n\r\n wrapper.attr(\"translateX\", wrapperX);\r\n return false;\r\n };\r\n attrSetters.y = function(value) {\r\n wrapperY = wrapper.y = mathRound(value);\r\n wrapper.attr(\"translateY\", value);\r\n return false;\r\n };\r\n\r\n // Redirect certain methods to either the box or the text\r\n var baseCss = wrapper.css;\r\n return extend(wrapper, {\r\n /**\r\n * Pick up some properties and apply them to the text instead of the wrapper\r\n */\r\n css: function(styles) {\r\n if (styles) {\r\n var textStyles = {};\r\n styles = merge({}, styles); // create a copy to avoid altering the original object (#537)\r\n each(\r\n [\r\n \"fontSize\",\r\n \"fontWeight\",\r\n \"fontFamily\",\r\n \"color\",\r\n \"lineHeight\",\r\n \"width\"\r\n ],\r\n function(prop) {\r\n if (styles[prop] !== UNDEFINED) {\r\n textStyles[prop] = styles[prop];\r\n delete styles[prop];\r\n }\r\n }\r\n );\r\n text.css(textStyles);\r\n }\r\n return baseCss.call(wrapper, styles);\r\n },\r\n /**\r\n * Return the bounding box of the box, not the group\r\n */\r\n getBBox: function() {\r\n return {\r\n width: bBox.width + 2 * padding,\r\n height: bBox.height + 2 * padding,\r\n x: bBox.x - padding,\r\n y: bBox.y - padding\r\n };\r\n },\r\n /**\r\n * Apply the shadow to the box\r\n */\r\n shadow: function(b) {\r\n if (box) {\r\n box.shadow(b);\r\n }\r\n return wrapper;\r\n },\r\n /**\r\n * Destroy and release memory.\r\n */\r\n destroy: function() {\r\n removeEvent(wrapper, \"add\", getSizeAfterAdd);\r\n\r\n // Added by button implementation\r\n removeEvent(wrapper.element, \"mouseenter\");\r\n removeEvent(wrapper.element, \"mouseleave\");\r\n\r\n if (text) {\r\n text = text.destroy();\r\n }\r\n if (box) {\r\n box = box.destroy();\r\n }\r\n // Call base implementation to destroy the rest\r\n SVGElement.prototype.destroy.call(wrapper);\r\n\r\n // Release local pointers (#1298)\r\n wrapper = renderer = updateBoxSize = updateTextPadding = boxAttr = getSizeAfterAdd = null;\r\n }\r\n });\r\n }\r\n }; // end SVGRenderer\r\n\r\n // general renderer\r\n Renderer = SVGRenderer;\r\n\r\n /* ****************************************************************************\r\n * *\r\n * START OF INTERNET EXPLORER <= 8 SPECIFIC CODE *\r\n * *\r\n * For applications and websites that don't need IE support, like platform *\r\n * targeted mobile apps and web apps, this code can be removed. *\r\n * *\r\n *****************************************************************************/\r\n\r\n /**\r\n * @constructor\r\n */\r\n var VMLRenderer;\r\n if (!hasSVG && !useCanVG) {\r\n /**\r\n * The VML element wrapper.\r\n */\r\n var VMLElement = {\r\n /**\r\n * Initialize a new VML element wrapper. It builds the markup as a string\r\n * to minimize DOM traffic.\r\n * @param {Object} renderer\r\n * @param {Object} nodeName\r\n */\r\n init: function(renderer, nodeName) {\r\n var wrapper = this,\r\n markup = [\"<\", nodeName, ' filled=\"f\" stroked=\"f\"'],\r\n style = [\"position: \", ABSOLUTE, \";\"];\r\n\r\n // divs and shapes need size\r\n if (nodeName === \"shape\" || nodeName === DIV) {\r\n style.push(\"left:0;top:0;width:1px;height:1px;\");\r\n }\r\n if (docMode8) {\r\n style.push(\"visibility: \", nodeName === DIV ? HIDDEN : VISIBLE);\r\n }\r\n\r\n markup.push(' style=\"', style.join(\"\"), '\"/>');\r\n\r\n // create element with default attributes and style\r\n if (nodeName) {\r\n markup =\r\n nodeName === DIV || nodeName === \"span\" || nodeName === \"img\"\r\n ? markup.join(\"\")\r\n : renderer.prepVML(markup);\r\n wrapper.element = createElement(markup);\r\n }\r\n\r\n wrapper.renderer = renderer;\r\n wrapper.attrSetters = {};\r\n },\r\n\r\n /**\r\n * Add the node to the given parent\r\n * @param {Object} parent\r\n */\r\n add: function(parent) {\r\n var wrapper = this,\r\n renderer = wrapper.renderer,\r\n element = wrapper.element,\r\n box = renderer.box,\r\n inverted = parent && parent.inverted,\r\n // get the parent node\r\n parentNode = parent ? parent.element || parent : box;\r\n\r\n // if the parent group is inverted, apply inversion on all children\r\n if (inverted) {\r\n // only on groups\r\n renderer.invertChild(element, parentNode);\r\n }\r\n\r\n // append it\r\n parentNode.appendChild(element);\r\n\r\n // align text after adding to be able to read offset\r\n wrapper.added = true;\r\n if (wrapper.alignOnAdd && !wrapper.deferUpdateTransform) {\r\n wrapper.updateTransform();\r\n }\r\n\r\n // fire an event for internal hooks\r\n fireEvent(wrapper, \"add\");\r\n\r\n return wrapper;\r\n },\r\n\r\n /**\r\n * VML always uses htmlUpdateTransform\r\n */\r\n updateTransform: SVGElement.prototype.htmlUpdateTransform,\r\n\r\n /**\r\n * Get or set attributes\r\n */\r\n attr: function(hash, val) {\r\n var wrapper = this,\r\n key,\r\n value,\r\n i,\r\n result,\r\n element = wrapper.element || {},\r\n elemStyle = element.style,\r\n nodeName = element.nodeName,\r\n renderer = wrapper.renderer,\r\n symbolName = wrapper.symbolName,\r\n hasSetSymbolSize,\r\n shadows = wrapper.shadows,\r\n skipAttr,\r\n attrSetters = wrapper.attrSetters,\r\n ret = wrapper;\r\n\r\n // single key-value pair\r\n if (isString(hash) && defined(val)) {\r\n key = hash;\r\n hash = {};\r\n hash[key] = val;\r\n }\r\n\r\n // used as a getter, val is undefined\r\n if (isString(hash)) {\r\n key = hash;\r\n if (key === \"strokeWidth\" || key === \"stroke-width\") {\r\n ret = wrapper.strokeweight;\r\n }\r\n else {\r\n ret = wrapper[key];\r\n }\r\n\r\n // setter\r\n }\r\n else {\r\n for (key in hash) {\r\n value = hash[key];\r\n skipAttr = false;\r\n\r\n // check for a specific attribute setter\r\n result =\r\n attrSetters[key] && attrSetters[key].call(wrapper, value, key);\r\n\r\n if (result !== false && value !== null) {\r\n // #620\r\n\r\n if (result !== UNDEFINED) {\r\n value = result; // the attribute setter has returned a new value to set\r\n }\r\n\r\n // prepare paths\r\n // symbols\r\n if (\r\n symbolName &&\r\n /^(x|y|r|start|end|width|height|innerR|anchorX|anchorY)/.test(\r\n key\r\n )\r\n ) {\r\n // if one of the symbol size affecting parameters are changed,\r\n // check all the others only once for each call to an element's\r\n // .attr() method\r\n if (!hasSetSymbolSize) {\r\n wrapper.symbolAttr(hash);\r\n\r\n hasSetSymbolSize = true;\r\n }\r\n skipAttr = true;\r\n }\r\n else if (key === \"d\") {\r\n value = value || [];\r\n wrapper.d = value.join(\" \"); // used in getter for animation\r\n\r\n // convert paths\r\n i = value.length;\r\n var convertedPath = [];\r\n while (i--) {\r\n // Multiply by 10 to allow subpixel precision.\r\n // Substracting half a pixel seems to make the coordinates\r\n // align with SVG, but this hasn't been tested thoroughly\r\n if (isNumber(value[i])) {\r\n convertedPath[i] = mathRound(value[i] * 10) - 5;\r\n }\r\n else if (value[i] === \"Z\") {\r\n // close the path\r\n convertedPath[i] = \"x\";\r\n }\r\n else {\r\n convertedPath[i] = value[i];\r\n }\r\n }\r\n value = convertedPath.join(\" \") || \"x\";\r\n element.path = value;\r\n\r\n // update shadows\r\n if (shadows) {\r\n i = shadows.length;\r\n while (i--) {\r\n shadows[i].path = shadows[i].cutOff\r\n ? this.cutOffPath(value, shadows[i].cutOff)\r\n : value;\r\n }\r\n }\r\n skipAttr = true;\r\n\r\n // handle visibility\r\n }\r\n else if (key === \"visibility\") {\r\n // let the shadow follow the main element\r\n if (shadows) {\r\n i = shadows.length;\r\n while (i--) {\r\n shadows[i].style[key] = value;\r\n }\r\n }\r\n\r\n // Instead of toggling the visibility CSS property, move the div out of the viewport.\r\n // This works around #61 and #586\r\n if (nodeName === \"DIV\") {\r\n value = value === HIDDEN ? \"-999em\" : 0;\r\n key = \"top\";\r\n }\r\n\r\n elemStyle[key] = value;\r\n skipAttr = true;\r\n\r\n // directly mapped to css\r\n }\r\n else if (key === \"zIndex\") {\r\n if (value) {\r\n elemStyle[key] = value;\r\n }\r\n skipAttr = true;\r\n\r\n // width and height\r\n }\r\n else if (key === \"width\" || key === \"height\") {\r\n value = mathMax(0, value); // don't set width or height below zero (#311)\r\n\r\n this[key] = value; // used in getter\r\n\r\n // clipping rectangle special\r\n if (wrapper.updateClipping) {\r\n wrapper[key] = value;\r\n wrapper.updateClipping();\r\n }\r\n else {\r\n // normal\r\n elemStyle[key] = value;\r\n }\r\n\r\n skipAttr = true;\r\n\r\n // x and y\r\n }\r\n else if (key === \"x\" || key === \"y\") {\r\n wrapper[key] = value; // used in getter\r\n elemStyle[{ x: \"left\", y: \"top\" }[key]] = value;\r\n\r\n // class name\r\n }\r\n else if (key === \"class\") {\r\n // IE8 Standards mode has problems retrieving the className\r\n element.className = value;\r\n\r\n // stroke\r\n }\r\n else if (key === \"stroke\") {\r\n value = renderer.color(value, element, key);\r\n\r\n key = \"strokecolor\";\r\n\r\n // stroke width\r\n }\r\n else if (key === \"stroke-width\" || key === \"strokeWidth\") {\r\n element.stroked = value ? true : false;\r\n key = \"strokeweight\";\r\n wrapper[key] = value; // used in getter, issue #113\r\n if (isNumber(value)) {\r\n value += PX;\r\n }\r\n\r\n // dashStyle\r\n }\r\n else if (key === \"dashstyle\") {\r\n var strokeElem =\r\n element.getElementsByTagName(\"stroke\")[0] ||\r\n createElement(\r\n renderer.prepVML([\"\"]),\r\n null,\r\n null,\r\n element\r\n );\r\n strokeElem[key] = value || \"solid\";\r\n wrapper.dashstyle = value; /* because changing stroke-width will change the dash length\r\n\t\t\t\t\t\t\tand cause an epileptic effect */\r\n skipAttr = true;\r\n\r\n // fill\r\n }\r\n else if (key === \"fill\") {\r\n if (nodeName === \"SPAN\") {\r\n // text color\r\n elemStyle.color = value;\r\n }\r\n else if (nodeName !== \"IMG\") {\r\n // #1336\r\n element.filled = value !== NONE ? true : false;\r\n\r\n value = renderer.color(value, element, key, wrapper);\r\n\r\n key = \"fillcolor\";\r\n }\r\n\r\n // rotation on VML elements\r\n }\r\n else if (nodeName === \"shape\" && key === \"rotation\") {\r\n wrapper[key] = value;\r\n // Correction for the 1x1 size of the shape container. Used in gauge needles.\r\n element.style.left =\r\n -mathRound(mathSin(value * deg2rad) + 1) + PX;\r\n element.style.top = mathRound(mathCos(value * deg2rad)) + PX;\r\n\r\n // translation for animation\r\n }\r\n else if (\r\n key === \"translateX\" ||\r\n key === \"translateY\" ||\r\n key === \"rotation\"\r\n ) {\r\n wrapper[key] = value;\r\n wrapper.updateTransform();\r\n\r\n skipAttr = true;\r\n\r\n // text for rotated and non-rotated elements\r\n }\r\n else if (key === \"text\") {\r\n this.bBox = null;\r\n element.innerHTML = value;\r\n skipAttr = true;\r\n }\r\n\r\n if (!skipAttr) {\r\n if (docMode8) {\r\n // IE8 setAttribute bug\r\n element[key] = value;\r\n }\r\n else {\r\n attr(element, key, value);\r\n }\r\n }\r\n }\r\n }\r\n }\r\n return ret;\r\n },\r\n\r\n /**\r\n * Set the element's clipping to a predefined rectangle\r\n *\r\n * @param {String} id The id of the clip rectangle\r\n */\r\n clip: function(clipRect) {\r\n var wrapper = this,\r\n clipMembers,\r\n element = wrapper.element,\r\n parentNode = element.parentNode,\r\n cssRet;\r\n\r\n if (clipRect) {\r\n clipMembers = clipRect.members;\r\n erase(clipMembers, wrapper); // Ensure unique list of elements (#1258)\r\n clipMembers.push(wrapper);\r\n wrapper.destroyClip = function() {\r\n erase(clipMembers, wrapper);\r\n };\r\n // Issue #863 workaround - related to #140, #61, #74\r\n if (\r\n parentNode &&\r\n parentNode.className === \"highcharts-tracker\" &&\r\n !docMode8\r\n ) {\r\n css(element, { visibility: HIDDEN });\r\n }\r\n cssRet = clipRect.getCSS(wrapper);\r\n }\r\n else {\r\n if (wrapper.destroyClip) {\r\n wrapper.destroyClip();\r\n }\r\n cssRet = { clip: docMode8 ? \"inherit\" : \"rect(auto)\" }; // #1214\r\n }\r\n\r\n return wrapper.css(cssRet);\r\n },\r\n\r\n /**\r\n * Set styles for the element\r\n * @param {Object} styles\r\n */\r\n css: SVGElement.prototype.htmlCss,\r\n\r\n /**\r\n * Removes a child either by removeChild or move to garbageBin.\r\n * Issue 490; in VML removeChild results in Orphaned nodes according to sIEve, discardElement does not.\r\n */\r\n safeRemoveChild: function(element) {\r\n // discardElement will detach the node from its parent before attaching it\r\n // to the garbage bin. Therefore it is important that the node is attached and have parent.\r\n if (element.parentNode) {\r\n discardElement(element);\r\n }\r\n },\r\n\r\n /**\r\n * Extend element.destroy by removing it from the clip members array\r\n */\r\n destroy: function() {\r\n if (this.destroyClip) {\r\n this.destroyClip();\r\n }\r\n\r\n return SVGElement.prototype.destroy.apply(this);\r\n },\r\n\r\n /**\r\n * Remove all child nodes of a group, except the v:group element\r\n */\r\n empty: function() {\r\n var element = this.element,\r\n childNodes = element.childNodes,\r\n i = childNodes.length,\r\n node;\r\n\r\n while (i--) {\r\n node = childNodes[i];\r\n node.parentNode.removeChild(node);\r\n }\r\n },\r\n\r\n /**\r\n * Add an event listener. VML override for normalizing event parameters.\r\n * @param {String} eventType\r\n * @param {Function} handler\r\n */\r\n on: function(eventType, handler) {\r\n // simplest possible event model for internal use\r\n this.element[\"on\" + eventType] = function() {\r\n var evt = win.event;\r\n evt.target = evt.srcElement;\r\n handler(evt);\r\n };\r\n return this;\r\n },\r\n\r\n /**\r\n * In stacked columns, cut off the shadows so that they don't overlap\r\n */\r\n cutOffPath: function(path, length) {\r\n var len;\r\n\r\n path = path.split(/[ ,]/);\r\n len = path.length;\r\n\r\n if (len === 9 || len === 11) {\r\n path[len - 4] = path[len - 2] = pInt(path[len - 2]) - 10 * length;\r\n }\r\n return path.join(\" \");\r\n },\r\n\r\n /**\r\n * Apply a drop shadow by copying elements and giving them different strokes\r\n * @param {Boolean|Object} shadowOptions\r\n */\r\n shadow: function(shadowOptions, group, cutOff) {\r\n var shadows = [],\r\n i,\r\n element = this.element,\r\n renderer = this.renderer,\r\n shadow,\r\n elemStyle = element.style,\r\n markup,\r\n path = element.path,\r\n strokeWidth,\r\n modifiedPath,\r\n shadowWidth,\r\n shadowElementOpacity;\r\n\r\n // some times empty paths are not strings\r\n if (path && typeof path.value !== \"string\") {\r\n path = \"x\";\r\n }\r\n modifiedPath = path;\r\n\r\n if (shadowOptions) {\r\n shadowWidth = pick(shadowOptions.width, 3);\r\n shadowElementOpacity = (shadowOptions.opacity || 0.15) / shadowWidth;\r\n for (i = 1; i <= 3; i++) {\r\n strokeWidth = shadowWidth * 2 + 1 - 2 * i;\r\n\r\n // Cut off shadows for stacked column items\r\n if (cutOff) {\r\n modifiedPath = this.cutOffPath(path.value, strokeWidth + 0.5);\r\n }\r\n\r\n markup = [\r\n ''\r\n ];\r\n\r\n shadow = createElement(renderer.prepVML(markup), null, {\r\n left: pInt(elemStyle.left) + pick(shadowOptions.offsetX, 1),\r\n top: pInt(elemStyle.top) + pick(shadowOptions.offsetY, 1)\r\n });\r\n if (cutOff) {\r\n shadow.cutOff = strokeWidth + 1;\r\n }\r\n\r\n // apply the opacity\r\n markup = [\r\n ''\r\n ];\r\n createElement(renderer.prepVML(markup), null, null, shadow);\r\n\r\n // insert it\r\n if (group) {\r\n group.element.appendChild(shadow);\r\n }\r\n else {\r\n element.parentNode.insertBefore(shadow, element);\r\n }\r\n\r\n // record it\r\n shadows.push(shadow);\r\n }\r\n\r\n this.shadows = shadows;\r\n }\r\n return this;\r\n }\r\n };\r\n VMLElement = extendClass(SVGElement, VMLElement);\r\n\r\n /**\r\n * The VML renderer\r\n */\r\n var VMLRendererExtension = {\r\n // inherit SVGRenderer\r\n\r\n Element: VMLElement,\r\n isIE8: userAgent.indexOf(\"MSIE 8.0\") > -1,\r\n\r\n /**\r\n * Initialize the VMLRenderer\r\n * @param {Object} container\r\n * @param {Number} width\r\n * @param {Number} height\r\n */\r\n init: function(container, width, height) {\r\n var renderer = this,\r\n boxWrapper,\r\n box;\r\n\r\n renderer.alignedObjects = [];\r\n\r\n boxWrapper = renderer.createElement(DIV);\r\n box = boxWrapper.element;\r\n box.style.position = RELATIVE; // for freeform drawing using renderer directly\r\n container.appendChild(boxWrapper.element);\r\n\r\n // generate the containing box\r\n renderer.box = box;\r\n renderer.boxWrapper = boxWrapper;\r\n\r\n renderer.setSize(width, height, false);\r\n\r\n // The only way to make IE6 and IE7 print is to use a global namespace. However,\r\n // with IE8 the only way to make the dynamic shapes visible in screen and print mode\r\n // seems to be to add the xmlns attribute and the behaviour style inline.\r\n if (!doc.namespaces.hcv) {\r\n doc.namespaces.add(\"hcv\", \"urn:schemas-microsoft-com:vml\");\r\n\r\n // setup default css\r\n doc.createStyleSheet().cssText =\r\n \"hcv\\\\:fill, hcv\\\\:path, hcv\\\\:shape, hcv\\\\:stroke\" +\r\n \"{ behavior:url(#default#VML); display: inline-block; } \";\r\n }\r\n },\r\n\r\n /**\r\n * Detect whether the renderer is hidden. This happens when one of the parent elements\r\n * has display: none\r\n */\r\n isHidden: function() {\r\n return !this.box.offsetWidth;\r\n },\r\n\r\n /**\r\n * Define a clipping rectangle. In VML it is accomplished by storing the values\r\n * for setting the CSS style to all associated members.\r\n *\r\n * @param {Number} x\r\n * @param {Number} y\r\n * @param {Number} width\r\n * @param {Number} height\r\n */\r\n clipRect: function(x, y, width, height) {\r\n // create a dummy element\r\n var clipRect = this.createElement(),\r\n isObj = isObject(x);\r\n\r\n // mimic a rectangle with its style object for automatic updating in attr\r\n return extend(clipRect, {\r\n members: [],\r\n left: isObj ? x.x : x,\r\n top: isObj ? x.y : y,\r\n width: isObj ? x.width : width,\r\n height: isObj ? x.height : height,\r\n getCSS: function(wrapper) {\r\n var inverted = wrapper.inverted,\r\n rect = this,\r\n top = rect.top,\r\n left = rect.left,\r\n right = left + rect.width,\r\n bottom = top + rect.height,\r\n ret = {\r\n clip:\r\n \"rect(\" +\r\n mathRound(inverted ? left : top) +\r\n \"px,\" +\r\n mathRound(inverted ? bottom : right) +\r\n \"px,\" +\r\n mathRound(inverted ? right : bottom) +\r\n \"px,\" +\r\n mathRound(inverted ? top : left) +\r\n \"px)\"\r\n };\r\n\r\n // issue 74 workaround\r\n if (!inverted && docMode8 && wrapper.element.nodeName !== \"IMG\") {\r\n extend(ret, {\r\n width: right + PX,\r\n height: bottom + PX\r\n });\r\n }\r\n\r\n return ret;\r\n },\r\n\r\n // used in attr and animation to update the clipping of all members\r\n updateClipping: function() {\r\n each(clipRect.members, function(member) {\r\n member.css(clipRect.getCSS(member));\r\n });\r\n }\r\n });\r\n },\r\n\r\n /**\r\n * Take a color and return it if it's a string, make it a gradient if it's a\r\n * gradient configuration object, and apply opacity.\r\n *\r\n * @param {Object} color The color or config object\r\n */\r\n color: function(color, elem, prop, wrapper) {\r\n var renderer = this,\r\n colorObject,\r\n regexRgba = /^rgba/,\r\n markup,\r\n fillType,\r\n ret = NONE;\r\n\r\n // Check for linear or radial gradient\r\n if (color && color.linearGradient) {\r\n fillType = \"gradient\";\r\n }\r\n else if (color && color.radialGradient) {\r\n fillType = \"pattern\";\r\n }\r\n\r\n if (fillType) {\r\n var stopColor,\r\n stopOpacity,\r\n gradient = color.linearGradient || color.radialGradient,\r\n x1,\r\n y1,\r\n x2,\r\n y2,\r\n opacity1,\r\n opacity2,\r\n color1,\r\n color2,\r\n fillAttr = \"\",\r\n stops = color.stops,\r\n firstStop,\r\n lastStop,\r\n colors = [],\r\n addFillNode = function() {\r\n // Add the fill subnode. When colors attribute is used, the meanings of opacity and o:opacity2\r\n // are reversed.\r\n markup = [\r\n ''\r\n ];\r\n createElement(renderer.prepVML(markup), null, null, elem);\r\n };\r\n\r\n // Extend from 0 to 1\r\n firstStop = stops[0];\r\n lastStop = stops[stops.length - 1];\r\n if (firstStop[0] > 0) {\r\n stops.unshift([0, firstStop[1]]);\r\n }\r\n if (lastStop[0] < 1) {\r\n stops.push([1, lastStop[1]]);\r\n }\r\n\r\n // Compute the stops\r\n each(stops, function(stop, i) {\r\n if (regexRgba.test(stop[1])) {\r\n colorObject = Color(stop[1]);\r\n stopColor = colorObject.get(\"rgb\");\r\n stopOpacity = colorObject.get(\"a\");\r\n }\r\n else {\r\n stopColor = stop[1];\r\n stopOpacity = 1;\r\n }\r\n\r\n // Build the color attribute\r\n colors.push(stop[0] * 100 + \"% \" + stopColor);\r\n\r\n // Only start and end opacities are allowed, so we use the first and the last\r\n if (!i) {\r\n opacity1 = stopOpacity;\r\n color2 = stopColor;\r\n }\r\n else {\r\n opacity2 = stopOpacity;\r\n color1 = stopColor;\r\n }\r\n });\r\n\r\n // Apply the gradient to fills only.\r\n if (prop === \"fill\") {\r\n // Handle linear gradient angle\r\n if (fillType === \"gradient\") {\r\n x1 = gradient.x1 || gradient[0] || 0;\r\n y1 = gradient.y1 || gradient[1] || 0;\r\n x2 = gradient.x2 || gradient[2] || 0;\r\n y2 = gradient.y2 || gradient[3] || 0;\r\n fillAttr =\r\n 'angle=\"' +\r\n (90 -\r\n (math.atan(\r\n (y2 - y1) / // y vector\r\n (x2 - x1) // x vector\r\n ) *\r\n 180) /\r\n mathPI) +\r\n '\"';\r\n\r\n addFillNode();\r\n\r\n // Radial (circular) gradient\r\n }\r\n else {\r\n var r = gradient.r,\r\n sizex = r * 2,\r\n sizey = r * 2,\r\n cx = gradient.cx,\r\n cy = gradient.cy,\r\n radialReference = elem.radialReference,\r\n bBox,\r\n applyRadialGradient = function() {\r\n if (radialReference) {\r\n bBox = wrapper.getBBox();\r\n cx += (radialReference[0] - bBox.x) / bBox.width - 0.5;\r\n cy += (radialReference[1] - bBox.y) / bBox.height - 0.5;\r\n sizex *= radialReference[2] / bBox.width;\r\n sizey *= radialReference[2] / bBox.height;\r\n }\r\n fillAttr =\r\n 'src=\"' +\r\n defaultOptions.global.VMLRadialGradientURL +\r\n '\" ' +\r\n 'size=\"' +\r\n sizex +\r\n \",\" +\r\n sizey +\r\n '\" ' +\r\n 'origin=\"0.5,0.5\" ' +\r\n 'position=\"' +\r\n cx +\r\n \",\" +\r\n cy +\r\n '\" ' +\r\n 'color2=\"' +\r\n color2 +\r\n '\" ';\r\n\r\n addFillNode();\r\n };\r\n\r\n // Apply radial gradient\r\n if (wrapper.added) {\r\n applyRadialGradient();\r\n }\r\n else {\r\n // We need to know the bounding box to get the size and position right\r\n addEvent(wrapper, \"add\", applyRadialGradient);\r\n }\r\n\r\n // The fill element's color attribute is broken in IE8 standards mode, so we\r\n // need to set the parent shape's fillcolor attribute instead.\r\n ret = color1;\r\n }\r\n\r\n // Gradients are not supported for VML stroke, return the first color. #722.\r\n }\r\n else {\r\n ret = stopColor;\r\n }\r\n\r\n // if the color is an rgba color, split it and add a fill node\r\n // to hold the opacity component\r\n }\r\n else if (regexRgba.test(color) && elem.tagName !== \"IMG\") {\r\n colorObject = Color(color);\r\n\r\n markup = [\"<\", prop, ' opacity=\"', colorObject.get(\"a\"), '\"/>'];\r\n createElement(this.prepVML(markup), null, null, elem);\r\n\r\n ret = colorObject.get(\"rgb\");\r\n }\r\n else {\r\n var strokeNodes = elem.getElementsByTagName(prop);\r\n if (strokeNodes.length) {\r\n strokeNodes[0].opacity = 1;\r\n }\r\n ret = color;\r\n }\r\n\r\n return ret;\r\n },\r\n\r\n /**\r\n * Take a VML string and prepare it for either IE8 or IE6/IE7.\r\n * @param {Array} markup A string array of the VML markup to prepare\r\n */\r\n prepVML: function(markup) {\r\n var vmlStyle = \"display:inline-block;behavior:url(#default#VML);\",\r\n isIE8 = this.isIE8;\r\n\r\n markup = markup.join(\"\");\r\n\r\n if (isIE8) {\r\n // add xmlns and style inline\r\n markup = markup.replace(\r\n \"/>\",\r\n ' xmlns=\"urn:schemas-microsoft-com:vml\" />'\r\n );\r\n if (markup.indexOf('style=\"') === -1) {\r\n markup = markup.replace(\"/>\", ' style=\"' + vmlStyle + '\" />');\r\n }\r\n else {\r\n markup = markup.replace('style=\"', 'style=\"' + vmlStyle);\r\n }\r\n }\r\n else {\r\n // add namespace\r\n markup = markup.replace(\"<\", \" 1) {\r\n obj.attr({\r\n x: x,\r\n y: y,\r\n width: width,\r\n height: height\r\n });\r\n }\r\n return obj;\r\n },\r\n\r\n /**\r\n * VML uses a shape for rect to overcome bugs and rotation problems\r\n */\r\n rect: function(x, y, width, height, r, strokeWidth) {\r\n if (isObject(x)) {\r\n y = x.y;\r\n width = x.width;\r\n height = x.height;\r\n strokeWidth = x.strokeWidth;\r\n x = x.x;\r\n }\r\n var wrapper = this.symbol(\"rect\");\r\n wrapper.r = r;\r\n\r\n return wrapper.attr(\r\n wrapper.crisp(\r\n strokeWidth,\r\n x,\r\n y,\r\n mathMax(width, 0),\r\n mathMax(height, 0)\r\n )\r\n );\r\n },\r\n\r\n /**\r\n * In the VML renderer, each child of an inverted div (group) is inverted\r\n * @param {Object} element\r\n * @param {Object} parentNode\r\n */\r\n invertChild: function(element, parentNode) {\r\n var parentStyle = parentNode.style;\r\n css(element, {\r\n flip: \"x\",\r\n left: pInt(parentStyle.width) - 1,\r\n top: pInt(parentStyle.height) - 1,\r\n rotation: -90\r\n });\r\n },\r\n\r\n /**\r\n * Symbol definitions that override the parent SVG renderer's symbols\r\n *\r\n */\r\n symbols: {\r\n // VML specific arc function\r\n arc: function(x, y, w, h, options) {\r\n var start = options.start,\r\n end = options.end,\r\n radius = options.r || w || h,\r\n cosStart = mathCos(start),\r\n sinStart = mathSin(start),\r\n cosEnd = mathCos(end),\r\n sinEnd = mathSin(end),\r\n innerRadius = options.innerR,\r\n circleCorrection = 0.08 / radius, // #760\r\n innerCorrection = (innerRadius && 0.1 / innerRadius) || 0,\r\n ret;\r\n\r\n if (end - start === 0) {\r\n // no angle, don't show it.\r\n return [\"x\"];\r\n }\r\n else if (2 * mathPI - end + start < circleCorrection) {\r\n // full circle\r\n // empirical correction found by trying out the limits for different radii\r\n cosEnd = -circleCorrection;\r\n }\r\n else if (end - start < innerCorrection) {\r\n // issue #186, another mysterious VML arc problem\r\n cosEnd = mathCos(start + innerCorrection);\r\n }\r\n\r\n ret = [\r\n \"wa\", // clockwise arc to\r\n x - radius, // left\r\n y - radius, // top\r\n x + radius, // right\r\n y + radius, // bottom\r\n x + radius * cosStart, // start x\r\n y + radius * sinStart, // start y\r\n x + radius * cosEnd, // end x\r\n y + radius * sinEnd // end y\r\n ];\r\n\r\n if (options.open && !innerRadius) {\r\n ret.push(\r\n \"e\",\r\n M,\r\n x, // - innerRadius,\r\n y // - innerRadius\r\n );\r\n }\r\n\r\n ret.push(\r\n \"at\", // anti clockwise arc to\r\n x - innerRadius, // left\r\n y - innerRadius, // top\r\n x + innerRadius, // right\r\n y + innerRadius, // bottom\r\n x + innerRadius * cosEnd, // start x\r\n y + innerRadius * sinEnd, // start y\r\n x + innerRadius * cosStart, // end x\r\n y + innerRadius * sinStart, // end y\r\n \"x\", // finish path\r\n \"e\" // close\r\n );\r\n\r\n return ret;\r\n },\r\n // Add circle symbol path. This performs significantly faster than v:oval.\r\n circle: function(x, y, w, h) {\r\n return [\r\n \"wa\", // clockwisearcto\r\n x, // left\r\n y, // top\r\n x + w, // right\r\n y + h, // bottom\r\n x + w, // start x\r\n y + h / 2, // start y\r\n x + w, // end x\r\n y + h / 2, // end y\r\n //'x', // finish path\r\n \"e\" // close\r\n ];\r\n },\r\n /**\r\n * Add rectangle symbol path which eases rotation and omits arcsize problems\r\n * compared to the built-in VML roundrect shape\r\n *\r\n * @param {Number} left Left position\r\n * @param {Number} top Top position\r\n * @param {Number} r Border radius\r\n * @param {Object} options Width and height\r\n */\r\n\r\n rect: function(left, top, width, height, options) {\r\n var right = left + width,\r\n bottom = top + height,\r\n ret,\r\n r;\r\n\r\n // No radius, return the more lightweight square\r\n if (!defined(options) || !options.r) {\r\n ret = SVGRenderer.prototype.symbols.square.apply(0, arguments);\r\n\r\n // Has radius add arcs for the corners\r\n }\r\n else {\r\n r = mathMin(options.r, width, height);\r\n ret = [\r\n M,\r\n left + r,\r\n top,\r\n\r\n L,\r\n right - r,\r\n top,\r\n \"wa\",\r\n right - 2 * r,\r\n top,\r\n right,\r\n top + 2 * r,\r\n right - r,\r\n top,\r\n right,\r\n top + r,\r\n\r\n L,\r\n right,\r\n bottom - r,\r\n \"wa\",\r\n right - 2 * r,\r\n bottom - 2 * r,\r\n right,\r\n bottom,\r\n right,\r\n bottom - r,\r\n right - r,\r\n bottom,\r\n\r\n L,\r\n left + r,\r\n bottom,\r\n \"wa\",\r\n left,\r\n bottom - 2 * r,\r\n left + 2 * r,\r\n bottom,\r\n left + r,\r\n bottom,\r\n left,\r\n bottom - r,\r\n\r\n L,\r\n left,\r\n top + r,\r\n \"wa\",\r\n left,\r\n top,\r\n left + 2 * r,\r\n top + 2 * r,\r\n left,\r\n top + r,\r\n left + r,\r\n top,\r\n\r\n \"x\",\r\n \"e\"\r\n ];\r\n }\r\n return ret;\r\n }\r\n }\r\n };\r\n VMLRenderer = function() {\r\n this.init.apply(this, arguments);\r\n };\r\n VMLRenderer.prototype = merge(SVGRenderer.prototype, VMLRendererExtension);\r\n\r\n // general renderer\r\n Renderer = VMLRenderer;\r\n }\r\n\r\n /* ****************************************************************************\r\n * *\r\n * END OF INTERNET EXPLORER <= 8 SPECIFIC CODE *\r\n * *\r\n *****************************************************************************/\r\n /* ****************************************************************************\r\n * *\r\n * START OF ANDROID < 3 SPECIFIC CODE. THIS CAN BE REMOVED IF YOU'RE NOT *\r\n * TARGETING THAT SYSTEM. *\r\n * *\r\n *****************************************************************************/\r\n var CanVGRenderer, CanVGController;\r\n\r\n if (useCanVG) {\r\n /**\r\n * The CanVGRenderer is empty from start to keep the source footprint small.\r\n * When requested, the CanVGController downloads the rest of the source packaged\r\n * together with the canvg library.\r\n */\r\n CanVGRenderer = function() {\r\n // Override the global SVG namespace to fake SVG/HTML that accepts CSS\r\n SVG_NS = \"http://www.w3.org/1999/xhtml\";\r\n };\r\n\r\n /**\r\n * Start with an empty symbols object. This is needed when exporting is used (exporting.src.js will add a few symbols), but\r\n * the implementation from SvgRenderer will not be merged in until first render.\r\n */\r\n CanVGRenderer.prototype.symbols = {};\r\n\r\n /**\r\n * Handles on demand download of canvg rendering support.\r\n */\r\n CanVGController = (function() {\r\n // List of renderering calls\r\n var deferredRenderCalls = [];\r\n\r\n /**\r\n * When downloaded, we are ready to draw deferred charts.\r\n */\r\n function drawDeferred() {\r\n var callLength = deferredRenderCalls.length,\r\n callIndex;\r\n\r\n // Draw all pending render calls\r\n for (callIndex = 0; callIndex < callLength; callIndex++) {\r\n deferredRenderCalls[callIndex]();\r\n }\r\n // Clear the list\r\n deferredRenderCalls = [];\r\n }\r\n\r\n return {\r\n push: function(func, scriptLocation) {\r\n // Only get the script once\r\n if (deferredRenderCalls.length === 0) {\r\n getScript(scriptLocation, drawDeferred);\r\n }\r\n // Register render call\r\n deferredRenderCalls.push(func);\r\n }\r\n };\r\n })();\r\n } // end CanVGRenderer\r\n\r\n /* ****************************************************************************\r\n * *\r\n * END OF ANDROID < 3 SPECIFIC CODE *\r\n * *\r\n *****************************************************************************/\r\n\r\n /**\r\n * General renderer\r\n */\r\n Renderer = VMLRenderer || CanVGRenderer || SVGRenderer;\r\n /**\r\n * The Tick class\r\n */\r\n function Tick(axis, pos, type) {\r\n this.axis = axis;\r\n this.pos = pos;\r\n this.type = type || \"\";\r\n this.isNew = true;\r\n\r\n if (!type) {\r\n this.addLabel();\r\n }\r\n }\r\n\r\n Tick.prototype = {\r\n /**\r\n * Write the tick label\r\n */\r\n addLabel: function() {\r\n var tick = this,\r\n axis = tick.axis,\r\n options = axis.options,\r\n chart = axis.chart,\r\n horiz = axis.horiz,\r\n categories = axis.categories,\r\n pos = tick.pos,\r\n labelOptions = options.labels,\r\n str,\r\n tickPositions = axis.tickPositions,\r\n width =\r\n (categories &&\r\n horiz &&\r\n categories.length &&\r\n !labelOptions.step &&\r\n !labelOptions.staggerLines &&\r\n !labelOptions.rotation &&\r\n chart.plotWidth / tickPositions.length) ||\r\n (!horiz && chart.plotWidth / 2),\r\n isFirst = pos === tickPositions[0],\r\n isLast = pos === tickPositions[tickPositions.length - 1],\r\n css,\r\n attr,\r\n value = categories && defined(categories[pos]) ? categories[pos] : pos,\r\n label = tick.label,\r\n tickPositionInfo = tickPositions.info,\r\n dateTimeLabelFormat;\r\n\r\n // Set the datetime label format. If a higher rank is set for this position, use that. If not,\r\n // use the general format.\r\n if (axis.isDatetimeAxis && tickPositionInfo) {\r\n dateTimeLabelFormat =\r\n options.dateTimeLabelFormats[\r\n tickPositionInfo.higherRanks[pos] || tickPositionInfo.unitName\r\n ];\r\n }\r\n\r\n // set properties for access in render method\r\n tick.isFirst = isFirst;\r\n tick.isLast = isLast;\r\n\r\n // get the string\r\n str = axis.labelFormatter.call({\r\n axis: axis,\r\n chart: chart,\r\n isFirst: isFirst,\r\n isLast: isLast,\r\n dateTimeLabelFormat: dateTimeLabelFormat,\r\n value: axis.isLog ? correctFloat(lin2log(value)) : value\r\n });\r\n\r\n // prepare CSS\r\n css = width && {\r\n width:\r\n mathMax(1, mathRound(width - 2 * (labelOptions.padding || 10))) + PX\r\n };\r\n css = extend(css, labelOptions.style);\r\n\r\n // first call\r\n if (!defined(label)) {\r\n attr = {\r\n align: labelOptions.align\r\n };\r\n if (isNumber(labelOptions.rotation)) {\r\n attr.rotation = labelOptions.rotation;\r\n }\r\n tick.label =\r\n defined(str) && labelOptions.enabled\r\n ? chart.renderer\r\n .text(str, 0, 0, labelOptions.useHTML)\r\n .attr(attr)\r\n // without position absolute, IE export sometimes is wrong\r\n .css(css)\r\n .add(axis.labelGroup)\r\n : null;\r\n\r\n // update\r\n }\r\n else if (label) {\r\n label\r\n .attr({\r\n text: str\r\n })\r\n .css(css);\r\n }\r\n },\r\n\r\n /**\r\n * Get the offset height or width of the label\r\n */\r\n getLabelSize: function() {\r\n var label = this.label,\r\n axis = this.axis;\r\n return label\r\n ? (this.labelBBox = label.getBBox())[axis.horiz ? \"height\" : \"width\"]\r\n : 0;\r\n },\r\n\r\n /**\r\n * Find how far the labels extend to the right and left of the tick's x position. Used for anti-collision\r\n * detection with overflow logic.\r\n */\r\n getLabelSides: function() {\r\n var bBox = this.labelBBox, // assume getLabelSize has run at this point\r\n axis = this.axis,\r\n options = axis.options,\r\n labelOptions = options.labels,\r\n width = bBox.width,\r\n leftSide =\r\n width * { left: 0, center: 0.5, right: 1 }[labelOptions.align] -\r\n labelOptions.x;\r\n\r\n return [-leftSide, width - leftSide];\r\n },\r\n\r\n /**\r\n * Handle the label overflow by adjusting the labels to the left and right edge, or\r\n * hide them if they collide into the neighbour label.\r\n */\r\n handleOverflow: function(index, xy) {\r\n var show = true,\r\n axis = this.axis,\r\n chart = axis.chart,\r\n isFirst = this.isFirst,\r\n isLast = this.isLast,\r\n x = xy.x,\r\n reversed = axis.reversed,\r\n tickPositions = axis.tickPositions;\r\n\r\n if (isFirst || isLast) {\r\n var sides = this.getLabelSides(),\r\n leftSide = sides[0],\r\n rightSide = sides[1],\r\n plotLeft = chart.plotLeft,\r\n plotRight = plotLeft + axis.len,\r\n neighbour = axis.ticks[tickPositions[index + (isFirst ? 1 : -1)]],\r\n neighbourEdge =\r\n neighbour &&\r\n neighbour.label.xy &&\r\n neighbour.label.xy.x + neighbour.getLabelSides()[isFirst ? 0 : 1];\r\n\r\n if ((isFirst && !reversed) || (isLast && reversed)) {\r\n // Is the label spilling out to the left of the plot area?\r\n if (x + leftSide < plotLeft) {\r\n // Align it to plot left\r\n x = plotLeft - leftSide;\r\n\r\n // Hide it if it now overlaps the neighbour label\r\n if (neighbour && x + rightSide > neighbourEdge) {\r\n show = false;\r\n }\r\n }\r\n }\r\n else {\r\n // Is the label spilling out to the right of the plot area?\r\n if (x + rightSide > plotRight) {\r\n // Align it to plot right\r\n x = plotRight - rightSide;\r\n\r\n // Hide it if it now overlaps the neighbour label\r\n if (neighbour && x + leftSide < neighbourEdge) {\r\n show = false;\r\n }\r\n }\r\n }\r\n\r\n // Set the modified x position of the label\r\n xy.x = x;\r\n }\r\n return show;\r\n },\r\n\r\n /**\r\n * Get the x and y position for ticks and labels\r\n */\r\n getPosition: function(horiz, pos, tickmarkOffset, old) {\r\n var axis = this.axis,\r\n chart = axis.chart,\r\n cHeight = (old && chart.oldChartHeight) || chart.chartHeight;\r\n\r\n return {\r\n x: horiz\r\n ? axis.translate(pos + tickmarkOffset, null, null, old) + axis.transB\r\n : axis.left +\r\n axis.offset +\r\n (axis.opposite\r\n ? ((old && chart.oldChartWidth) || chart.chartWidth) -\r\n axis.right -\r\n axis.left\r\n : 0),\r\n\r\n y: horiz\r\n ? cHeight -\r\n axis.bottom +\r\n axis.offset -\r\n (axis.opposite ? axis.height : 0)\r\n : cHeight -\r\n axis.translate(pos + tickmarkOffset, null, null, old) -\r\n axis.transB\r\n };\r\n },\r\n\r\n /**\r\n * Get the x, y position of the tick label\r\n */\r\n getLabelPosition: function(\r\n x,\r\n y,\r\n label,\r\n horiz,\r\n labelOptions,\r\n tickmarkOffset,\r\n index,\r\n step\r\n ) {\r\n var axis = this.axis,\r\n transA = axis.transA,\r\n reversed = axis.reversed,\r\n staggerLines = axis.staggerLines;\r\n\r\n x =\r\n x +\r\n labelOptions.x -\r\n (tickmarkOffset && horiz\r\n ? tickmarkOffset * transA * (reversed ? -1 : 1)\r\n : 0);\r\n y =\r\n y +\r\n labelOptions.y -\r\n (tickmarkOffset && !horiz\r\n ? tickmarkOffset * transA * (reversed ? 1 : -1)\r\n : 0);\r\n\r\n // Vertically centered\r\n if (!defined(labelOptions.y)) {\r\n y += pInt(label.styles.lineHeight) * 0.9 - label.getBBox().height / 2;\r\n }\r\n\r\n // Correct for staggered labels\r\n if (staggerLines) {\r\n y += ((index / (step || 1)) % staggerLines) * 16;\r\n }\r\n\r\n return {\r\n x: x,\r\n y: y\r\n };\r\n },\r\n\r\n /**\r\n * Extendible method to return the path of the marker\r\n */\r\n getMarkPath: function(x, y, tickLength, tickWidth, horiz, renderer) {\r\n return renderer.crispLine(\r\n [\r\n M,\r\n x,\r\n y,\r\n L,\r\n x + (horiz ? 0 : -tickLength),\r\n y + (horiz ? tickLength : 0)\r\n ],\r\n tickWidth\r\n );\r\n },\r\n\r\n /**\r\n * Put everything in place\r\n *\r\n * @param index {Number}\r\n * @param old {Boolean} Use old coordinates to prepare an animation into new position\r\n */\r\n render: function(index, old) {\r\n var tick = this,\r\n axis = tick.axis,\r\n options = axis.options,\r\n chart = axis.chart,\r\n renderer = chart.renderer,\r\n horiz = axis.horiz,\r\n type = tick.type,\r\n label = tick.label,\r\n pos = tick.pos,\r\n labelOptions = options.labels,\r\n gridLine = tick.gridLine,\r\n gridPrefix = type ? type + \"Grid\" : \"grid\",\r\n tickPrefix = type ? type + \"Tick\" : \"tick\",\r\n gridLineWidth = options[gridPrefix + \"LineWidth\"],\r\n gridLineColor = options[gridPrefix + \"LineColor\"],\r\n dashStyle = options[gridPrefix + \"LineDashStyle\"],\r\n tickLength = options[tickPrefix + \"Length\"],\r\n tickWidth = options[tickPrefix + \"Width\"] || 0,\r\n tickColor = options[tickPrefix + \"Color\"],\r\n tickPosition = options[tickPrefix + \"Position\"],\r\n gridLinePath,\r\n mark = tick.mark,\r\n markPath,\r\n step = labelOptions.step,\r\n attribs,\r\n show = true,\r\n tickmarkOffset = axis.tickmarkOffset,\r\n xy = tick.getPosition(horiz, pos, tickmarkOffset, old),\r\n x = xy.x,\r\n y = xy.y,\r\n staggerLines = axis.staggerLines;\r\n\r\n // create the grid line\r\n if (gridLineWidth) {\r\n gridLinePath = axis.getPlotLinePath(\r\n pos + tickmarkOffset,\r\n gridLineWidth,\r\n old\r\n );\r\n\r\n if (gridLine === UNDEFINED) {\r\n attribs = {\r\n stroke: gridLineColor,\r\n \"stroke-width\": gridLineWidth\r\n };\r\n if (dashStyle) {\r\n attribs.dashstyle = dashStyle;\r\n }\r\n if (!type) {\r\n attribs.zIndex = 1;\r\n }\r\n tick.gridLine = gridLine = gridLineWidth\r\n ? renderer\r\n .path(gridLinePath)\r\n .attr(attribs)\r\n .add(axis.gridGroup)\r\n : null;\r\n }\r\n\r\n // If the parameter 'old' is set, the current call will be followed\r\n // by another call, therefore do not do any animations this time\r\n if (!old && gridLine && gridLinePath) {\r\n gridLine[tick.isNew ? \"attr\" : \"animate\"]({\r\n d: gridLinePath\r\n });\r\n }\r\n }\r\n\r\n // create the tick mark\r\n if (tickWidth && tickLength) {\r\n // negate the length\r\n if (tickPosition === \"inside\") {\r\n tickLength = -tickLength;\r\n }\r\n if (axis.opposite) {\r\n tickLength = -tickLength;\r\n }\r\n\r\n markPath = tick.getMarkPath(\r\n x,\r\n y,\r\n tickLength,\r\n tickWidth,\r\n horiz,\r\n renderer\r\n );\r\n\r\n if (mark) {\r\n // updating\r\n mark.animate({\r\n d: markPath\r\n });\r\n }\r\n else {\r\n // first time\r\n tick.mark = renderer\r\n .path(markPath)\r\n .attr({\r\n stroke: tickColor,\r\n \"stroke-width\": tickWidth\r\n })\r\n .add(axis.axisGroup);\r\n }\r\n }\r\n\r\n // the label is created on init - now move it into place\r\n if (label && !isNaN(x)) {\r\n label.xy = xy = tick.getLabelPosition(\r\n x,\r\n y,\r\n label,\r\n horiz,\r\n labelOptions,\r\n tickmarkOffset,\r\n index,\r\n step\r\n );\r\n\r\n // apply show first and show last\r\n if (\r\n (tick.isFirst && !pick(options.showFirstLabel, 1)) ||\r\n (tick.isLast && !pick(options.showLastLabel, 1))\r\n ) {\r\n show = false;\r\n\r\n // Handle label overflow and show or hide accordingly\r\n }\r\n else if (\r\n !staggerLines &&\r\n horiz &&\r\n labelOptions.overflow === \"justify\" &&\r\n !tick.handleOverflow(index, xy)\r\n ) {\r\n show = false;\r\n }\r\n\r\n // apply step\r\n if (step && index % step) {\r\n // show those indices dividable by step\r\n show = false;\r\n }\r\n\r\n // Set the new position, and show or hide\r\n if (show) {\r\n label[tick.isNew ? \"attr\" : \"animate\"](xy);\r\n tick.isNew = false;\r\n }\r\n else {\r\n label.attr(\"y\", -9999); // #1338\r\n }\r\n }\r\n },\r\n\r\n /**\r\n * Destructor for the tick prototype\r\n */\r\n destroy: function() {\r\n destroyObjectProperties(this, this.axis);\r\n }\r\n };\r\n\r\n /**\r\n * The object wrapper for plot lines and plot bands\r\n * @param {Object} options\r\n */\r\n function PlotLineOrBand(axis, options) {\r\n this.axis = axis;\r\n\r\n if (options) {\r\n this.options = options;\r\n this.id = options.id;\r\n }\r\n\r\n //plotLine.render()\r\n return this;\r\n }\r\n\r\n PlotLineOrBand.prototype = {\r\n /**\r\n * Render the plot line or plot band. If it is already existing,\r\n * move it.\r\n */\r\n render: function() {\r\n var plotLine = this,\r\n axis = plotLine.axis,\r\n horiz = axis.horiz,\r\n halfPointRange = (axis.pointRange || 0) / 2,\r\n options = plotLine.options,\r\n optionsLabel = options.label,\r\n label = plotLine.label,\r\n width = options.width,\r\n to = options.to,\r\n from = options.from,\r\n isBand = defined(from) && defined(to),\r\n value = options.value,\r\n dashStyle = options.dashStyle,\r\n svgElem = plotLine.svgElem,\r\n path = [],\r\n addEvent,\r\n eventType,\r\n xs,\r\n ys,\r\n x,\r\n y,\r\n color = options.color,\r\n zIndex = options.zIndex,\r\n events = options.events,\r\n attribs,\r\n renderer = axis.chart.renderer;\r\n\r\n // logarithmic conversion\r\n if (axis.isLog) {\r\n from = log2lin(from);\r\n to = log2lin(to);\r\n value = log2lin(value);\r\n }\r\n\r\n // plot line\r\n if (width) {\r\n path = axis.getPlotLinePath(value, width);\r\n attribs = {\r\n stroke: color,\r\n \"stroke-width\": width\r\n };\r\n if (dashStyle) {\r\n attribs.dashstyle = dashStyle;\r\n }\r\n }\r\n else if (isBand) {\r\n // plot band\r\n\r\n // keep within plot area\r\n from = mathMax(from, axis.min - halfPointRange);\r\n to = mathMin(to, axis.max + halfPointRange);\r\n\r\n path = axis.getPlotBandPath(from, to, options);\r\n attribs = {\r\n fill: color\r\n };\r\n if (options.borderWidth) {\r\n attribs.stroke = options.borderColor;\r\n attribs[\"stroke-width\"] = options.borderWidth;\r\n }\r\n }\r\n else {\r\n return;\r\n }\r\n // zIndex\r\n if (defined(zIndex)) {\r\n attribs.zIndex = zIndex;\r\n }\r\n\r\n // common for lines and bands\r\n if (svgElem) {\r\n if (path) {\r\n svgElem.animate(\r\n {\r\n d: path\r\n },\r\n null,\r\n svgElem.onGetPath\r\n );\r\n }\r\n else {\r\n svgElem.hide();\r\n svgElem.onGetPath = function() {\r\n svgElem.show();\r\n };\r\n }\r\n }\r\n else if (path && path.length) {\r\n plotLine.svgElem = svgElem = renderer\r\n .path(path)\r\n .attr(attribs)\r\n .add();\r\n\r\n // events\r\n if (events) {\r\n addEvent = function(eventType) {\r\n svgElem.on(eventType, function(e) {\r\n events[eventType].apply(plotLine, [e]);\r\n });\r\n };\r\n for (eventType in events) {\r\n addEvent(eventType);\r\n }\r\n }\r\n }\r\n\r\n // the plot band/line label\r\n if (\r\n optionsLabel &&\r\n defined(optionsLabel.text) &&\r\n path &&\r\n path.length &&\r\n axis.width > 0 &&\r\n axis.height > 0\r\n ) {\r\n // apply defaults\r\n optionsLabel = merge(\r\n {\r\n align: horiz && isBand && \"center\",\r\n x: horiz ? !isBand && 4 : 10,\r\n verticalAlign: !horiz && isBand && \"middle\",\r\n y: horiz ? (isBand ? 16 : 10) : isBand ? 6 : -4,\r\n rotation: horiz && !isBand && 90\r\n },\r\n optionsLabel\r\n );\r\n\r\n // add the SVG element\r\n if (!label) {\r\n plotLine.label = label = renderer\r\n .text(optionsLabel.text, 0, 0)\r\n .attr({\r\n align: optionsLabel.textAlign || optionsLabel.align,\r\n rotation: optionsLabel.rotation,\r\n zIndex: zIndex\r\n })\r\n .css(optionsLabel.style)\r\n .add();\r\n }\r\n\r\n // get the bounding box and align the label\r\n xs = [path[1], path[4], pick(path[6], path[1])];\r\n ys = [path[2], path[5], pick(path[7], path[2])];\r\n x = arrayMin(xs);\r\n y = arrayMin(ys);\r\n\r\n label.align(optionsLabel, false, {\r\n x: x,\r\n y: y,\r\n width: arrayMax(xs) - x,\r\n height: arrayMax(ys) - y\r\n });\r\n label.show();\r\n }\r\n else if (label) {\r\n // move out of sight\r\n label.hide();\r\n }\r\n\r\n // chainable\r\n return plotLine;\r\n },\r\n\r\n /**\r\n * Remove the plot line or band\r\n */\r\n destroy: function() {\r\n var plotLine = this,\r\n axis = plotLine.axis;\r\n\r\n // remove it from the lookup\r\n erase(axis.plotLinesAndBands, plotLine);\r\n\r\n destroyObjectProperties(plotLine, this.axis);\r\n }\r\n };\r\n /**\r\n * The class for stack items\r\n */\r\n function StackItem(axis, options, isNegative, x, stackOption, stacking) {\r\n var inverted = axis.chart.inverted;\r\n\r\n this.axis = axis;\r\n\r\n // Tells if the stack is negative\r\n this.isNegative = isNegative;\r\n\r\n // Save the options to be able to style the label\r\n this.options = options;\r\n\r\n // Save the x value to be able to position the label later\r\n this.x = x;\r\n\r\n // Save the stack option on the series configuration object, and whether to treat it as percent\r\n this.stack = stackOption;\r\n this.percent = stacking === \"percent\";\r\n\r\n // The align options and text align varies on whether the stack is negative and\r\n // if the chart is inverted or not.\r\n // First test the user supplied value, then use the dynamic.\r\n this.alignOptions = {\r\n align:\r\n options.align ||\r\n (inverted ? (isNegative ? \"left\" : \"right\") : \"center\"),\r\n verticalAlign:\r\n options.verticalAlign ||\r\n (inverted ? \"middle\" : isNegative ? \"bottom\" : \"top\"),\r\n y: pick(options.y, inverted ? 4 : isNegative ? 14 : -6),\r\n x: pick(options.x, inverted ? (isNegative ? -6 : 6) : 0)\r\n };\r\n\r\n this.textAlign =\r\n options.textAlign ||\r\n (inverted ? (isNegative ? \"right\" : \"left\") : \"center\");\r\n }\r\n\r\n StackItem.prototype = {\r\n destroy: function() {\r\n destroyObjectProperties(this, this.axis);\r\n },\r\n\r\n /**\r\n * Sets the total of this stack. Should be called when a serie is hidden or shown\r\n * since that will affect the total of other stacks.\r\n */\r\n setTotal: function(total) {\r\n this.total = total;\r\n this.cum = total;\r\n },\r\n\r\n /**\r\n * Renders the stack total label and adds it to the stack label group.\r\n */\r\n render: function(group) {\r\n var str = this.options.formatter.call(this); // format the text in the label\r\n\r\n // Change the text to reflect the new total and set visibility to hidden in case the serie is hidden\r\n if (this.label) {\r\n this.label.attr({ text: str, visibility: HIDDEN });\r\n // Create new label\r\n }\r\n else {\r\n this.label = this.axis.chart.renderer\r\n .text(str, 0, 0) // dummy positions, actual position updated with setOffset method in columnseries\r\n .css(this.options.style) // apply style\r\n .attr({\r\n align: this.textAlign, // fix the text-anchor\r\n rotation: this.options.rotation, // rotation\r\n visibility: HIDDEN // hidden until setOffset is called\r\n })\r\n .add(group); // add to the labels-group\r\n }\r\n },\r\n\r\n /**\r\n * Sets the offset that the stack has from the x value and repositions the label.\r\n */\r\n setOffset: function(xOffset, xWidth) {\r\n var stackItem = this,\r\n axis = stackItem.axis,\r\n chart = axis.chart,\r\n inverted = chart.inverted,\r\n neg = this.isNegative, // special treatment is needed for negative stacks\r\n y = axis.translate(this.percent ? 100 : this.total, 0, 0, 0, 1), // stack value translated mapped to chart coordinates\r\n yZero = axis.translate(0), // stack origin\r\n h = mathAbs(y - yZero), // stack height\r\n x = chart.xAxis[0].translate(this.x) + xOffset, // stack x position\r\n plotHeight = chart.plotHeight,\r\n stackBox = {\r\n // this is the box for the complete stack\r\n x: inverted ? (neg ? y : y - h) : x,\r\n y: inverted\r\n ? plotHeight - x - xWidth\r\n : neg\r\n ? plotHeight - y - h\r\n : plotHeight - y,\r\n width: inverted ? h : xWidth,\r\n height: inverted ? xWidth : h\r\n },\r\n label = this.label,\r\n alignAttr;\r\n\r\n if (label) {\r\n label.align(this.alignOptions, null, stackBox); // align the label to the box\r\n\r\n // Set visibility (#678)\r\n alignAttr = label.alignAttr;\r\n label.attr({\r\n visibility:\r\n this.options.crop === false ||\r\n chart.isInsidePlot(alignAttr.x, alignAttr.y)\r\n ? hasSVG\r\n ? \"inherit\"\r\n : VISIBLE\r\n : HIDDEN\r\n });\r\n }\r\n }\r\n };\r\n /**\r\n * Create a new axis object\r\n * @param {Object} chart\r\n * @param {Object} options\r\n */\r\n function Axis() {\r\n this.init.apply(this, arguments);\r\n }\r\n\r\n Axis.prototype = {\r\n /**\r\n * Default options for the X axis - the Y axis has extended defaults\r\n */\r\n defaultOptions: {\r\n // allowDecimals: null,\r\n // alternateGridColor: null,\r\n // categories: [],\r\n dateTimeLabelFormats: {\r\n millisecond: \"%H:%M:%S.%L\",\r\n second: \"%H:%M:%S\",\r\n minute: \"%H:%M\",\r\n hour: \"%H:%M\",\r\n day: \"%e. %b\",\r\n week: \"%e. %b\",\r\n month: \"%b '%y\",\r\n year: \"%Y\"\r\n },\r\n endOnTick: false,\r\n gridLineColor: \"#C0C0C0\",\r\n // gridLineDashStyle: 'solid',\r\n // gridLineWidth: 0,\r\n // reversed: false,\r\n\r\n labels: defaultLabelOptions,\r\n // { step: null },\r\n lineColor: \"#C0D0E0\",\r\n lineWidth: 1,\r\n //linkedTo: null,\r\n //max: undefined,\r\n //min: undefined,\r\n minPadding: 0.01,\r\n maxPadding: 0.01,\r\n //minRange: null,\r\n minorGridLineColor: \"#E0E0E0\",\r\n // minorGridLineDashStyle: null,\r\n minorGridLineWidth: 1,\r\n minorTickColor: \"#A0A0A0\",\r\n //minorTickInterval: null,\r\n minorTickLength: 2,\r\n minorTickPosition: \"outside\", // inside or outside\r\n //minorTickWidth: 0,\r\n //opposite: false,\r\n //offset: 0,\r\n //plotBands: [{\r\n //\tevents: {},\r\n //\tzIndex: 1,\r\n //\tlabels: { align, x, verticalAlign, y, style, rotation, textAlign }\r\n //}],\r\n //plotLines: [{\r\n //\tevents: {}\r\n // dashStyle: {}\r\n //\tzIndex:\r\n //\tlabels: { align, x, verticalAlign, y, style, rotation, textAlign }\r\n //}],\r\n //reversed: false,\r\n // showFirstLabel: true,\r\n // showLastLabel: true,\r\n startOfWeek: 1,\r\n startOnTick: false,\r\n tickColor: \"#C0D0E0\",\r\n //tickInterval: null,\r\n tickLength: 5,\r\n tickmarkPlacement: \"between\", // on or between\r\n tickPixelInterval: 100,\r\n tickPosition: \"outside\",\r\n tickWidth: 1,\r\n title: {\r\n //text: null,\r\n align: \"middle\", // low, middle or high\r\n //margin: 0 for horizontal, 10 for vertical axes,\r\n //rotation: 0,\r\n //side: 'outside',\r\n style: {\r\n color: \"#6D869F\",\r\n //font: defaultFont.replace('normal', 'bold')\r\n fontWeight: \"bold\"\r\n }\r\n //x: 0,\r\n //y: 0\r\n },\r\n type: \"linear\" // linear, logarithmic or datetime\r\n },\r\n\r\n /**\r\n * This options set extends the defaultOptions for Y axes\r\n */\r\n defaultYAxisOptions: {\r\n endOnTick: true,\r\n gridLineWidth: 1,\r\n tickPixelInterval: 72,\r\n showLastLabel: true,\r\n labels: {\r\n align: \"right\",\r\n x: -8,\r\n y: 3\r\n },\r\n lineWidth: 0,\r\n maxPadding: 0.05,\r\n minPadding: 0.05,\r\n startOnTick: true,\r\n tickWidth: 0,\r\n title: {\r\n rotation: 270,\r\n text: \"Y-values\"\r\n },\r\n stackLabels: {\r\n enabled: false,\r\n //align: dynamic,\r\n //y: dynamic,\r\n //x: dynamic,\r\n //verticalAlign: dynamic,\r\n //textAlign: dynamic,\r\n //rotation: 0,\r\n formatter: function() {\r\n return this.total;\r\n },\r\n style: defaultLabelOptions.style\r\n }\r\n },\r\n\r\n /**\r\n * These options extend the defaultOptions for left axes\r\n */\r\n defaultLeftAxisOptions: {\r\n labels: {\r\n align: \"right\",\r\n x: -8,\r\n y: null\r\n },\r\n title: {\r\n rotation: 270\r\n }\r\n },\r\n\r\n /**\r\n * These options extend the defaultOptions for right axes\r\n */\r\n defaultRightAxisOptions: {\r\n labels: {\r\n align: \"left\",\r\n x: 8,\r\n y: null\r\n },\r\n title: {\r\n rotation: 90\r\n }\r\n },\r\n\r\n /**\r\n * These options extend the defaultOptions for bottom axes\r\n */\r\n defaultBottomAxisOptions: {\r\n labels: {\r\n align: \"center\",\r\n x: 0,\r\n y: 14\r\n // overflow: undefined,\r\n // staggerLines: null\r\n },\r\n title: {\r\n rotation: 0\r\n }\r\n },\r\n /**\r\n * These options extend the defaultOptions for left axes\r\n */\r\n defaultTopAxisOptions: {\r\n labels: {\r\n align: \"center\",\r\n x: 0,\r\n y: -5\r\n // overflow: undefined\r\n // staggerLines: null\r\n },\r\n title: {\r\n rotation: 0\r\n }\r\n },\r\n\r\n /**\r\n * Initialize the axis\r\n */\r\n init: function(chart, userOptions) {\r\n var isXAxis = userOptions.isX,\r\n axis = this;\r\n\r\n // Flag, is the axis horizontal\r\n axis.horiz = chart.inverted ? !isXAxis : isXAxis;\r\n\r\n // Flag, isXAxis\r\n axis.isXAxis = isXAxis;\r\n axis.xOrY = isXAxis ? \"x\" : \"y\";\r\n\r\n axis.opposite = userOptions.opposite; // needed in setOptions\r\n axis.side = axis.horiz\r\n ? axis.opposite\r\n ? 0\r\n : 2 // top : bottom\r\n : axis.opposite\r\n ? 1\r\n : 3; // right : left\r\n\r\n axis.setOptions(userOptions);\r\n\r\n var options = this.options,\r\n type = options.type,\r\n isDatetimeAxis = type === \"datetime\";\r\n\r\n axis.labelFormatter =\r\n options.labels.formatter || axis.defaultLabelFormatter; // can be overwritten by dynamic format\r\n\r\n // Flag, stagger lines or not\r\n axis.staggerLines = axis.horiz && options.labels.staggerLines;\r\n axis.userOptions = userOptions;\r\n\r\n //axis.axisTitleMargin = UNDEFINED,// = options.title.margin,\r\n axis.minPixelPadding = 0;\r\n //axis.ignoreMinPadding = UNDEFINED; // can be set to true by a column or bar series\r\n //axis.ignoreMaxPadding = UNDEFINED;\r\n\r\n axis.chart = chart;\r\n axis.reversed = options.reversed;\r\n\r\n // Initial categories\r\n axis.categories = options.categories;\r\n\r\n // Elements\r\n //axis.axisGroup = UNDEFINED;\r\n //axis.gridGroup = UNDEFINED;\r\n //axis.axisTitle = UNDEFINED;\r\n //axis.axisLine = UNDEFINED;\r\n\r\n // Flag if type === logarithmic\r\n axis.isLog = type === \"logarithmic\";\r\n\r\n // Flag, if axis is linked to another axis\r\n axis.isLinked = defined(options.linkedTo);\r\n // Linked axis.\r\n //axis.linkedParent = UNDEFINED;\r\n\r\n // Flag if type === datetime\r\n axis.isDatetimeAxis = isDatetimeAxis;\r\n\r\n // Flag if percentage mode\r\n //axis.usePercentage = UNDEFINED;\r\n\r\n // Tick positions\r\n //axis.tickPositions = UNDEFINED; // array containing predefined positions\r\n // Tick intervals\r\n //axis.tickInterval = UNDEFINED;\r\n //axis.minorTickInterval = UNDEFINED;\r\n\r\n axis.tickmarkOffset =\r\n options.categories && options.tickmarkPlacement === \"between\" ? 0.5 : 0;\r\n\r\n // Major ticks\r\n axis.ticks = {};\r\n // Minor ticks\r\n axis.minorTicks = {};\r\n //axis.tickAmount = UNDEFINED;\r\n\r\n // List of plotLines/Bands\r\n axis.plotLinesAndBands = [];\r\n\r\n // Alternate bands\r\n axis.alternateBands = {};\r\n\r\n // Axis metrics\r\n //axis.left = UNDEFINED;\r\n //axis.top = UNDEFINED;\r\n //axis.width = UNDEFINED;\r\n //axis.height = UNDEFINED;\r\n //axis.bottom = UNDEFINED;\r\n //axis.right = UNDEFINED;\r\n //axis.transA = UNDEFINED;\r\n //axis.transB = UNDEFINED;\r\n //axis.oldTransA = UNDEFINED;\r\n axis.len = 0;\r\n //axis.oldMin = UNDEFINED;\r\n //axis.oldMax = UNDEFINED;\r\n //axis.oldUserMin = UNDEFINED;\r\n //axis.oldUserMax = UNDEFINED;\r\n //axis.oldAxisLength = UNDEFINED;\r\n axis.minRange = axis.userMinRange = options.minRange || options.maxZoom;\r\n axis.range = options.range;\r\n axis.offset = options.offset || 0;\r\n\r\n // Dictionary for stacks\r\n axis.stacks = {};\r\n\r\n // Min and max in the data\r\n //axis.dataMin = UNDEFINED,\r\n //axis.dataMax = UNDEFINED,\r\n\r\n // The axis range\r\n axis.max = null;\r\n axis.min = null;\r\n\r\n // User set min and max\r\n //axis.userMin = UNDEFINED,\r\n //axis.userMax = UNDEFINED,\r\n\r\n // Run Axis\r\n\r\n var eventType,\r\n events = axis.options.events;\r\n\r\n // Register\r\n chart.axes.push(axis);\r\n chart[isXAxis ? \"xAxis\" : \"yAxis\"].push(axis);\r\n\r\n axis.series = []; // populated by Series\r\n\r\n // inverted charts have reversed xAxes as default\r\n if (chart.inverted && isXAxis && axis.reversed === UNDEFINED) {\r\n axis.reversed = true;\r\n }\r\n\r\n axis.removePlotBand = axis.removePlotBandOrLine;\r\n axis.removePlotLine = axis.removePlotBandOrLine;\r\n axis.addPlotBand = axis.addPlotBandOrLine;\r\n axis.addPlotLine = axis.addPlotBandOrLine;\r\n\r\n // register event listeners\r\n for (eventType in events) {\r\n addEvent(axis, eventType, events[eventType]);\r\n }\r\n\r\n // extend logarithmic axis\r\n if (axis.isLog) {\r\n axis.val2lin = log2lin;\r\n axis.lin2val = lin2log;\r\n }\r\n },\r\n\r\n /**\r\n * Merge and set options\r\n */\r\n setOptions: function(userOptions) {\r\n this.options = merge(\r\n this.defaultOptions,\r\n this.isXAxis ? {} : this.defaultYAxisOptions,\r\n [\r\n this.defaultTopAxisOptions,\r\n this.defaultRightAxisOptions,\r\n this.defaultBottomAxisOptions,\r\n this.defaultLeftAxisOptions\r\n ][this.side],\r\n merge(\r\n defaultOptions[this.isXAxis ? \"xAxis\" : \"yAxis\"], // if set in setOptions (#1053)\r\n userOptions\r\n )\r\n );\r\n },\r\n\r\n /**\r\n * The default label formatter. The context is a special config object for the label.\r\n */\r\n defaultLabelFormatter: function() {\r\n var axis = this.axis,\r\n value = this.value,\r\n categories = axis.categories,\r\n dateTimeLabelFormat = this.dateTimeLabelFormat,\r\n numericSymbols = defaultOptions.lang.numericSymbols,\r\n i = numericSymbols && numericSymbols.length,\r\n multi,\r\n ret,\r\n // make sure the same symbol is added for all labels on a linear axis\r\n numericSymbolDetector = axis.isLog ? value : axis.tickInterval;\r\n\r\n if (categories) {\r\n ret = value;\r\n }\r\n else if (dateTimeLabelFormat) {\r\n // datetime axis\r\n ret = dateFormat(dateTimeLabelFormat, value);\r\n }\r\n else if (i && numericSymbolDetector >= 1000) {\r\n // Decide whether we should add a numeric symbol like k (thousands) or M (millions).\r\n // If we are to enable this in tooltip or other places as well, we can move this\r\n // logic to the numberFormatter and enable it by a parameter.\r\n while (i-- && ret === UNDEFINED) {\r\n multi = Math.pow(1000, i + 1);\r\n if (numericSymbolDetector >= multi && numericSymbols[i] !== null) {\r\n ret = numberFormat(value / multi, -1) + numericSymbols[i];\r\n }\r\n }\r\n }\r\n\r\n if (ret === UNDEFINED) {\r\n if (value >= 1000) {\r\n // add thousands separators\r\n ret = numberFormat(value, 0);\r\n }\r\n else {\r\n // small numbers\r\n ret = numberFormat(value, -1);\r\n }\r\n }\r\n\r\n return ret;\r\n },\r\n\r\n /**\r\n * Get the minimum and maximum for the series of each axis\r\n */\r\n getSeriesExtremes: function() {\r\n var axis = this,\r\n chart = axis.chart,\r\n stacks = axis.stacks,\r\n posStack = [],\r\n negStack = [],\r\n i;\r\n\r\n axis.hasVisibleSeries = false;\r\n\r\n // reset dataMin and dataMax in case we're redrawing\r\n axis.dataMin = axis.dataMax = null;\r\n\r\n // loop through this axis' series\r\n each(axis.series, function(series) {\r\n if (series.visible || !chart.options.chart.ignoreHiddenSeries) {\r\n var seriesOptions = series.options,\r\n stacking,\r\n posPointStack,\r\n negPointStack,\r\n stackKey,\r\n stackOption,\r\n negKey,\r\n xData,\r\n yData,\r\n x,\r\n y,\r\n threshold = seriesOptions.threshold,\r\n yDataLength,\r\n activeYData = [],\r\n activeCounter = 0;\r\n\r\n axis.hasVisibleSeries = true;\r\n\r\n // Validate threshold in logarithmic axes\r\n if (axis.isLog && threshold <= 0) {\r\n threshold = seriesOptions.threshold = null;\r\n }\r\n\r\n // Get dataMin and dataMax for X axes\r\n if (axis.isXAxis) {\r\n xData = series.xData;\r\n if (xData.length) {\r\n axis.dataMin = mathMin(\r\n pick(axis.dataMin, xData[0]),\r\n arrayMin(xData)\r\n );\r\n axis.dataMax = mathMax(\r\n pick(axis.dataMax, xData[0]),\r\n arrayMax(xData)\r\n );\r\n }\r\n\r\n // Get dataMin and dataMax for Y axes, as well as handle stacking and processed data\r\n }\r\n else {\r\n var isNegative,\r\n pointStack,\r\n key,\r\n cropped = series.cropped,\r\n xExtremes = series.xAxis.getExtremes(),\r\n //findPointRange,\r\n //pointRange,\r\n j,\r\n hasModifyValue = !!series.modifyValue;\r\n\r\n // Handle stacking\r\n stacking = seriesOptions.stacking;\r\n axis.usePercentage = stacking === \"percent\";\r\n\r\n // create a stack for this particular series type\r\n if (stacking) {\r\n stackOption = seriesOptions.stack;\r\n stackKey = series.type + pick(stackOption, \"\");\r\n negKey = \"-\" + stackKey;\r\n series.stackKey = stackKey; // used in translate\r\n\r\n posPointStack = posStack[stackKey] || []; // contains the total values for each x\r\n posStack[stackKey] = posPointStack;\r\n\r\n negPointStack = negStack[negKey] || [];\r\n negStack[negKey] = negPointStack;\r\n }\r\n if (axis.usePercentage) {\r\n axis.dataMin = 0;\r\n axis.dataMax = 99;\r\n }\r\n\r\n // processData can alter series.pointRange, so this goes after\r\n //findPointRange = series.pointRange === null;\r\n\r\n xData = series.processedXData;\r\n yData = series.processedYData;\r\n yDataLength = yData.length;\r\n\r\n // loop over the non-null y values and read them into a local array\r\n for (i = 0; i < yDataLength; i++) {\r\n x = xData[i];\r\n y = yData[i];\r\n\r\n // Read stacked values into a stack based on the x value,\r\n // the sign of y and the stack key. Stacking is also handled for null values (#739)\r\n if (stacking) {\r\n isNegative = y < threshold;\r\n pointStack = isNegative ? negPointStack : posPointStack;\r\n key = isNegative ? negKey : stackKey;\r\n\r\n // Set the stack value and y for extremes\r\n if (defined(pointStack[x])) {\r\n // we're adding to the stack\r\n pointStack[x] = correctFloat(pointStack[x] + y);\r\n y = [y, pointStack[x]]; // consider both the actual value and the stack (#1376)\r\n }\r\n else {\r\n // it's the first point in the stack\r\n pointStack[x] = y;\r\n }\r\n\r\n // add the series\r\n if (!stacks[key]) {\r\n stacks[key] = {};\r\n }\r\n\r\n // If the StackItem is there, just update the values,\r\n // if not, create one first\r\n if (!stacks[key][x]) {\r\n stacks[key][x] = new StackItem(\r\n axis,\r\n axis.options.stackLabels,\r\n isNegative,\r\n x,\r\n stackOption,\r\n stacking\r\n );\r\n }\r\n stacks[key][x].setTotal(pointStack[x]);\r\n }\r\n\r\n // Handle non null values\r\n if (y !== null && y !== UNDEFINED) {\r\n // general hook, used for Highstock compare values feature\r\n if (hasModifyValue) {\r\n y = series.modifyValue(y);\r\n }\r\n\r\n // for points within the visible range, including the first point outside the\r\n // visible range, consider y extremes\r\n if (\r\n cropped ||\r\n ((xData[i + 1] || x) >= xExtremes.min &&\r\n (xData[i - 1] || x) <= xExtremes.max)\r\n ) {\r\n j = y.length;\r\n if (j) {\r\n // array, like ohlc or range data\r\n while (j--) {\r\n if (y[j] !== null) {\r\n activeYData[activeCounter++] = y[j];\r\n }\r\n }\r\n }\r\n else {\r\n activeYData[activeCounter++] = y;\r\n }\r\n }\r\n }\r\n }\r\n\r\n // Get the dataMin and dataMax so far. If percentage is used, the min and max are\r\n // always 0 and 100. If the length of activeYData is 0, continue with null values.\r\n if (!axis.usePercentage && activeYData.length) {\r\n axis.dataMin = mathMin(\r\n pick(axis.dataMin, activeYData[0]),\r\n arrayMin(activeYData)\r\n );\r\n axis.dataMax = mathMax(\r\n pick(axis.dataMax, activeYData[0]),\r\n arrayMax(activeYData)\r\n );\r\n }\r\n\r\n // Adjust to threshold\r\n if (defined(threshold)) {\r\n if (axis.dataMin >= threshold) {\r\n axis.dataMin = threshold;\r\n axis.ignoreMinPadding = true;\r\n }\r\n else if (axis.dataMax < threshold) {\r\n axis.dataMax = threshold;\r\n axis.ignoreMaxPadding = true;\r\n }\r\n }\r\n }\r\n }\r\n });\r\n },\r\n\r\n /**\r\n * Translate from axis value to pixel position on the chart, or back\r\n *\r\n */\r\n translate: function(\r\n val,\r\n backwards,\r\n cvsCoord,\r\n old,\r\n handleLog,\r\n pointPlacementBetween\r\n ) {\r\n var axis = this,\r\n axisLength = axis.len,\r\n sign = 1,\r\n cvsOffset = 0,\r\n localA = old ? axis.oldTransA : axis.transA,\r\n localMin = old ? axis.oldMin : axis.min,\r\n returnValue,\r\n postTranslate = axis.options.ordinal || (axis.isLog && handleLog);\r\n\r\n if (!localA) {\r\n localA = axis.transA;\r\n }\r\n\r\n if (cvsCoord) {\r\n sign *= -1; // canvas coordinates inverts the value\r\n cvsOffset = axisLength;\r\n }\r\n if (axis.reversed) {\r\n // reversed axis\r\n sign *= -1;\r\n cvsOffset -= sign * axisLength;\r\n }\r\n\r\n if (backwards) {\r\n // reverse translation\r\n if (axis.reversed) {\r\n val = axisLength - val;\r\n }\r\n returnValue = val / localA + localMin; // from chart pixel to value\r\n if (postTranslate) {\r\n // log and ordinal axes\r\n returnValue = axis.lin2val(returnValue);\r\n }\r\n }\r\n else {\r\n // normal translation, from axis value to pixel, relative to plot\r\n if (postTranslate) {\r\n // log and ordinal axes\r\n val = axis.val2lin(val);\r\n }\r\n\r\n returnValue =\r\n sign * (val - localMin) * localA +\r\n cvsOffset +\r\n sign * axis.minPixelPadding +\r\n (pointPlacementBetween ? (localA * axis.pointRange) / 2 : 0);\r\n }\r\n\r\n return returnValue;\r\n },\r\n\r\n /**\r\n * Create the path for a plot line that goes from the given value on\r\n * this axis, across the plot to the opposite side\r\n * @param {Number} value\r\n * @param {Number} lineWidth Used for calculation crisp line\r\n * @param {Number] old Use old coordinates (for resizing and rescaling)\r\n */\r\n getPlotLinePath: function(value, lineWidth, old) {\r\n var axis = this,\r\n chart = axis.chart,\r\n axisLeft = axis.left,\r\n axisTop = axis.top,\r\n x1,\r\n y1,\r\n x2,\r\n y2,\r\n translatedValue = axis.translate(value, null, null, old),\r\n cHeight = (old && chart.oldChartHeight) || chart.chartHeight,\r\n cWidth = (old && chart.oldChartWidth) || chart.chartWidth,\r\n skip,\r\n transB = axis.transB;\r\n\r\n x1 = x2 = mathRound(translatedValue + transB);\r\n y1 = y2 = mathRound(cHeight - translatedValue - transB);\r\n\r\n if (isNaN(translatedValue)) {\r\n // no min or max\r\n skip = true;\r\n }\r\n else if (axis.horiz) {\r\n y1 = axisTop;\r\n y2 = cHeight - axis.bottom;\r\n if (x1 < axisLeft || x1 > axisLeft + axis.width) {\r\n skip = true;\r\n }\r\n }\r\n else {\r\n x1 = axisLeft;\r\n x2 = cWidth - axis.right;\r\n\r\n if (y1 < axisTop || y1 > axisTop + axis.height) {\r\n skip = true;\r\n }\r\n }\r\n return skip\r\n ? null\r\n : chart.renderer.crispLine([M, x1, y1, L, x2, y2], lineWidth || 0);\r\n },\r\n\r\n /**\r\n * Create the path for a plot band\r\n */\r\n getPlotBandPath: function(from, to) {\r\n var toPath = this.getPlotLinePath(to),\r\n path = this.getPlotLinePath(from);\r\n\r\n if (path && toPath) {\r\n path.push(toPath[4], toPath[5], toPath[1], toPath[2]);\r\n }\r\n else {\r\n // outside the axis area\r\n path = null;\r\n }\r\n\r\n return path;\r\n },\r\n\r\n /**\r\n * Set the tick positions of a linear axis to round values like whole tens or every five.\r\n */\r\n getLinearTickPositions: function(tickInterval, min, max) {\r\n var pos,\r\n lastPos,\r\n roundedMin = correctFloat(mathFloor(min / tickInterval) * tickInterval),\r\n roundedMax = correctFloat(mathCeil(max / tickInterval) * tickInterval),\r\n tickPositions = [];\r\n\r\n // Populate the intermediate values\r\n pos = roundedMin;\r\n while (pos <= roundedMax) {\r\n // Place the tick on the rounded value\r\n tickPositions.push(pos);\r\n\r\n // Always add the raw tickInterval, not the corrected one.\r\n pos = correctFloat(pos + tickInterval);\r\n\r\n // If the interval is not big enough in the current min - max range to actually increase\r\n // the loop variable, we need to break out to prevent endless loop. Issue #619\r\n if (pos === lastPos) {\r\n break;\r\n }\r\n\r\n // Record the last value\r\n lastPos = pos;\r\n }\r\n return tickPositions;\r\n },\r\n\r\n /**\r\n * Set the tick positions of a logarithmic axis\r\n */\r\n getLogTickPositions: function(interval, min, max, minor) {\r\n var axis = this,\r\n options = axis.options,\r\n axisLength = axis.len;\r\n\r\n // Since we use this method for both major and minor ticks,\r\n // use a local variable and return the result\r\n var positions = [];\r\n\r\n // Reset\r\n if (!minor) {\r\n axis._minorAutoInterval = null;\r\n }\r\n\r\n // First case: All ticks fall on whole logarithms: 1, 10, 100 etc.\r\n if (interval >= 0.5) {\r\n interval = mathRound(interval);\r\n positions = axis.getLinearTickPositions(interval, min, max);\r\n\r\n // Second case: We need intermediary ticks. For example\r\n // 1, 2, 4, 6, 8, 10, 20, 40 etc.\r\n }\r\n else if (interval >= 0.08) {\r\n var roundedMin = mathFloor(min),\r\n intermediate,\r\n i,\r\n j,\r\n len,\r\n pos,\r\n lastPos,\r\n break2;\r\n\r\n if (interval > 0.3) {\r\n intermediate = [1, 2, 4];\r\n }\r\n else if (interval > 0.15) {\r\n // 0.2 equals five minor ticks per 1, 10, 100 etc\r\n intermediate = [1, 2, 4, 6, 8];\r\n }\r\n else {\r\n // 0.1 equals ten minor ticks per 1, 10, 100 etc\r\n intermediate = [1, 2, 3, 4, 5, 6, 7, 8, 9];\r\n }\r\n\r\n for (i = roundedMin; i < max + 1 && !break2; i++) {\r\n len = intermediate.length;\r\n for (j = 0; j < len && !break2; j++) {\r\n pos = log2lin(lin2log(i) * intermediate[j]);\r\n\r\n if (pos > min) {\r\n positions.push(lastPos);\r\n }\r\n\r\n if (lastPos > max) {\r\n break2 = true;\r\n }\r\n lastPos = pos;\r\n }\r\n }\r\n\r\n // Third case: We are so deep in between whole logarithmic values that\r\n // we might as well handle the tick positions like a linear axis. For\r\n // example 1.01, 1.02, 1.03, 1.04.\r\n }\r\n else {\r\n var realMin = lin2log(min),\r\n realMax = lin2log(max),\r\n tickIntervalOption =\r\n options[minor ? \"minorTickInterval\" : \"tickInterval\"],\r\n filteredTickIntervalOption =\r\n tickIntervalOption === \"auto\" ? null : tickIntervalOption,\r\n tickPixelIntervalOption = options.tickPixelInterval / (minor ? 5 : 1),\r\n totalPixelLength = minor\r\n ? axisLength / axis.tickPositions.length\r\n : axisLength;\r\n\r\n interval = pick(\r\n filteredTickIntervalOption,\r\n axis._minorAutoInterval,\r\n ((realMax - realMin) * tickPixelIntervalOption) /\r\n (totalPixelLength || 1)\r\n );\r\n\r\n interval = normalizeTickInterval(\r\n interval,\r\n null,\r\n math.pow(10, mathFloor(math.log(interval) / math.LN10))\r\n );\r\n\r\n positions = map(\r\n axis.getLinearTickPositions(interval, realMin, realMax),\r\n log2lin\r\n );\r\n\r\n if (!minor) {\r\n axis._minorAutoInterval = interval / 5;\r\n }\r\n }\r\n\r\n // Set the axis-level tickInterval variable\r\n if (!minor) {\r\n axis.tickInterval = interval;\r\n }\r\n return positions;\r\n },\r\n\r\n /**\r\n * Return the minor tick positions. For logarithmic axes, reuse the same logic\r\n * as for major ticks.\r\n */\r\n getMinorTickPositions: function() {\r\n var axis = this,\r\n options = axis.options,\r\n tickPositions = axis.tickPositions,\r\n minorTickInterval = axis.minorTickInterval;\r\n\r\n var minorTickPositions = [],\r\n pos,\r\n i,\r\n len;\r\n\r\n if (axis.isLog) {\r\n len = tickPositions.length;\r\n for (i = 1; i < len; i++) {\r\n minorTickPositions = minorTickPositions.concat(\r\n axis.getLogTickPositions(\r\n minorTickInterval,\r\n tickPositions[i - 1],\r\n tickPositions[i],\r\n true\r\n )\r\n );\r\n }\r\n }\r\n else if (axis.isDatetimeAxis && options.minorTickInterval === \"auto\") {\r\n // #1314\r\n minorTickPositions = minorTickPositions.concat(\r\n getTimeTicks(\r\n normalizeTimeTickInterval(minorTickInterval),\r\n axis.min,\r\n axis.max,\r\n options.startOfWeek\r\n )\r\n );\r\n }\r\n else {\r\n for (\r\n pos = axis.min + ((tickPositions[0] - axis.min) % minorTickInterval);\r\n pos <= axis.max;\r\n pos += minorTickInterval\r\n ) {\r\n minorTickPositions.push(pos);\r\n }\r\n }\r\n return minorTickPositions;\r\n },\r\n\r\n /**\r\n * Adjust the min and max for the minimum range. Keep in mind that the series data is\r\n * not yet processed, so we don't have information on data cropping and grouping, or\r\n * updated axis.pointRange or series.pointRange. The data can't be processed until\r\n * we have finally established min and max.\r\n */\r\n adjustForMinRange: function() {\r\n var axis = this,\r\n options = axis.options,\r\n min = axis.min,\r\n max = axis.max,\r\n zoomOffset,\r\n spaceAvailable = axis.dataMax - axis.dataMin >= axis.minRange,\r\n closestDataRange,\r\n i,\r\n distance,\r\n xData,\r\n loopLength,\r\n minArgs,\r\n maxArgs;\r\n\r\n // Set the automatic minimum range based on the closest point distance\r\n if (axis.isXAxis && axis.minRange === UNDEFINED && !axis.isLog) {\r\n if (defined(options.min) || defined(options.max)) {\r\n axis.minRange = null; // don't do this again\r\n }\r\n else {\r\n // Find the closest distance between raw data points, as opposed to\r\n // closestPointRange that applies to processed points (cropped and grouped)\r\n each(axis.series, function(series) {\r\n xData = series.xData;\r\n loopLength = series.xIncrement ? 1 : xData.length - 1;\r\n for (i = loopLength; i > 0; i--) {\r\n distance = xData[i] - xData[i - 1];\r\n if (\r\n closestDataRange === UNDEFINED ||\r\n distance < closestDataRange\r\n ) {\r\n closestDataRange = distance;\r\n }\r\n }\r\n });\r\n axis.minRange = mathMin(\r\n closestDataRange * 5,\r\n axis.dataMax - axis.dataMin\r\n );\r\n }\r\n }\r\n\r\n // if minRange is exceeded, adjust\r\n if (max - min < axis.minRange) {\r\n var minRange = axis.minRange;\r\n zoomOffset = (minRange - max + min) / 2;\r\n\r\n // if min and max options have been set, don't go beyond it\r\n minArgs = [min - zoomOffset, pick(options.min, min - zoomOffset)];\r\n if (spaceAvailable) {\r\n // if space is available, stay within the data range\r\n minArgs[2] = axis.dataMin;\r\n }\r\n min = arrayMax(minArgs);\r\n\r\n maxArgs = [min + minRange, pick(options.max, min + minRange)];\r\n if (spaceAvailable) {\r\n // if space is availabe, stay within the data range\r\n maxArgs[2] = axis.dataMax;\r\n }\r\n\r\n max = arrayMin(maxArgs);\r\n\r\n // now if the max is adjusted, adjust the min back\r\n if (max - min < minRange) {\r\n minArgs[0] = max - minRange;\r\n minArgs[1] = pick(options.min, max - minRange);\r\n min = arrayMax(minArgs);\r\n }\r\n }\r\n\r\n // Record modified extremes\r\n axis.min = min;\r\n axis.max = max;\r\n },\r\n\r\n /**\r\n * Update translation information\r\n */\r\n setAxisTranslation: function() {\r\n var axis = this,\r\n range = axis.max - axis.min,\r\n pointRange = 0,\r\n closestPointRange,\r\n minPointOffset = 0,\r\n pointRangePadding = 0,\r\n linkedParent = axis.linkedParent,\r\n transA = axis.transA;\r\n\r\n // adjust translation for padding\r\n if (axis.isXAxis) {\r\n if (linkedParent) {\r\n minPointOffset = linkedParent.minPointOffset;\r\n pointRangePadding = linkedParent.pointRangePadding;\r\n }\r\n else {\r\n each(axis.series, function(series) {\r\n var seriesPointRange = series.pointRange,\r\n pointPlacement = series.options.pointPlacement,\r\n seriesClosestPointRange = series.closestPointRange;\r\n\r\n pointRange = mathMax(pointRange, seriesPointRange);\r\n\r\n // minPointOffset is the value padding to the left of the axis in order to make\r\n // room for points with a pointRange, typically columns. When the pointPlacement option\r\n // is 'between' or 'on', this padding does not apply.\r\n minPointOffset = mathMax(\r\n minPointOffset,\r\n pointPlacement ? 0 : seriesPointRange / 2\r\n );\r\n\r\n // Determine the total padding needed to the length of the axis to make room for the\r\n // pointRange. If the series' pointPlacement is 'on', no padding is added.\r\n pointRangePadding = mathMax(\r\n pointRangePadding,\r\n pointPlacement === \"on\" ? 0 : seriesPointRange\r\n );\r\n\r\n // Set the closestPointRange\r\n if (!series.noSharedTooltip && defined(seriesClosestPointRange)) {\r\n closestPointRange = defined(closestPointRange)\r\n ? mathMin(closestPointRange, seriesClosestPointRange)\r\n : seriesClosestPointRange;\r\n }\r\n });\r\n }\r\n\r\n // Record minPointOffset and pointRangePadding\r\n axis.minPointOffset = minPointOffset;\r\n axis.pointRangePadding = pointRangePadding;\r\n\r\n // pointRange means the width reserved for each point, like in a column chart\r\n axis.pointRange = pointRange;\r\n\r\n // closestPointRange means the closest distance between points. In columns\r\n // it is mostly equal to pointRange, but in lines pointRange is 0 while closestPointRange\r\n // is some other value\r\n axis.closestPointRange = closestPointRange;\r\n }\r\n\r\n // secondary values\r\n axis.oldTransA = transA;\r\n //axis.translationSlope = axis.transA = transA = axis.len / ((range + (2 * minPointOffset)) || 1);\r\n axis.translationSlope = axis.transA = transA =\r\n axis.len / (range + pointRangePadding || 1);\r\n axis.transB = axis.horiz ? axis.left : axis.bottom; // translation addend\r\n axis.minPixelPadding = transA * minPointOffset;\r\n },\r\n\r\n /**\r\n * Set the tick positions to round values and optionally extend the extremes\r\n * to the nearest tick\r\n */\r\n setTickPositions: function(secondPass) {\r\n var axis = this,\r\n chart = axis.chart,\r\n options = axis.options,\r\n isLog = axis.isLog,\r\n isDatetimeAxis = axis.isDatetimeAxis,\r\n isXAxis = axis.isXAxis,\r\n isLinked = axis.isLinked,\r\n tickPositioner = axis.options.tickPositioner,\r\n magnitude,\r\n maxPadding = options.maxPadding,\r\n minPadding = options.minPadding,\r\n length,\r\n linkedParentExtremes,\r\n tickIntervalOption = options.tickInterval,\r\n minTickIntervalOption = options.minTickInterval,\r\n tickPixelIntervalOption = options.tickPixelInterval,\r\n tickPositions,\r\n categories = axis.categories;\r\n\r\n // linked axis gets the extremes from the parent axis\r\n if (isLinked) {\r\n axis.linkedParent =\r\n chart[isXAxis ? \"xAxis\" : \"yAxis\"][options.linkedTo];\r\n linkedParentExtremes = axis.linkedParent.getExtremes();\r\n axis.min = pick(linkedParentExtremes.min, linkedParentExtremes.dataMin);\r\n axis.max = pick(linkedParentExtremes.max, linkedParentExtremes.dataMax);\r\n if (options.type !== axis.linkedParent.options.type) {\r\n error(11, 1); // Can't link axes of different type\r\n }\r\n }\r\n else {\r\n // initial min and max from the extreme data values\r\n axis.min = pick(axis.userMin, options.min, axis.dataMin);\r\n axis.max = pick(axis.userMax, options.max, axis.dataMax);\r\n }\r\n\r\n if (isLog) {\r\n if (\r\n !secondPass &&\r\n mathMin(axis.min, pick(axis.dataMin, axis.min)) <= 0\r\n ) {\r\n // #978\r\n error(10, 1); // Can't plot negative values on log axis\r\n }\r\n axis.min = correctFloat(log2lin(axis.min)); // correctFloat cures #934\r\n axis.max = correctFloat(log2lin(axis.max));\r\n }\r\n\r\n // handle zoomed range\r\n if (axis.range) {\r\n axis.userMin = axis.min = mathMax(axis.min, axis.max - axis.range); // #618\r\n axis.userMax = axis.max;\r\n if (secondPass) {\r\n axis.range = null; // don't use it when running setExtremes\r\n }\r\n }\r\n\r\n // adjust min and max for the minimum range\r\n axis.adjustForMinRange();\r\n\r\n // Pad the values to get clear of the chart's edges. To avoid tickInterval taking the padding\r\n // into account, we do this after computing tick interval (#1337).\r\n if (\r\n !categories &&\r\n !axis.usePercentage &&\r\n !isLinked &&\r\n defined(axis.min) &&\r\n defined(axis.max)\r\n ) {\r\n length = axis.max - axis.min;\r\n if (length) {\r\n if (\r\n !defined(options.min) &&\r\n !defined(axis.userMin) &&\r\n minPadding &&\r\n (axis.dataMin < 0 || !axis.ignoreMinPadding)\r\n ) {\r\n axis.min -= length * minPadding;\r\n }\r\n if (\r\n !defined(options.max) &&\r\n !defined(axis.userMax) &&\r\n maxPadding &&\r\n (axis.dataMax > 0 || !axis.ignoreMaxPadding)\r\n ) {\r\n axis.max += length * maxPadding;\r\n }\r\n }\r\n }\r\n\r\n // get tickInterval\r\n if (\r\n axis.min === axis.max ||\r\n axis.min === undefined ||\r\n axis.max === undefined\r\n ) {\r\n axis.tickInterval = 1;\r\n }\r\n else if (\r\n isLinked &&\r\n !tickIntervalOption &&\r\n tickPixelIntervalOption === axis.linkedParent.options.tickPixelInterval\r\n ) {\r\n axis.tickInterval = axis.linkedParent.tickInterval;\r\n }\r\n else {\r\n axis.tickInterval = pick(\r\n tickIntervalOption,\r\n categories // for categoried axis, 1 is default, for linear axis use tickPix\r\n ? 1\r\n : ((axis.max - axis.min) * tickPixelIntervalOption) /\r\n (axis.len || 1)\r\n );\r\n }\r\n\r\n // Now we're finished detecting min and max, crop and group series data. This\r\n // is in turn needed in order to find tick positions in ordinal axes.\r\n if (isXAxis && !secondPass) {\r\n each(axis.series, function(series) {\r\n series.processData(\r\n axis.min !== axis.oldMin || axis.max !== axis.oldMax\r\n );\r\n });\r\n }\r\n\r\n // set the translation factor used in translate function\r\n axis.setAxisTranslation(secondPass);\r\n\r\n // hook for ordinal axes and radial axes\r\n if (axis.beforeSetTickPositions) {\r\n axis.beforeSetTickPositions();\r\n }\r\n\r\n // hook for extensions, used in Highstock ordinal axes\r\n if (axis.postProcessTickInterval) {\r\n axis.tickInterval = axis.postProcessTickInterval(axis.tickInterval);\r\n }\r\n\r\n // Before normalizing the tick interval, handle minimum tick interval. This applies only if tickInterval is not defined.\r\n if (!tickIntervalOption && axis.tickInterval < minTickIntervalOption) {\r\n axis.tickInterval = minTickIntervalOption;\r\n }\r\n\r\n // for linear axes, get magnitude and normalize the interval\r\n if (!isDatetimeAxis && !isLog) {\r\n // linear\r\n magnitude = math.pow(\r\n 10,\r\n mathFloor(math.log(axis.tickInterval) / math.LN10)\r\n );\r\n if (!tickIntervalOption) {\r\n axis.tickInterval = normalizeTickInterval(\r\n axis.tickInterval,\r\n null,\r\n magnitude,\r\n options\r\n );\r\n }\r\n }\r\n\r\n // get minorTickInterval\r\n axis.minorTickInterval =\r\n options.minorTickInterval === \"auto\" && axis.tickInterval\r\n ? axis.tickInterval / 5\r\n : options.minorTickInterval;\r\n\r\n // find the tick positions\r\n axis.tickPositions = tickPositions =\r\n options.tickPositions ||\r\n (tickPositioner && tickPositioner.apply(axis, [axis.min, axis.max]));\r\n if (!tickPositions) {\r\n if (isDatetimeAxis) {\r\n tickPositions = (axis.getNonLinearTimeTicks || getTimeTicks)(\r\n normalizeTimeTickInterval(axis.tickInterval, options.units),\r\n axis.min,\r\n axis.max,\r\n options.startOfWeek,\r\n axis.ordinalPositions,\r\n axis.closestPointRange,\r\n true\r\n );\r\n }\r\n else if (isLog) {\r\n tickPositions = axis.getLogTickPositions(\r\n axis.tickInterval,\r\n axis.min,\r\n axis.max\r\n );\r\n }\r\n else {\r\n tickPositions = axis.getLinearTickPositions(\r\n axis.tickInterval,\r\n axis.min,\r\n axis.max\r\n );\r\n }\r\n axis.tickPositions = tickPositions;\r\n }\r\n\r\n if (!isLinked) {\r\n // reset min/max or remove extremes based on start/end on tick\r\n var roundedMin = tickPositions[0],\r\n roundedMax = tickPositions[tickPositions.length - 1],\r\n minPointOffset = axis.minPointOffset || 0,\r\n singlePad;\r\n\r\n if (options.startOnTick) {\r\n axis.min = roundedMin;\r\n }\r\n else if (axis.min - minPointOffset > roundedMin) {\r\n tickPositions.shift();\r\n }\r\n\r\n if (options.endOnTick) {\r\n axis.max = roundedMax;\r\n }\r\n else if (axis.max + minPointOffset < roundedMax) {\r\n tickPositions.pop();\r\n }\r\n\r\n // When there is only one point, or all points have the same value on this axis, then min\r\n // and max are equal and tickPositions.length is 1. In this case, add some padding\r\n // in order to center the point, but leave it with one tick. #1337.\r\n if (tickPositions.length === 1) {\r\n singlePad = 1e-9; // The lowest possible number to avoid extra padding on columns\r\n axis.min -= singlePad;\r\n axis.max += singlePad;\r\n }\r\n }\r\n },\r\n\r\n /**\r\n * Set the max ticks of either the x and y axis collection\r\n */\r\n setMaxTicks: function() {\r\n var chart = this.chart,\r\n maxTicks = chart.maxTicks,\r\n tickPositions = this.tickPositions,\r\n xOrY = this.xOrY;\r\n\r\n if (!maxTicks) {\r\n // first call, or maxTicks have been reset after a zoom operation\r\n maxTicks = {\r\n x: 0,\r\n y: 0\r\n };\r\n }\r\n\r\n if (\r\n !this.isLinked &&\r\n !this.isDatetimeAxis &&\r\n tickPositions.length > maxTicks[xOrY] &&\r\n this.options.alignTicks !== false\r\n ) {\r\n maxTicks[xOrY] = tickPositions.length;\r\n }\r\n chart.maxTicks = maxTicks;\r\n },\r\n\r\n /**\r\n * When using multiple axes, adjust the number of ticks to match the highest\r\n * number of ticks in that group\r\n */\r\n adjustTickAmount: function() {\r\n var axis = this,\r\n chart = axis.chart,\r\n xOrY = axis.xOrY,\r\n tickPositions = axis.tickPositions,\r\n maxTicks = chart.maxTicks;\r\n\r\n if (\r\n maxTicks &&\r\n maxTicks[xOrY] &&\r\n !axis.isDatetimeAxis &&\r\n !axis.categories &&\r\n !axis.isLinked &&\r\n axis.options.alignTicks !== false\r\n ) {\r\n // only apply to linear scale\r\n var oldTickAmount = axis.tickAmount,\r\n calculatedTickAmount = tickPositions.length,\r\n tickAmount;\r\n\r\n // set the axis-level tickAmount to use below\r\n axis.tickAmount = tickAmount = maxTicks[xOrY];\r\n\r\n if (calculatedTickAmount < tickAmount) {\r\n while (tickPositions.length < tickAmount) {\r\n tickPositions.push(\r\n correctFloat(\r\n tickPositions[tickPositions.length - 1] + axis.tickInterval\r\n )\r\n );\r\n }\r\n axis.transA *= (calculatedTickAmount - 1) / (tickAmount - 1);\r\n axis.max = tickPositions[tickPositions.length - 1];\r\n }\r\n if (defined(oldTickAmount) && tickAmount !== oldTickAmount) {\r\n axis.isDirty = true;\r\n }\r\n }\r\n },\r\n\r\n /**\r\n * Set the scale based on data min and max, user set min and max or options\r\n *\r\n */\r\n setScale: function() {\r\n var axis = this,\r\n stacks = axis.stacks,\r\n type,\r\n i,\r\n isDirtyData,\r\n isDirtyAxisLength;\r\n\r\n axis.oldMin = axis.min;\r\n axis.oldMax = axis.max;\r\n axis.oldAxisLength = axis.len;\r\n\r\n // set the new axisLength\r\n axis.setAxisSize();\r\n //axisLength = horiz ? axisWidth : axisHeight;\r\n isDirtyAxisLength = axis.len !== axis.oldAxisLength;\r\n\r\n // is there new data?\r\n each(axis.series, function(series) {\r\n if (series.isDirtyData || series.isDirty || series.xAxis.isDirty) {\r\n // when x axis is dirty, we need new data extremes for y as well\r\n isDirtyData = true;\r\n }\r\n });\r\n\r\n // do we really need to go through all this?\r\n if (\r\n isDirtyAxisLength ||\r\n isDirtyData ||\r\n axis.isLinked ||\r\n axis.userMin !== axis.oldUserMin ||\r\n axis.userMax !== axis.oldUserMax\r\n ) {\r\n // get data extremes if needed\r\n axis.getSeriesExtremes();\r\n\r\n // get fixed positions based on tickInterval\r\n axis.setTickPositions();\r\n\r\n // record old values to decide whether a rescale is necessary later on (#540)\r\n axis.oldUserMin = axis.userMin;\r\n axis.oldUserMax = axis.userMax;\r\n\r\n // Mark as dirty if it is not already set to dirty and extremes have changed. #595.\r\n if (!axis.isDirty) {\r\n axis.isDirty =\r\n isDirtyAxisLength ||\r\n axis.min !== axis.oldMin ||\r\n axis.max !== axis.oldMax;\r\n }\r\n }\r\n\r\n // reset stacks\r\n if (!axis.isXAxis) {\r\n for (type in stacks) {\r\n for (i in stacks[type]) {\r\n stacks[type][i].cum = stacks[type][i].total;\r\n }\r\n }\r\n }\r\n\r\n // Set the maximum tick amount\r\n axis.setMaxTicks();\r\n },\r\n\r\n /**\r\n * Set the extremes and optionally redraw\r\n * @param {Number} newMin\r\n * @param {Number} newMax\r\n * @param {Boolean} redraw\r\n * @param {Boolean|Object} animation Whether to apply animation, and optionally animation\r\n * configuration\r\n * @param {Object} eventArguments\r\n *\r\n */\r\n setExtremes: function(newMin, newMax, redraw, animation, eventArguments) {\r\n var axis = this,\r\n chart = axis.chart;\r\n\r\n redraw = pick(redraw, true); // defaults to true\r\n\r\n // Extend the arguments with min and max\r\n eventArguments = extend(eventArguments, {\r\n min: newMin,\r\n max: newMax\r\n });\r\n\r\n // Fire the event\r\n fireEvent(axis, \"setExtremes\", eventArguments, function() {\r\n // the default event handler\r\n\r\n axis.userMin = newMin;\r\n axis.userMax = newMax;\r\n\r\n // Mark for running afterSetExtremes\r\n axis.isDirtyExtremes = true;\r\n\r\n // redraw\r\n if (redraw) {\r\n chart.redraw(animation);\r\n }\r\n });\r\n },\r\n\r\n /**\r\n * Overridable method for zooming chart. Pulled out in a separate method to allow overriding\r\n * in stock charts.\r\n */\r\n zoom: function(newMin, newMax) {\r\n this.setExtremes(newMin, newMax, false, UNDEFINED, { trigger: \"zoom\" });\r\n return true;\r\n },\r\n\r\n /**\r\n * Update the axis metrics\r\n */\r\n setAxisSize: function() {\r\n var axis = this,\r\n chart = axis.chart,\r\n options = axis.options;\r\n\r\n var offsetLeft = options.offsetLeft || 0,\r\n offsetRight = options.offsetRight || 0;\r\n\r\n // basic values\r\n // expose to use in Series object and navigator\r\n axis.left = pick(options.left, chart.plotLeft + offsetLeft);\r\n axis.top = pick(options.top, chart.plotTop);\r\n axis.width = pick(\r\n options.width,\r\n chart.plotWidth - offsetLeft + offsetRight\r\n );\r\n axis.height = pick(options.height, chart.plotHeight);\r\n axis.bottom = chart.chartHeight - axis.height - axis.top;\r\n axis.right = chart.chartWidth - axis.width - axis.left;\r\n axis.len = mathMax(axis.horiz ? axis.width : axis.height, 0); // mathMax fixes #905\r\n },\r\n\r\n /**\r\n * Get the actual axis extremes\r\n */\r\n getExtremes: function() {\r\n var axis = this,\r\n isLog = axis.isLog;\r\n\r\n return {\r\n min: isLog ? correctFloat(lin2log(axis.min)) : axis.min,\r\n max: isLog ? correctFloat(lin2log(axis.max)) : axis.max,\r\n dataMin: axis.dataMin,\r\n dataMax: axis.dataMax,\r\n userMin: axis.userMin,\r\n userMax: axis.userMax\r\n };\r\n },\r\n\r\n /**\r\n * Get the zero plane either based on zero or on the min or max value.\r\n * Used in bar and area plots\r\n */\r\n getThreshold: function(threshold) {\r\n var axis = this,\r\n isLog = axis.isLog;\r\n\r\n var realMin = isLog ? lin2log(axis.min) : axis.min,\r\n realMax = isLog ? lin2log(axis.max) : axis.max;\r\n\r\n if (realMin > threshold || threshold === null) {\r\n threshold = realMin;\r\n }\r\n else if (realMax < threshold) {\r\n threshold = realMax;\r\n }\r\n\r\n return axis.translate(threshold, 0, 1, 0, 1);\r\n },\r\n\r\n /**\r\n * Add a plot band or plot line after render time\r\n *\r\n * @param options {Object} The plotBand or plotLine configuration object\r\n */\r\n addPlotBandOrLine: function(options) {\r\n var obj = new PlotLineOrBand(this, options).render();\r\n this.plotLinesAndBands.push(obj);\r\n return obj;\r\n },\r\n\r\n /**\r\n * Render the tick labels to a preliminary position to get their sizes\r\n */\r\n getOffset: function() {\r\n var axis = this,\r\n chart = axis.chart,\r\n renderer = chart.renderer,\r\n options = axis.options,\r\n tickPositions = axis.tickPositions,\r\n ticks = axis.ticks,\r\n horiz = axis.horiz,\r\n side = axis.side,\r\n hasData,\r\n showAxis,\r\n titleOffset = 0,\r\n titleOffsetOption,\r\n titleMargin = 0,\r\n axisTitleOptions = options.title,\r\n labelOptions = options.labels,\r\n labelOffset = 0, // reset\r\n axisOffset = chart.axisOffset,\r\n directionFactor = [-1, 1, 1, -1][side],\r\n n;\r\n\r\n // For reuse in Axis.render\r\n axis.hasData = hasData =\r\n axis.hasVisibleSeries ||\r\n (defined(axis.min) && defined(axis.max) && !!tickPositions);\r\n axis.showAxis = showAxis = hasData || pick(options.showEmpty, true);\r\n\r\n // Create the axisGroup and gridGroup elements on first iteration\r\n if (!axis.axisGroup) {\r\n axis.gridGroup = renderer\r\n .g(\"grid\")\r\n .attr({ zIndex: options.gridZIndex || 1 })\r\n .add();\r\n axis.axisGroup = renderer\r\n .g(\"axis\")\r\n .attr({ zIndex: options.zIndex || 2 })\r\n .add();\r\n axis.labelGroup = renderer\r\n .g(\"axis-labels\")\r\n .attr({ zIndex: labelOptions.zIndex || 7 })\r\n .add();\r\n }\r\n\r\n if (hasData || axis.isLinked) {\r\n each(tickPositions, function(pos) {\r\n if (!ticks[pos]) {\r\n ticks[pos] = new Tick(axis, pos);\r\n }\r\n else {\r\n ticks[pos].addLabel(); // update labels depending on tick interval\r\n }\r\n });\r\n\r\n each(tickPositions, function(pos) {\r\n // left side must be align: right and right side must have align: left for labels\r\n if (\r\n side === 0 ||\r\n side === 2 ||\r\n { 1: \"left\", 3: \"right\" }[side] === labelOptions.align\r\n ) {\r\n // get the highest offset\r\n labelOffset = mathMax(ticks[pos].getLabelSize(), labelOffset);\r\n }\r\n });\r\n\r\n if (axis.staggerLines) {\r\n labelOffset += (axis.staggerLines - 1) * 16;\r\n }\r\n }\r\n else {\r\n // doesn't have data\r\n for (n in ticks) {\r\n ticks[n].destroy();\r\n delete ticks[n];\r\n }\r\n }\r\n\r\n if (axisTitleOptions && axisTitleOptions.text) {\r\n if (!axis.axisTitle) {\r\n axis.axisTitle = renderer\r\n .text(axisTitleOptions.text, 0, 0, axisTitleOptions.useHTML)\r\n .attr({\r\n zIndex: 7,\r\n rotation: axisTitleOptions.rotation || 0,\r\n align:\r\n axisTitleOptions.textAlign ||\r\n { low: \"left\", middle: \"center\", high: \"right\" }[\r\n axisTitleOptions.align\r\n ]\r\n })\r\n .css(axisTitleOptions.style)\r\n .add(axis.axisGroup);\r\n axis.axisTitle.isNew = true;\r\n }\r\n\r\n if (showAxis) {\r\n titleOffset = axis.axisTitle.getBBox()[horiz ? \"height\" : \"width\"];\r\n titleMargin = pick(axisTitleOptions.margin, horiz ? 5 : 10);\r\n titleOffsetOption = axisTitleOptions.offset;\r\n }\r\n\r\n // hide or show the title depending on whether showEmpty is set\r\n axis.axisTitle[showAxis ? \"show\" : \"hide\"]();\r\n }\r\n\r\n // handle automatic or user set offset\r\n axis.offset = directionFactor * pick(options.offset, axisOffset[side]);\r\n\r\n axis.axisTitleMargin = pick(\r\n titleOffsetOption,\r\n labelOffset +\r\n titleMargin +\r\n (side !== 2 &&\r\n labelOffset &&\r\n directionFactor * options.labels[horiz ? \"y\" : \"x\"])\r\n );\r\n\r\n axisOffset[side] = mathMax(\r\n axisOffset[side],\r\n axis.axisTitleMargin + titleOffset + directionFactor * axis.offset\r\n );\r\n },\r\n\r\n /**\r\n * Get the path for the axis line\r\n */\r\n getLinePath: function(lineWidth) {\r\n var chart = this.chart,\r\n opposite = this.opposite,\r\n offset = this.offset,\r\n horiz = this.horiz,\r\n lineLeft = this.left + (opposite ? this.width : 0) + offset,\r\n lineTop =\r\n chart.chartHeight -\r\n this.bottom -\r\n (opposite ? this.height : 0) +\r\n offset;\r\n\r\n this.lineTop = lineTop; // used by flag series\r\n\r\n return chart.renderer.crispLine(\r\n [\r\n M,\r\n horiz ? this.left : lineLeft,\r\n horiz ? lineTop : this.top,\r\n L,\r\n horiz ? chart.chartWidth - this.right : lineLeft,\r\n horiz ? lineTop : chart.chartHeight - this.bottom\r\n ],\r\n lineWidth\r\n );\r\n },\r\n\r\n /**\r\n * Position the title\r\n */\r\n getTitlePosition: function() {\r\n // compute anchor points for each of the title align options\r\n var horiz = this.horiz,\r\n axisLeft = this.left,\r\n axisTop = this.top,\r\n axisLength = this.len,\r\n axisTitleOptions = this.options.title,\r\n margin = horiz ? axisLeft : axisTop,\r\n opposite = this.opposite,\r\n offset = this.offset,\r\n fontSize = pInt(axisTitleOptions.style.fontSize || 12),\r\n // the position in the length direction of the axis\r\n alongAxis = {\r\n low: margin + (horiz ? 0 : axisLength),\r\n middle: margin + axisLength / 2,\r\n high: margin + (horiz ? axisLength : 0)\r\n }[axisTitleOptions.align],\r\n // the position in the perpendicular direction of the axis\r\n offAxis =\r\n (horiz ? axisTop + this.height : axisLeft) +\r\n (horiz ? 1 : -1) * // horizontal axis reverses the margin\r\n (opposite ? -1 : 1) * // so does opposite axes\r\n this.axisTitleMargin +\r\n (this.side === 2 ? fontSize : 0);\r\n\r\n return {\r\n x: horiz\r\n ? alongAxis\r\n : offAxis +\r\n (opposite ? this.width : 0) +\r\n offset +\r\n (axisTitleOptions.x || 0), // x\r\n y: horiz\r\n ? offAxis - (opposite ? this.height : 0) + offset\r\n : alongAxis + (axisTitleOptions.y || 0) // y\r\n };\r\n },\r\n\r\n /**\r\n * Render the axis\r\n */\r\n render: function() {\r\n var axis = this,\r\n chart = axis.chart,\r\n renderer = chart.renderer,\r\n options = axis.options,\r\n isLog = axis.isLog,\r\n isLinked = axis.isLinked,\r\n tickPositions = axis.tickPositions,\r\n axisTitle = axis.axisTitle,\r\n stacks = axis.stacks,\r\n ticks = axis.ticks,\r\n minorTicks = axis.minorTicks,\r\n alternateBands = axis.alternateBands,\r\n stackLabelOptions = options.stackLabels,\r\n alternateGridColor = options.alternateGridColor,\r\n tickmarkOffset = axis.tickmarkOffset,\r\n lineWidth = options.lineWidth,\r\n linePath,\r\n hasRendered = chart.hasRendered,\r\n slideInTicks =\r\n hasRendered && defined(axis.oldMin) && !isNaN(axis.oldMin),\r\n hasData = axis.hasData,\r\n showAxis = axis.showAxis,\r\n from,\r\n to;\r\n\r\n // If the series has data draw the ticks. Else only the line and title\r\n if (hasData || isLinked) {\r\n // minor ticks\r\n if (axis.minorTickInterval && !axis.categories) {\r\n each(axis.getMinorTickPositions(), function(pos) {\r\n if (!minorTicks[pos]) {\r\n minorTicks[pos] = new Tick(axis, pos, \"minor\");\r\n }\r\n\r\n // render new ticks in old position\r\n if (slideInTicks && minorTicks[pos].isNew) {\r\n minorTicks[pos].render(null, true);\r\n }\r\n\r\n minorTicks[pos].isActive = true;\r\n minorTicks[pos].render();\r\n });\r\n }\r\n\r\n // Major ticks. Pull out the first item and render it last so that\r\n // we can get the position of the neighbour label. #808.\r\n if (tickPositions.length) {\r\n // #1300\r\n each(tickPositions.slice(1).concat([tickPositions[0]]), function(\r\n pos,\r\n i\r\n ) {\r\n // Reorganize the indices\r\n i = i === tickPositions.length - 1 ? 0 : i + 1;\r\n\r\n // linked axes need an extra check to find out if\r\n if (!isLinked || (pos >= axis.min && pos <= axis.max)) {\r\n if (!ticks[pos]) {\r\n ticks[pos] = new Tick(axis, pos);\r\n }\r\n\r\n // render new ticks in old position\r\n if (slideInTicks && ticks[pos].isNew) {\r\n ticks[pos].render(i, true);\r\n }\r\n\r\n ticks[pos].isActive = true;\r\n ticks[pos].render(i);\r\n }\r\n });\r\n }\r\n\r\n // alternate grid color\r\n if (alternateGridColor) {\r\n each(tickPositions, function(pos, i) {\r\n if (i % 2 === 0 && pos < axis.max) {\r\n if (!alternateBands[pos]) {\r\n alternateBands[pos] = new PlotLineOrBand(axis);\r\n }\r\n from = pos + tickmarkOffset; // #949\r\n to =\r\n tickPositions[i + 1] !== UNDEFINED\r\n ? tickPositions[i + 1] + tickmarkOffset\r\n : axis.max;\r\n alternateBands[pos].options = {\r\n from: isLog ? lin2log(from) : from,\r\n to: isLog ? lin2log(to) : to,\r\n color: alternateGridColor\r\n };\r\n alternateBands[pos].render();\r\n alternateBands[pos].isActive = true;\r\n }\r\n });\r\n }\r\n\r\n // custom plot lines and bands\r\n if (!axis._addedPlotLB) {\r\n // only first time\r\n each(\r\n (options.plotLines || []).concat(options.plotBands || []),\r\n function(plotLineOptions) {\r\n //plotLinesAndBands.push(new PlotLineOrBand(plotLineOptions).render());\r\n axis.addPlotBandOrLine(plotLineOptions);\r\n }\r\n );\r\n axis._addedPlotLB = true;\r\n }\r\n } // end if hasData\r\n\r\n // remove inactive ticks\r\n each([ticks, minorTicks, alternateBands], function(coll) {\r\n var pos;\r\n for (pos in coll) {\r\n if (!coll[pos].isActive) {\r\n coll[pos].destroy();\r\n delete coll[pos];\r\n }\r\n else {\r\n coll[pos].isActive = false; // reset\r\n }\r\n }\r\n });\r\n\r\n // Static items. As the axis group is cleared on subsequent calls\r\n // to render, these items are added outside the group.\r\n // axis line\r\n if (lineWidth) {\r\n linePath = axis.getLinePath(lineWidth);\r\n if (!axis.axisLine) {\r\n axis.axisLine = renderer\r\n .path(linePath)\r\n .attr({\r\n stroke: options.lineColor,\r\n \"stroke-width\": lineWidth,\r\n zIndex: 7\r\n })\r\n .add(axis.axisGroup);\r\n }\r\n else {\r\n axis.axisLine.animate({ d: linePath });\r\n }\r\n\r\n // show or hide the line depending on options.showEmpty\r\n axis.axisLine[showAxis ? \"show\" : \"hide\"]();\r\n }\r\n\r\n if (axisTitle && showAxis) {\r\n axisTitle[axisTitle.isNew ? \"attr\" : \"animate\"](\r\n axis.getTitlePosition()\r\n );\r\n axisTitle.isNew = false;\r\n }\r\n\r\n // Stacked totals:\r\n if (stackLabelOptions && stackLabelOptions.enabled) {\r\n var stackKey,\r\n oneStack,\r\n stackCategory,\r\n stackTotalGroup = axis.stackTotalGroup;\r\n\r\n // Create a separate group for the stack total labels\r\n if (!stackTotalGroup) {\r\n axis.stackTotalGroup = stackTotalGroup = renderer\r\n .g(\"stack-labels\")\r\n .attr({\r\n visibility: VISIBLE,\r\n zIndex: 6\r\n })\r\n .add();\r\n }\r\n\r\n // plotLeft/Top will change when y axis gets wider so we need to translate the\r\n // stackTotalGroup at every render call. See bug #506 and #516\r\n stackTotalGroup.translate(chart.plotLeft, chart.plotTop);\r\n\r\n // Render each stack total\r\n for (stackKey in stacks) {\r\n oneStack = stacks[stackKey];\r\n for (stackCategory in oneStack) {\r\n oneStack[stackCategory].render(stackTotalGroup);\r\n }\r\n }\r\n }\r\n // End stacked totals\r\n\r\n axis.isDirty = false;\r\n },\r\n\r\n /**\r\n * Remove a plot band or plot line from the chart by id\r\n * @param {Object} id\r\n */\r\n removePlotBandOrLine: function(id) {\r\n var plotLinesAndBands = this.plotLinesAndBands,\r\n i = plotLinesAndBands.length;\r\n while (i--) {\r\n if (plotLinesAndBands[i].id === id) {\r\n plotLinesAndBands[i].destroy();\r\n }\r\n }\r\n },\r\n\r\n /**\r\n * Update the axis title by options\r\n */\r\n setTitle: function(newTitleOptions, redraw) {\r\n var chart = this.chart,\r\n options = this.options,\r\n axisTitle = this.axisTitle;\r\n\r\n options.title = merge(options.title, newTitleOptions);\r\n\r\n this.axisTitle = axisTitle && axisTitle.destroy(); // #922\r\n this.isDirty = true;\r\n\r\n if (pick(redraw, true)) {\r\n chart.redraw();\r\n }\r\n },\r\n\r\n /**\r\n * Redraw the axis to reflect changes in the data or axis extremes\r\n */\r\n redraw: function() {\r\n var axis = this,\r\n chart = axis.chart;\r\n\r\n // hide tooltip and hover states\r\n if (chart.tracker.resetTracker) {\r\n chart.tracker.resetTracker(true);\r\n }\r\n\r\n // render the axis\r\n axis.render();\r\n\r\n // move plot lines and bands\r\n each(axis.plotLinesAndBands, function(plotLine) {\r\n plotLine.render();\r\n });\r\n\r\n // mark associated series as dirty and ready for redraw\r\n each(axis.series, function(series) {\r\n series.isDirty = true;\r\n });\r\n },\r\n\r\n /**\r\n * Set new axis categories and optionally redraw\r\n * @param {Array} newCategories\r\n * @param {Boolean} doRedraw\r\n */\r\n setCategories: function(newCategories, doRedraw) {\r\n var axis = this,\r\n chart = axis.chart;\r\n\r\n // set the categories\r\n axis.categories = axis.userOptions.categories = newCategories;\r\n\r\n // force reindexing tooltips\r\n each(axis.series, function(series) {\r\n series.translate();\r\n series.setTooltipPoints(true);\r\n });\r\n\r\n // optionally redraw\r\n axis.isDirty = true;\r\n\r\n if (pick(doRedraw, true)) {\r\n chart.redraw();\r\n }\r\n },\r\n\r\n /**\r\n * Destroys an Axis instance.\r\n */\r\n destroy: function() {\r\n var axis = this,\r\n stacks = axis.stacks,\r\n stackKey;\r\n\r\n // Remove the events\r\n removeEvent(axis);\r\n\r\n // Destroy each stack total\r\n for (stackKey in stacks) {\r\n destroyObjectProperties(stacks[stackKey]);\r\n\r\n stacks[stackKey] = null;\r\n }\r\n\r\n // Destroy collections\r\n each(\r\n [\r\n axis.ticks,\r\n axis.minorTicks,\r\n axis.alternateBands,\r\n axis.plotLinesAndBands\r\n ],\r\n function(coll) {\r\n destroyObjectProperties(coll);\r\n }\r\n );\r\n\r\n // Destroy local variables\r\n each(\r\n [\r\n \"stackTotalGroup\",\r\n \"axisLine\",\r\n \"axisGroup\",\r\n \"gridGroup\",\r\n \"labelGroup\",\r\n \"axisTitle\"\r\n ],\r\n function(prop) {\r\n if (axis[prop]) {\r\n axis[prop] = axis[prop].destroy();\r\n }\r\n }\r\n );\r\n }\r\n }; // end Axis\r\n\r\n /**\r\n * The tooltip object\r\n * @param {Object} chart The chart instance\r\n * @param {Object} options Tooltip options\r\n */\r\n function Tooltip(chart, options) {\r\n var borderWidth = options.borderWidth,\r\n style = options.style,\r\n padding = pInt(style.padding);\r\n\r\n // Save the chart and options\r\n this.chart = chart;\r\n this.options = options;\r\n\r\n // Keep track of the current series\r\n //this.currentSeries = UNDEFINED;\r\n\r\n // List of crosshairs\r\n this.crosshairs = [];\r\n\r\n // Current values of x and y when animating\r\n this.now = { x: 0, y: 0 };\r\n\r\n // The tooltip is initially hidden\r\n this.isHidden = true;\r\n\r\n // create the label\r\n this.label = chart.renderer\r\n .label(\r\n \"\",\r\n 0,\r\n 0,\r\n options.shape,\r\n null,\r\n null,\r\n options.useHTML,\r\n null,\r\n \"tooltip\"\r\n )\r\n .attr({\r\n padding: padding,\r\n fill: options.backgroundColor,\r\n \"stroke-width\": borderWidth,\r\n r: options.borderRadius,\r\n zIndex: 8\r\n })\r\n .css(style)\r\n .css({ padding: 0 }) // Remove it from VML, the padding is applied as an attribute instead (#1117)\r\n .hide()\r\n .add();\r\n\r\n // When using canVG the shadow shows up as a gray circle\r\n // even if the tooltip is hidden.\r\n if (!useCanVG) {\r\n this.label.shadow(options.shadow);\r\n }\r\n\r\n // Public property for getting the shared state.\r\n this.shared = options.shared;\r\n }\r\n\r\n Tooltip.prototype = {\r\n /**\r\n * Destroy the tooltip and its elements.\r\n */\r\n destroy: function() {\r\n each(this.crosshairs, function(crosshair) {\r\n if (crosshair) {\r\n crosshair.destroy();\r\n }\r\n });\r\n\r\n // Destroy and clear local variables\r\n if (this.label) {\r\n this.label = this.label.destroy();\r\n }\r\n },\r\n\r\n /**\r\n * Provide a soft movement for the tooltip\r\n *\r\n * @param {Number} x\r\n * @param {Number} y\r\n * @private\r\n */\r\n move: function(x, y, anchorX, anchorY) {\r\n var tooltip = this,\r\n now = tooltip.now,\r\n animate = tooltip.options.animation !== false && !tooltip.isHidden;\r\n\r\n // get intermediate values for animation\r\n extend(now, {\r\n x: animate ? (2 * now.x + x) / 3 : x,\r\n y: animate ? (now.y + y) / 2 : y,\r\n anchorX: animate ? (2 * now.anchorX + anchorX) / 3 : anchorX,\r\n anchorY: animate ? (now.anchorY + anchorY) / 2 : anchorY\r\n });\r\n\r\n // move to the intermediate value\r\n tooltip.label.attr(now);\r\n\r\n // run on next tick of the mouse tracker\r\n if (animate && (mathAbs(x - now.x) > 1 || mathAbs(y - now.y) > 1)) {\r\n // never allow two timeouts\r\n clearTimeout(this.tooltipTimeout);\r\n\r\n // set the fixed interval ticking for the smooth tooltip\r\n this.tooltipTimeout = setTimeout(function() {\r\n // The interval function may still be running during destroy, so check that the chart is really there before calling.\r\n if (tooltip) {\r\n tooltip.move(x, y, anchorX, anchorY);\r\n }\r\n }, 32);\r\n }\r\n },\r\n\r\n /**\r\n * Hide the tooltip\r\n */\r\n hide: function() {\r\n if (!this.isHidden) {\r\n var hoverPoints = this.chart.hoverPoints;\r\n\r\n this.label.hide();\r\n\r\n // hide previous hoverPoints and set new\r\n if (hoverPoints) {\r\n each(hoverPoints, function(point) {\r\n point.setState();\r\n });\r\n }\r\n\r\n this.chart.hoverPoints = null;\r\n this.isHidden = true;\r\n }\r\n },\r\n\r\n /**\r\n * Hide the crosshairs\r\n */\r\n hideCrosshairs: function() {\r\n each(this.crosshairs, function(crosshair) {\r\n if (crosshair) {\r\n crosshair.hide();\r\n }\r\n });\r\n },\r\n\r\n /**\r\n * Extendable method to get the anchor position of the tooltip\r\n * from a point or set of points\r\n */\r\n getAnchor: function(points, mouseEvent) {\r\n var ret,\r\n chart = this.chart,\r\n inverted = chart.inverted,\r\n plotX = 0,\r\n plotY = 0,\r\n yAxis;\r\n\r\n points = splat(points);\r\n\r\n // Pie uses a special tooltipPos\r\n ret = points[0].tooltipPos;\r\n\r\n // When shared, use the average position\r\n if (!ret) {\r\n each(points, function(point) {\r\n yAxis = point.series.yAxis;\r\n plotX += point.plotX;\r\n plotY +=\r\n (point.plotLow\r\n ? (point.plotLow + point.plotHigh) / 2\r\n : point.plotY) +\r\n (!inverted && yAxis ? yAxis.top - chart.plotTop : 0); // #1151\r\n });\r\n\r\n plotX /= points.length;\r\n plotY /= points.length;\r\n\r\n ret = [\r\n inverted ? chart.plotWidth - plotY : plotX,\r\n this.shared && !inverted && points.length > 1 && mouseEvent\r\n ? mouseEvent.chartY - chart.plotTop // place shared tooltip next to the mouse (#424)\r\n : inverted\r\n ? chart.plotHeight - plotX\r\n : plotY\r\n ];\r\n }\r\n\r\n return map(ret, mathRound);\r\n },\r\n\r\n /**\r\n * Place the tooltip in a chart without spilling over\r\n * and not covering the point it self.\r\n */\r\n getPosition: function(boxWidth, boxHeight, point) {\r\n // Set up the variables\r\n var chart = this.chart,\r\n plotLeft = chart.plotLeft,\r\n plotTop = chart.plotTop,\r\n plotWidth = chart.plotWidth,\r\n plotHeight = chart.plotHeight,\r\n distance = pick(this.options.distance, 12),\r\n pointX = point.plotX,\r\n pointY = point.plotY,\r\n x =\r\n pointX +\r\n plotLeft +\r\n (chart.inverted ? distance : -boxWidth - distance),\r\n y = pointY - boxHeight + plotTop + 15, // 15 means the point is 15 pixels up from the bottom of the tooltip\r\n alignedRight;\r\n\r\n // It is too far to the left, adjust it\r\n if (x < 7) {\r\n x = plotLeft + mathMax(pointX, 0) + distance;\r\n }\r\n\r\n // Test to see if the tooltip is too far to the right,\r\n // if it is, move it back to be inside and then up to not cover the point.\r\n if (x + boxWidth > plotLeft + plotWidth) {\r\n x -= x + boxWidth - (plotLeft + plotWidth);\r\n y = pointY - boxHeight + plotTop - distance;\r\n alignedRight = true;\r\n }\r\n\r\n // If it is now above the plot area, align it to the top of the plot area\r\n if (y < plotTop + 5) {\r\n y = plotTop + 5;\r\n\r\n // If the tooltip is still covering the point, move it below instead\r\n if (alignedRight && pointY >= y && pointY <= y + boxHeight) {\r\n y = pointY + plotTop + distance; // below\r\n }\r\n }\r\n\r\n // Now if the tooltip is below the chart, move it up. It's better to cover the\r\n // point than to disappear outside the chart. #834.\r\n if (y + boxHeight > plotTop + plotHeight) {\r\n y = mathMax(plotTop, plotTop + plotHeight - boxHeight - distance); // below\r\n }\r\n\r\n return { x: x, y: y };\r\n },\r\n\r\n /**\r\n * Refresh the tooltip's text and position.\r\n * @param {Object} point\r\n */\r\n refresh: function(point, mouseEvent) {\r\n var tooltip = this,\r\n chart = tooltip.chart,\r\n label = tooltip.label,\r\n options = tooltip.options;\r\n\r\n /**\r\n * In case no user defined formatter is given, this will be used\r\n */\r\n function defaultFormatter() {\r\n var pThis = this,\r\n items = pThis.points || splat(pThis),\r\n series = items[0].series,\r\n s;\r\n\r\n // build the header\r\n s = [series.tooltipHeaderFormatter(items[0].key)];\r\n\r\n // build the values\r\n each(items, function(item) {\r\n series = item.series;\r\n s.push(\r\n (series.tooltipFormatter && series.tooltipFormatter(item)) ||\r\n item.point.tooltipFormatter(series.tooltipOptions.pointFormat)\r\n );\r\n });\r\n\r\n // footer\r\n s.push(options.footerFormat || \"\");\r\n\r\n return s.join(\"\");\r\n }\r\n\r\n var x,\r\n y,\r\n show,\r\n anchor,\r\n textConfig = {},\r\n text,\r\n pointConfig = [],\r\n formatter = options.formatter || defaultFormatter,\r\n hoverPoints = chart.hoverPoints,\r\n placedTooltipPoint,\r\n borderColor,\r\n crosshairsOptions = options.crosshairs,\r\n shared = tooltip.shared,\r\n currentSeries;\r\n\r\n // get the reference point coordinates (pie charts use tooltipPos)\r\n anchor = tooltip.getAnchor(point, mouseEvent);\r\n x = anchor[0];\r\n y = anchor[1];\r\n\r\n // shared tooltip, array is sent over\r\n if (shared && !(point.series && point.series.noSharedTooltip)) {\r\n // hide previous hoverPoints and set new\r\n\r\n chart.hoverPoints = point;\r\n if (hoverPoints) {\r\n each(hoverPoints, function(point) {\r\n point.setState();\r\n });\r\n }\r\n\r\n each(point, function(item) {\r\n item.setState(HOVER_STATE);\r\n\r\n pointConfig.push(item.getLabelConfig());\r\n });\r\n\r\n textConfig = {\r\n x: point[0].category,\r\n y: point[0].y\r\n };\r\n textConfig.points = pointConfig;\r\n point = point[0];\r\n\r\n // single point tooltip\r\n }\r\n else {\r\n textConfig = point.getLabelConfig();\r\n }\r\n text = formatter.call(textConfig);\r\n\r\n // register the current series\r\n currentSeries = point.series;\r\n\r\n // For line type series, hide tooltip if the point falls outside the plot\r\n show =\r\n shared ||\r\n !currentSeries.isCartesian ||\r\n currentSeries.tooltipOutsidePlot ||\r\n chart.isInsidePlot(x, y);\r\n\r\n // update the inner HTML\r\n if (text === false || !show) {\r\n this.hide();\r\n }\r\n else {\r\n // show it\r\n if (tooltip.isHidden) {\r\n label.show();\r\n }\r\n\r\n // update text\r\n label.attr({\r\n text: text\r\n });\r\n\r\n // set the stroke color of the box\r\n borderColor =\r\n options.borderColor ||\r\n point.color ||\r\n currentSeries.color ||\r\n \"#606060\";\r\n label.attr({\r\n stroke: borderColor\r\n });\r\n\r\n placedTooltipPoint = (options.positioner || tooltip.getPosition).call(\r\n tooltip,\r\n label.width,\r\n label.height,\r\n { plotX: x, plotY: y }\r\n );\r\n\r\n // do the move\r\n tooltip.move(\r\n mathRound(placedTooltipPoint.x),\r\n mathRound(placedTooltipPoint.y),\r\n x + chart.plotLeft,\r\n y + chart.plotTop\r\n );\r\n\r\n tooltip.isHidden = false;\r\n }\r\n\r\n // crosshairs\r\n if (crosshairsOptions) {\r\n crosshairsOptions = splat(crosshairsOptions); // [x, y]\r\n\r\n var path,\r\n i = crosshairsOptions.length,\r\n attribs,\r\n axis;\r\n\r\n while (i--) {\r\n axis = point.series[i ? \"yAxis\" : \"xAxis\"];\r\n if (crosshairsOptions[i] && axis) {\r\n path = axis.getPlotLinePath(\r\n i ? pick(point.stackY, point.y) : point.x, // #814\r\n 1\r\n );\r\n\r\n if (tooltip.crosshairs[i]) {\r\n tooltip.crosshairs[i].attr({ d: path, visibility: VISIBLE });\r\n }\r\n else {\r\n attribs = {\r\n \"stroke-width\": crosshairsOptions[i].width || 1,\r\n stroke: crosshairsOptions[i].color || \"#C0C0C0\",\r\n zIndex: crosshairsOptions[i].zIndex || 2\r\n };\r\n if (crosshairsOptions[i].dashStyle) {\r\n attribs.dashstyle = crosshairsOptions[i].dashStyle;\r\n }\r\n tooltip.crosshairs[i] = chart.renderer\r\n .path(path)\r\n .attr(attribs)\r\n .add();\r\n }\r\n }\r\n }\r\n }\r\n fireEvent(chart, \"tooltipRefresh\", {\r\n text: text,\r\n x: x + chart.plotLeft,\r\n y: y + chart.plotTop,\r\n borderColor: borderColor\r\n });\r\n }\r\n };\r\n /**\r\n * The mouse tracker object\r\n * @param {Object} chart The Chart instance\r\n * @param {Object} options The root options object\r\n */\r\n function MouseTracker(chart, options) {\r\n var zoomType = useCanVG ? \"\" : options.chart.zoomType;\r\n\r\n // Zoom status\r\n this.zoomX = /x/.test(zoomType);\r\n this.zoomY = /y/.test(zoomType);\r\n\r\n // Store reference to options\r\n this.options = options;\r\n\r\n // Reference to the chart\r\n this.chart = chart;\r\n\r\n // The interval id\r\n //this.tooltipTimeout = UNDEFINED;\r\n\r\n // The cached x hover position\r\n //this.hoverX = UNDEFINED;\r\n\r\n // The chart position\r\n //this.chartPosition = UNDEFINED;\r\n\r\n // The selection marker element\r\n //this.selectionMarker = UNDEFINED;\r\n\r\n // False or a value > 0 if a dragging operation\r\n //this.mouseDownX = UNDEFINED;\r\n //this.mouseDownY = UNDEFINED;\r\n this.init(chart, options.tooltip);\r\n }\r\n\r\n MouseTracker.prototype = {\r\n /**\r\n * Add crossbrowser support for chartX and chartY\r\n * @param {Object} e The event object in standard browsers\r\n */\r\n normalizeMouseEvent: function(e) {\r\n var chartPosition, chartX, chartY, ePos;\r\n\r\n // common IE normalizing\r\n e = e || win.event;\r\n if (!e.target) {\r\n e.target = e.srcElement;\r\n }\r\n\r\n // Framework specific normalizing (#1165)\r\n e = washMouseEvent(e);\r\n\r\n // iOS\r\n ePos = e.touches ? e.touches.item(0) : e;\r\n\r\n // get mouse position\r\n this.chartPosition = chartPosition = offset(this.chart.container);\r\n\r\n // chartX and chartY\r\n if (ePos.pageX === UNDEFINED) {\r\n // IE < 9. #886.\r\n chartX = e.x;\r\n chartY = e.y;\r\n }\r\n else {\r\n chartX = ePos.pageX - chartPosition.left;\r\n chartY = ePos.pageY - chartPosition.top;\r\n }\r\n\r\n return extend(e, {\r\n chartX: mathRound(chartX),\r\n chartY: mathRound(chartY)\r\n });\r\n },\r\n\r\n /**\r\n * Get the click position in terms of axis values.\r\n *\r\n * @param {Object} e A mouse event\r\n */\r\n getMouseCoordinates: function(e) {\r\n var coordinates = {\r\n xAxis: [],\r\n yAxis: []\r\n },\r\n chart = this.chart;\r\n\r\n each(chart.axes, function(axis) {\r\n var isXAxis = axis.isXAxis,\r\n isHorizontal = chart.inverted ? !isXAxis : isXAxis;\r\n\r\n coordinates[isXAxis ? \"xAxis\" : \"yAxis\"].push({\r\n axis: axis,\r\n value: axis.translate(\r\n (isHorizontal\r\n ? e.chartX - chart.plotLeft\r\n : axis.top + axis.len - e.chartY) - axis.minPixelPadding, // #1051\r\n true\r\n )\r\n });\r\n });\r\n return coordinates;\r\n },\r\n\r\n /**\r\n * Return the index in the tooltipPoints array, corresponding to pixel position in\r\n * the plot area.\r\n */\r\n getIndex: function(e) {\r\n var chart = this.chart;\r\n return chart.inverted\r\n ? chart.plotHeight + chart.plotTop - e.chartY\r\n : e.chartX - chart.plotLeft;\r\n },\r\n\r\n /**\r\n * With line type charts with a single tracker, get the point closest to the mouse\r\n */\r\n onmousemove: function(e) {\r\n var mouseTracker = this,\r\n chart = mouseTracker.chart,\r\n series = chart.series,\r\n tooltip = chart.tooltip,\r\n point,\r\n points,\r\n hoverPoint = chart.hoverPoint,\r\n hoverSeries = chart.hoverSeries,\r\n i,\r\n j,\r\n distance = chart.chartWidth,\r\n index = mouseTracker.getIndex(e);\r\n\r\n // shared tooltip\r\n if (\r\n tooltip &&\r\n mouseTracker.options.tooltip.shared &&\r\n !(hoverSeries && hoverSeries.noSharedTooltip)\r\n ) {\r\n points = [];\r\n\r\n // loop over all series and find the ones with points closest to the mouse\r\n i = series.length;\r\n for (j = 0; j < i; j++) {\r\n if (\r\n series[j].visible &&\r\n series[j].options.enableMouseTracking !== false &&\r\n !series[j].noSharedTooltip &&\r\n series[j].tooltipPoints &&\r\n series[j].tooltipPoints.length\r\n ) {\r\n point = series[j].tooltipPoints[index];\r\n point._dist = mathAbs(\r\n index - point[series[j].xAxis.tooltipPosName || \"plotX\"]\r\n );\r\n distance = mathMin(distance, point._dist);\r\n points.push(point);\r\n }\r\n }\r\n // remove furthest points\r\n i = points.length;\r\n while (i--) {\r\n if (points[i]._dist > distance) {\r\n points.splice(i, 1);\r\n }\r\n }\r\n // refresh the tooltip if necessary\r\n if (points.length && points[0].plotX !== mouseTracker.hoverX) {\r\n tooltip.refresh(points, e);\r\n mouseTracker.hoverX = points[0].plotX;\r\n }\r\n }\r\n\r\n // separate tooltip and general mouse events\r\n if (hoverSeries && hoverSeries.tracker) {\r\n // only use for line-type series with common tracker\r\n\r\n // get the point\r\n point = hoverSeries.tooltipPoints[index];\r\n\r\n // a new point is hovered, refresh the tooltip\r\n if (point && point !== hoverPoint) {\r\n // trigger the events\r\n point.onMouseOver();\r\n }\r\n }\r\n },\r\n\r\n /**\r\n * Reset the tracking by hiding the tooltip, the hover series state and the hover point\r\n *\r\n * @param allowMove {Boolean} Instead of destroying the tooltip altogether, allow moving it if possible\r\n */\r\n resetTracker: function(allowMove) {\r\n var mouseTracker = this,\r\n chart = mouseTracker.chart,\r\n hoverSeries = chart.hoverSeries,\r\n hoverPoint = chart.hoverPoint,\r\n tooltip = chart.tooltip,\r\n tooltipPoints =\r\n tooltip && tooltip.shared ? chart.hoverPoints : hoverPoint;\r\n\r\n // Narrow in allowMove\r\n allowMove = allowMove && tooltip && tooltipPoints;\r\n\r\n // Check if the points have moved outside the plot area, #1003\r\n if (allowMove && splat(tooltipPoints)[0].plotX === UNDEFINED) {\r\n allowMove = false;\r\n }\r\n\r\n // Just move the tooltip, #349\r\n if (allowMove) {\r\n tooltip.refresh(tooltipPoints);\r\n\r\n // Full reset\r\n }\r\n else {\r\n if (hoverPoint) {\r\n hoverPoint.onMouseOut();\r\n }\r\n\r\n if (hoverSeries) {\r\n hoverSeries.onMouseOut();\r\n }\r\n\r\n if (tooltip) {\r\n tooltip.hide();\r\n tooltip.hideCrosshairs();\r\n }\r\n\r\n mouseTracker.hoverX = null;\r\n }\r\n },\r\n\r\n /**\r\n * Set the JS events on the container element\r\n */\r\n setDOMEvents: function() {\r\n var lastWasOutsidePlot = true,\r\n mouseTracker = this,\r\n chart = mouseTracker.chart,\r\n container = chart.container,\r\n hasDragged,\r\n zoomHor =\r\n (mouseTracker.zoomX && !chart.inverted) ||\r\n (mouseTracker.zoomY && chart.inverted),\r\n zoomVert =\r\n (mouseTracker.zoomY && !chart.inverted) ||\r\n (mouseTracker.zoomX && chart.inverted);\r\n\r\n /**\r\n * Mouse up or outside the plot area\r\n */\r\n function drop() {\r\n if (mouseTracker.selectionMarker) {\r\n var selectionData = {\r\n xAxis: [],\r\n yAxis: []\r\n },\r\n selectionBox = mouseTracker.selectionMarker.getBBox(),\r\n selectionLeft = selectionBox.x - chart.plotLeft,\r\n selectionTop = selectionBox.y - chart.plotTop,\r\n runZoom;\r\n\r\n // a selection has been made\r\n if (hasDragged) {\r\n // record each axis' min and max\r\n each(chart.axes, function(axis) {\r\n if (axis.options.zoomEnabled !== false) {\r\n var isXAxis = axis.isXAxis,\r\n isHorizontal = chart.inverted ? !isXAxis : isXAxis,\r\n selectionMin = axis.translate(\r\n isHorizontal\r\n ? selectionLeft\r\n : chart.plotHeight - selectionTop - selectionBox.height,\r\n true,\r\n 0,\r\n 0,\r\n 1\r\n ),\r\n selectionMax = axis.translate(\r\n (isHorizontal\r\n ? selectionLeft + selectionBox.width\r\n : chart.plotHeight - selectionTop) -\r\n 2 * axis.minPixelPadding, // #875\r\n true,\r\n 0,\r\n 0,\r\n 1\r\n );\r\n\r\n if (!isNaN(selectionMin) && !isNaN(selectionMax)) {\r\n // #859\r\n selectionData[isXAxis ? \"xAxis\" : \"yAxis\"].push({\r\n axis: axis,\r\n min: mathMin(selectionMin, selectionMax), // for reversed axes,\r\n max: mathMax(selectionMin, selectionMax)\r\n });\r\n runZoom = true;\r\n }\r\n }\r\n });\r\n if (runZoom) {\r\n fireEvent(chart, \"selection\", selectionData, function(args) {\r\n chart.zoom(args);\r\n });\r\n }\r\n }\r\n mouseTracker.selectionMarker = mouseTracker.selectionMarker.destroy();\r\n }\r\n\r\n if (chart) {\r\n // it may be destroyed on mouse up - #877\r\n css(container, { cursor: \"auto\" });\r\n chart.cancelClick = hasDragged; // #370\r\n chart.mouseIsDown = hasDragged = false;\r\n }\r\n\r\n removeEvent(doc, \"mouseup\", drop);\r\n if (hasTouch) {\r\n removeEvent(doc, \"touchend\", drop);\r\n }\r\n }\r\n\r\n /**\r\n * Special handler for mouse move that will hide the tooltip when the mouse leaves the plotarea.\r\n */\r\n mouseTracker.hideTooltipOnMouseMove = function(e) {\r\n // Get e.pageX and e.pageY back in MooTools\r\n e = washMouseEvent(e);\r\n\r\n // If we're outside, hide the tooltip\r\n if (\r\n mouseTracker.chartPosition &&\r\n chart.hoverSeries &&\r\n chart.hoverSeries.isCartesian &&\r\n !chart.isInsidePlot(\r\n e.pageX - mouseTracker.chartPosition.left - chart.plotLeft,\r\n e.pageY - mouseTracker.chartPosition.top - chart.plotTop\r\n )\r\n ) {\r\n mouseTracker.resetTracker();\r\n }\r\n };\r\n\r\n /**\r\n * When mouse leaves the container, hide the tooltip.\r\n */\r\n mouseTracker.hideTooltipOnMouseLeave = function() {\r\n mouseTracker.resetTracker();\r\n mouseTracker.chartPosition = null; // also reset the chart position, used in #149 fix\r\n };\r\n\r\n /*\r\n * Record the starting position of a dragoperation\r\n */\r\n container.onmousedown = function(e) {\r\n e = mouseTracker.normalizeMouseEvent(e);\r\n\r\n // issue #295, dragging not always working in Firefox\r\n if (e.type.indexOf(\"touch\") === -1 && e.preventDefault) {\r\n e.preventDefault();\r\n }\r\n\r\n // record the start position\r\n chart.mouseIsDown = true;\r\n chart.cancelClick = false;\r\n chart.mouseDownX = mouseTracker.mouseDownX = e.chartX;\r\n mouseTracker.mouseDownY = e.chartY;\r\n\r\n addEvent(doc, \"mouseup\", drop);\r\n if (hasTouch) {\r\n addEvent(doc, \"touchend\", drop);\r\n }\r\n };\r\n\r\n // The mousemove, touchmove and touchstart event handler\r\n var mouseMove = function(e) {\r\n // let the system handle multitouch operations like two finger scroll\r\n // and pinching\r\n if (e && e.touches && e.touches.length > 1) {\r\n return;\r\n }\r\n\r\n // normalize\r\n e = mouseTracker.normalizeMouseEvent(e);\r\n\r\n var type = e.type,\r\n chartX = e.chartX,\r\n chartY = e.chartY,\r\n isOutsidePlot = !chart.isInsidePlot(\r\n chartX - chart.plotLeft,\r\n chartY - chart.plotTop\r\n );\r\n\r\n if (type.indexOf(\"touch\") === -1) {\r\n // not for touch actions\r\n e.returnValue = false;\r\n }\r\n\r\n // on touch devices, only trigger click if a handler is defined\r\n if (type === \"touchstart\") {\r\n if (attr(e.target, \"isTracker\")) {\r\n if (!chart.runTrackerClick) {\r\n e.preventDefault();\r\n }\r\n }\r\n else if (!chart.runChartClick && !isOutsidePlot) {\r\n e.preventDefault();\r\n }\r\n }\r\n\r\n // cancel on mouse outside\r\n if (isOutsidePlot) {\r\n /*if (!lastWasOutsidePlot) {\r\n\t\t\t\t\t// reset the tracker\r\n\t\t\t\t\tresetTracker();\r\n\t\t\t\t}*/\r\n\r\n // drop the selection if any and reset mouseIsDown and hasDragged\r\n //drop();\r\n if (chartX < chart.plotLeft) {\r\n chartX = chart.plotLeft;\r\n }\r\n else if (chartX > chart.plotLeft + chart.plotWidth) {\r\n chartX = chart.plotLeft + chart.plotWidth;\r\n }\r\n\r\n if (chartY < chart.plotTop) {\r\n chartY = chart.plotTop;\r\n }\r\n else if (chartY > chart.plotTop + chart.plotHeight) {\r\n chartY = chart.plotTop + chart.plotHeight;\r\n }\r\n }\r\n\r\n if (chart.mouseIsDown && type !== \"touchstart\") {\r\n // make selection\r\n\r\n // determine if the mouse has moved more than 10px\r\n hasDragged = Math.sqrt(\r\n Math.pow(mouseTracker.mouseDownX - chartX, 2) +\r\n Math.pow(mouseTracker.mouseDownY - chartY, 2)\r\n );\r\n if (hasDragged > 10) {\r\n var clickedInside = chart.isInsidePlot(\r\n mouseTracker.mouseDownX - chart.plotLeft,\r\n mouseTracker.mouseDownY - chart.plotTop\r\n );\r\n\r\n // make a selection\r\n if (\r\n chart.hasCartesianSeries &&\r\n (mouseTracker.zoomX || mouseTracker.zoomY) &&\r\n clickedInside\r\n ) {\r\n if (!mouseTracker.selectionMarker) {\r\n mouseTracker.selectionMarker = chart.renderer\r\n .rect(\r\n chart.plotLeft,\r\n chart.plotTop,\r\n zoomHor ? 1 : chart.plotWidth,\r\n zoomVert ? 1 : chart.plotHeight,\r\n 0\r\n )\r\n .attr({\r\n fill:\r\n mouseTracker.options.chart.selectionMarkerFill ||\r\n \"rgba(69,114,167,0.25)\",\r\n zIndex: 7\r\n })\r\n .add();\r\n }\r\n }\r\n\r\n // adjust the width of the selection marker\r\n if (mouseTracker.selectionMarker && zoomHor) {\r\n var xSize = chartX - mouseTracker.mouseDownX;\r\n mouseTracker.selectionMarker.attr({\r\n width: mathAbs(xSize),\r\n x: (xSize > 0 ? 0 : xSize) + mouseTracker.mouseDownX\r\n });\r\n }\r\n // adjust the height of the selection marker\r\n if (mouseTracker.selectionMarker && zoomVert) {\r\n var ySize = chartY - mouseTracker.mouseDownY;\r\n mouseTracker.selectionMarker.attr({\r\n height: mathAbs(ySize),\r\n y: (ySize > 0 ? 0 : ySize) + mouseTracker.mouseDownY\r\n });\r\n }\r\n\r\n // panning\r\n if (\r\n clickedInside &&\r\n !mouseTracker.selectionMarker &&\r\n mouseTracker.options.chart.panning\r\n ) {\r\n chart.pan(chartX);\r\n }\r\n }\r\n }\r\n\r\n // Show the tooltip and run mouse over events (#977)\r\n if (!isOutsidePlot) {\r\n mouseTracker.onmousemove(e);\r\n }\r\n\r\n lastWasOutsidePlot = isOutsidePlot;\r\n\r\n // when outside plot, allow touch-drag by returning true\r\n return isOutsidePlot || !chart.hasCartesianSeries;\r\n };\r\n\r\n // When the mouse enters the container, run mouseMove\r\n if (!/Android 4\\.0/.test(userAgent)) {\r\n // This hurts. Best effort for #1385.\r\n container.onmousemove = mouseMove;\r\n }\r\n\r\n /*\r\n * When the mouse leaves the container, hide the tracking (tooltip).\r\n */\r\n addEvent(container, \"mouseleave\", mouseTracker.hideTooltipOnMouseLeave);\r\n\r\n // issue #149 workaround\r\n // The mouseleave event above does not always fire. Whenever the mouse is moving\r\n // outside the plotarea, hide the tooltip\r\n if (!hasTouch) {\r\n // #1385\r\n addEvent(doc, \"mousemove\", mouseTracker.hideTooltipOnMouseMove);\r\n }\r\n\r\n container.ontouchstart = function(e) {\r\n // For touch devices, use touchmove to zoom\r\n if (mouseTracker.zoomX || mouseTracker.zoomY) {\r\n container.onmousedown(e);\r\n }\r\n // Show tooltip and prevent the lower mouse pseudo event\r\n mouseMove(e);\r\n };\r\n\r\n /*\r\n * Allow dragging the finger over the chart to read the values on touch\r\n * devices\r\n */\r\n container.ontouchmove = mouseMove;\r\n\r\n /*\r\n * Allow dragging the finger over the chart to read the values on touch\r\n * devices\r\n */\r\n container.ontouchend = function() {\r\n if (hasDragged) {\r\n mouseTracker.resetTracker();\r\n }\r\n };\r\n\r\n // MooTools 1.2.3 doesn't fire this in IE when using addEvent\r\n container.onclick = function(e) {\r\n var hoverPoint = chart.hoverPoint,\r\n plotX,\r\n plotY;\r\n e = mouseTracker.normalizeMouseEvent(e);\r\n\r\n e.cancelBubble = true; // IE specific\r\n\r\n if (!chart.cancelClick) {\r\n // Detect clicks on trackers or tracker groups, #783\r\n if (\r\n hoverPoint &&\r\n (attr(e.target, \"isTracker\") ||\r\n attr(e.target.parentNode, \"isTracker\"))\r\n ) {\r\n plotX = hoverPoint.plotX;\r\n plotY = hoverPoint.plotY;\r\n\r\n // add page position info\r\n extend(hoverPoint, {\r\n pageX:\r\n mouseTracker.chartPosition.left +\r\n chart.plotLeft +\r\n (chart.inverted ? chart.plotWidth - plotY : plotX),\r\n pageY:\r\n mouseTracker.chartPosition.top +\r\n chart.plotTop +\r\n (chart.inverted ? chart.plotHeight - plotX : plotY)\r\n });\r\n\r\n // the series click event\r\n fireEvent(\r\n hoverPoint.series,\r\n \"click\",\r\n extend(e, {\r\n point: hoverPoint\r\n })\r\n );\r\n\r\n // the point click event\r\n hoverPoint.firePointEvent(\"click\", e);\r\n }\r\n else {\r\n extend(e, mouseTracker.getMouseCoordinates(e));\r\n\r\n // fire a click event in the chart\r\n if (\r\n chart.isInsidePlot(\r\n e.chartX - chart.plotLeft,\r\n e.chartY - chart.plotTop\r\n )\r\n ) {\r\n fireEvent(chart, \"click\", e);\r\n }\r\n }\r\n }\r\n };\r\n },\r\n\r\n /**\r\n * Destroys the MouseTracker object and disconnects DOM events.\r\n */\r\n destroy: function() {\r\n var mouseTracker = this,\r\n chart = mouseTracker.chart,\r\n container = chart.container;\r\n\r\n // Destroy the tracker group element\r\n if (chart.trackerGroup) {\r\n chart.trackerGroup = chart.trackerGroup.destroy();\r\n }\r\n\r\n removeEvent(\r\n container,\r\n \"mouseleave\",\r\n mouseTracker.hideTooltipOnMouseLeave\r\n );\r\n removeEvent(doc, \"mousemove\", mouseTracker.hideTooltipOnMouseMove);\r\n container.onclick = container.onmousedown = container.onmousemove = container.ontouchstart = container.ontouchend = container.ontouchmove = null;\r\n\r\n // memory and CPU leak\r\n clearInterval(this.tooltipTimeout);\r\n },\r\n\r\n // Run MouseTracker\r\n init: function(chart, options) {\r\n if (!chart.trackerGroup) {\r\n chart.trackerGroup = chart.renderer\r\n .g(\"tracker\")\r\n .attr({ zIndex: 9 })\r\n .add();\r\n }\r\n\r\n if (options.enabled) {\r\n chart.tooltip = new Tooltip(chart, options);\r\n }\r\n\r\n this.setDOMEvents();\r\n }\r\n };\r\n /**\r\n * The overview of the chart's series\r\n */\r\n function Legend(chart) {\r\n this.init(chart);\r\n }\r\n\r\n Legend.prototype = {\r\n /**\r\n * Initialize the legend\r\n */\r\n init: function(chart) {\r\n var legend = this,\r\n options = (legend.options = chart.options.legend);\r\n\r\n if (!options.enabled) {\r\n return;\r\n }\r\n\r\n var //style = options.style || {}, // deprecated\r\n itemStyle = options.itemStyle,\r\n padding = pick(options.padding, 8),\r\n itemMarginTop = options.itemMarginTop || 0;\r\n\r\n legend.baseline = pInt(itemStyle.fontSize) + 3 + itemMarginTop; // used in Series prototype\r\n legend.itemStyle = itemStyle;\r\n legend.itemHiddenStyle = merge(itemStyle, options.itemHiddenStyle);\r\n legend.itemMarginTop = itemMarginTop;\r\n legend.padding = padding;\r\n legend.initialItemX = padding;\r\n legend.initialItemY = padding - 5; // 5 is the number of pixels above the text\r\n legend.maxItemWidth = 0;\r\n legend.chart = chart;\r\n //legend.allItems = UNDEFINED;\r\n //legend.legendWidth = UNDEFINED;\r\n //legend.legendHeight = UNDEFINED;\r\n //legend.offsetWidth = UNDEFINED;\r\n legend.itemHeight = 0;\r\n legend.lastLineHeight = 0;\r\n //legend.itemX = UNDEFINED;\r\n //legend.itemY = UNDEFINED;\r\n //legend.lastItemY = UNDEFINED;\r\n\r\n // Elements\r\n //legend.group = UNDEFINED;\r\n //legend.box = UNDEFINED;\r\n\r\n // run legend\r\n legend.render();\r\n\r\n // move checkboxes\r\n addEvent(legend.chart, \"endResize\", function() {\r\n legend.positionCheckboxes();\r\n });\r\n\r\n /*\t\t// expose\r\n\t\treturn {\r\n\t\t\tcolorizeItem: colorizeItem,\r\n\t\t\tdestroyItem: destroyItem,\r\n\t\t\trender: render,\r\n\t\t\tdestroy: destroy,\r\n\t\t\tgetLegendWidth: getLegendWidth,\r\n\t\t\tgetLegendHeight: getLegendHeight\r\n\t\t};*/\r\n },\r\n\r\n /**\r\n * Set the colors for the legend item\r\n * @param {Object} item A Series or Point instance\r\n * @param {Object} visible Dimmed or colored\r\n */\r\n colorizeItem: function(item, visible) {\r\n var legend = this,\r\n options = legend.options,\r\n legendItem = item.legendItem,\r\n legendLine = item.legendLine,\r\n legendSymbol = item.legendSymbol,\r\n hiddenColor = legend.itemHiddenStyle.color,\r\n textColor = visible ? options.itemStyle.color : hiddenColor,\r\n symbolColor = visible ? item.color : hiddenColor,\r\n markerOptions = item.options && item.options.marker,\r\n symbolAttr = {\r\n stroke: symbolColor,\r\n fill: symbolColor\r\n },\r\n key,\r\n val;\r\n\r\n if (legendItem) {\r\n legendItem.css({ fill: textColor });\r\n }\r\n if (legendLine) {\r\n legendLine.attr({ stroke: symbolColor });\r\n }\r\n\r\n if (legendSymbol) {\r\n // Apply marker options\r\n if (markerOptions) {\r\n markerOptions = item.convertAttribs(markerOptions);\r\n for (key in markerOptions) {\r\n val = markerOptions[key];\r\n if (val !== UNDEFINED) {\r\n symbolAttr[key] = val;\r\n }\r\n }\r\n }\r\n\r\n legendSymbol.attr(symbolAttr);\r\n }\r\n },\r\n\r\n /**\r\n * Position the legend item\r\n * @param {Object} item A Series or Point instance\r\n */\r\n positionItem: function(item) {\r\n var legend = this,\r\n options = legend.options,\r\n symbolPadding = options.symbolPadding,\r\n ltr = !options.rtl,\r\n legendItemPos = item._legendItemPos,\r\n itemX = legendItemPos[0],\r\n itemY = legendItemPos[1],\r\n checkbox = item.checkbox;\r\n\r\n if (item.legendGroup) {\r\n item.legendGroup.translate(\r\n ltr ? itemX : legend.legendWidth - itemX - 2 * symbolPadding - 4,\r\n itemY\r\n );\r\n }\r\n\r\n if (checkbox) {\r\n checkbox.x = itemX;\r\n checkbox.y = itemY;\r\n }\r\n },\r\n\r\n /**\r\n * Destroy a single legend item\r\n * @param {Object} item The series or point\r\n */\r\n destroyItem: function(item) {\r\n var checkbox = item.checkbox;\r\n\r\n // destroy SVG elements\r\n each(\r\n [\"legendItem\", \"legendLine\", \"legendSymbol\", \"legendGroup\"],\r\n function(key) {\r\n if (item[key]) {\r\n item[key].destroy();\r\n }\r\n }\r\n );\r\n\r\n if (checkbox) {\r\n discardElement(item.checkbox);\r\n }\r\n },\r\n\r\n /**\r\n * Destroys the legend.\r\n */\r\n destroy: function() {\r\n var legend = this,\r\n legendGroup = legend.group,\r\n box = legend.box;\r\n\r\n if (box) {\r\n legend.box = box.destroy();\r\n }\r\n\r\n if (legendGroup) {\r\n legend.group = legendGroup.destroy();\r\n }\r\n },\r\n\r\n /**\r\n * Position the checkboxes after the width is determined\r\n */\r\n positionCheckboxes: function(scrollOffset) {\r\n var alignAttr = this.group.alignAttr,\r\n translateY,\r\n clipHeight = this.clipHeight || this.legendHeight;\r\n\r\n if (alignAttr) {\r\n translateY = alignAttr.translateY;\r\n each(this.allItems, function(item) {\r\n var checkbox = item.checkbox,\r\n top;\r\n\r\n if (checkbox) {\r\n top = translateY + checkbox.y + (scrollOffset || 0) + 3;\r\n css(checkbox, {\r\n left:\r\n alignAttr.translateX +\r\n item.legendItemWidth +\r\n checkbox.x -\r\n 20 +\r\n PX,\r\n top: top + PX,\r\n display:\r\n top > translateY - 6 && top < translateY + clipHeight - 6\r\n ? \"\"\r\n : NONE\r\n });\r\n }\r\n });\r\n }\r\n },\r\n\r\n /**\r\n * Render a single specific legend item\r\n * @param {Object} item A series or point\r\n */\r\n renderItem: function(item) {\r\n var legend = this,\r\n chart = legend.chart,\r\n renderer = chart.renderer,\r\n options = legend.options,\r\n horizontal = options.layout === \"horizontal\",\r\n symbolWidth = options.symbolWidth,\r\n symbolPadding = options.symbolPadding,\r\n itemStyle = legend.itemStyle,\r\n itemHiddenStyle = legend.itemHiddenStyle,\r\n padding = legend.padding,\r\n ltr = !options.rtl,\r\n itemHeight,\r\n widthOption = options.width,\r\n itemMarginBottom = options.itemMarginBottom || 0,\r\n itemMarginTop = legend.itemMarginTop,\r\n initialItemX = legend.initialItemX,\r\n bBox,\r\n itemWidth,\r\n li = item.legendItem,\r\n series = item.series || item,\r\n itemOptions = series.options,\r\n showCheckbox = itemOptions.showCheckbox,\r\n useHTML = options.useHTML;\r\n\r\n if (!li) {\r\n // generate it once, later move it\r\n\r\n // Generate the group box\r\n // A group to hold the symbol and text. Text is to be appended in Legend class.\r\n item.legendGroup = renderer\r\n .g(\"legend-item\")\r\n .attr({ zIndex: 1 })\r\n .add(legend.scrollGroup);\r\n\r\n // Draw the legend symbol inside the group box\r\n series.drawLegendSymbol(legend, item);\r\n\r\n // Generate the list item text and add it to the group\r\n item.legendItem = li = renderer\r\n .text(\r\n options.labelFormatter.call(item),\r\n ltr ? symbolWidth + symbolPadding : -symbolPadding,\r\n legend.baseline,\r\n useHTML\r\n )\r\n .css(merge(item.visible ? itemStyle : itemHiddenStyle)) // merge to prevent modifying original (#1021)\r\n .attr({\r\n align: ltr ? \"left\" : \"right\",\r\n zIndex: 2\r\n })\r\n .add(item.legendGroup);\r\n\r\n // Set the events on the item group, or in case of useHTML, the item itself (#1249)\r\n (useHTML ? li : item.legendGroup)\r\n .on(\"mouseover\", function() {\r\n item.setState(HOVER_STATE);\r\n li.css(legend.options.itemHoverStyle);\r\n })\r\n .on(\"mouseout\", function() {\r\n li.css(item.visible ? itemStyle : itemHiddenStyle);\r\n item.setState();\r\n })\r\n .on(\"click\", function(event) {\r\n var strLegendItemClick = \"legendItemClick\",\r\n fnLegendItemClick = function() {\r\n item.setVisible();\r\n };\r\n\r\n // Pass over the click/touch event. #4.\r\n event = {\r\n browserEvent: event\r\n };\r\n\r\n // click the name or symbol\r\n if (item.firePointEvent) {\r\n // point\r\n item.firePointEvent(strLegendItemClick, event, fnLegendItemClick);\r\n }\r\n else {\r\n fireEvent(item, strLegendItemClick, event, fnLegendItemClick);\r\n }\r\n });\r\n\r\n // Colorize the items\r\n legend.colorizeItem(item, item.visible);\r\n\r\n // add the HTML checkbox on top\r\n if (itemOptions && showCheckbox) {\r\n item.checkbox = createElement(\r\n \"input\",\r\n {\r\n type: \"checkbox\",\r\n checked: item.selected,\r\n defaultChecked: item.selected // required by IE7\r\n },\r\n options.itemCheckboxStyle,\r\n chart.container\r\n );\r\n\r\n addEvent(item.checkbox, \"click\", function(event) {\r\n var target = event.target;\r\n fireEvent(\r\n item,\r\n \"checkboxClick\",\r\n {\r\n checked: target.checked\r\n },\r\n function() {\r\n item.select();\r\n }\r\n );\r\n });\r\n }\r\n }\r\n\r\n // calculate the positions for the next line\r\n bBox = li.getBBox();\r\n\r\n itemWidth = item.legendItemWidth =\r\n options.itemWidth ||\r\n symbolWidth +\r\n symbolPadding +\r\n bBox.width +\r\n padding +\r\n (showCheckbox ? 20 : 0);\r\n legend.itemHeight = itemHeight = bBox.height;\r\n\r\n // if the item exceeds the width, start a new line\r\n if (\r\n horizontal &&\r\n legend.itemX - initialItemX + itemWidth >\r\n (widthOption || chart.chartWidth - 2 * padding - initialItemX)\r\n ) {\r\n legend.itemX = initialItemX;\r\n legend.itemY +=\r\n itemMarginTop + legend.lastLineHeight + itemMarginBottom;\r\n legend.lastLineHeight = 0; // reset for next line\r\n }\r\n\r\n // If the item exceeds the height, start a new column\r\n /*if (!horizontal && legend.itemY + options.y + itemHeight > chart.chartHeight - spacingTop - spacingBottom) {\r\n\t\t\tlegend.itemY = legend.initialItemY;\r\n\t\t\tlegend.itemX += legend.maxItemWidth;\r\n\t\t\tlegend.maxItemWidth = 0;\r\n\t\t}*/\r\n\r\n // Set the edge positions\r\n legend.maxItemWidth = mathMax(legend.maxItemWidth, itemWidth);\r\n legend.lastItemY = itemMarginTop + legend.itemY + itemMarginBottom;\r\n legend.lastLineHeight = mathMax(itemHeight, legend.lastLineHeight); // #915\r\n\r\n // cache the position of the newly generated or reordered items\r\n item._legendItemPos = [legend.itemX, legend.itemY];\r\n\r\n // advance\r\n if (horizontal) {\r\n legend.itemX += itemWidth;\r\n }\r\n else {\r\n legend.itemY += itemMarginTop + itemHeight + itemMarginBottom;\r\n legend.lastLineHeight = itemHeight;\r\n }\r\n\r\n // the width of the widest item\r\n legend.offsetWidth =\r\n widthOption ||\r\n mathMax(\r\n horizontal ? legend.itemX - initialItemX : itemWidth,\r\n legend.offsetWidth\r\n );\r\n },\r\n\r\n /**\r\n * Render the legend. This method can be called both before and after\r\n * chart.render. If called after, it will only rearrange items instead\r\n * of creating new ones.\r\n */\r\n render: function() {\r\n var legend = this,\r\n chart = legend.chart,\r\n renderer = chart.renderer,\r\n legendGroup = legend.group,\r\n allItems,\r\n display,\r\n legendWidth,\r\n legendHeight,\r\n box = legend.box,\r\n options = legend.options,\r\n padding = legend.padding,\r\n legendBorderWidth = options.borderWidth,\r\n legendBackgroundColor = options.backgroundColor;\r\n\r\n legend.itemX = legend.initialItemX;\r\n legend.itemY = legend.initialItemY;\r\n legend.offsetWidth = 0;\r\n legend.lastItemY = 0;\r\n\r\n if (!legendGroup) {\r\n legend.group = legendGroup = renderer\r\n .g(\"legend\")\r\n // #414, #759. Trackers will be drawn above the legend, but we have\r\n // to sacrifice that because tooltips need to be above the legend\r\n // and trackers above tooltips\r\n .attr({ zIndex: 7 })\r\n .add();\r\n legend.contentGroup = renderer\r\n .g()\r\n .attr({ zIndex: 1 }) // above background\r\n .add(legendGroup);\r\n legend.scrollGroup = renderer.g().add(legend.contentGroup);\r\n legend.clipRect = renderer.clipRect(0, 0, 9999, chart.chartHeight);\r\n legend.contentGroup.clip(legend.clipRect);\r\n }\r\n\r\n // add each series or point\r\n allItems = [];\r\n each(chart.series, function(serie) {\r\n var seriesOptions = serie.options;\r\n\r\n if (!seriesOptions.showInLegend) {\r\n return;\r\n }\r\n\r\n // use points or series for the legend item depending on legendType\r\n allItems = allItems.concat(\r\n serie.legendItems ||\r\n (seriesOptions.legendType === \"point\" ? serie.data : serie)\r\n );\r\n });\r\n\r\n // sort by legendIndex\r\n stableSort(allItems, function(a, b) {\r\n return (\r\n ((a.options && a.options.legendIndex) || 0) -\r\n ((b.options && b.options.legendIndex) || 0)\r\n );\r\n });\r\n\r\n // reversed legend\r\n if (options.reversed) {\r\n allItems.reverse();\r\n }\r\n\r\n legend.allItems = allItems;\r\n legend.display = display = !!allItems.length;\r\n\r\n // render the items\r\n each(allItems, function(item) {\r\n legend.renderItem(item);\r\n });\r\n\r\n // Draw the border\r\n legendWidth = options.width || legend.offsetWidth;\r\n legendHeight = legend.lastItemY + legend.lastLineHeight;\r\n\r\n legendHeight = legend.handleOverflow(legendHeight);\r\n\r\n if (legendBorderWidth || legendBackgroundColor) {\r\n legendWidth += padding;\r\n legendHeight += padding;\r\n\r\n if (!box) {\r\n legend.box = box = renderer\r\n .rect(\r\n 0,\r\n 0,\r\n legendWidth,\r\n legendHeight,\r\n options.borderRadius,\r\n legendBorderWidth || 0\r\n )\r\n .attr({\r\n stroke: options.borderColor,\r\n \"stroke-width\": legendBorderWidth || 0,\r\n fill: legendBackgroundColor || NONE\r\n })\r\n .add(legendGroup)\r\n .shadow(options.shadow);\r\n box.isNew = true;\r\n }\r\n else if (legendWidth > 0 && legendHeight > 0) {\r\n box[box.isNew ? \"attr\" : \"animate\"](\r\n box.crisp(null, null, null, legendWidth, legendHeight)\r\n );\r\n box.isNew = false;\r\n }\r\n\r\n // hide the border if no items\r\n box[display ? \"show\" : \"hide\"]();\r\n }\r\n\r\n legend.legendWidth = legendWidth;\r\n legend.legendHeight = legendHeight;\r\n\r\n // Now that the legend width and height are established, put the items in the\r\n // final position\r\n each(allItems, function(item) {\r\n legend.positionItem(item);\r\n });\r\n\r\n // 1.x compatibility: positioning based on style\r\n /*var props = ['left', 'right', 'top', 'bottom'],\r\n\t\t\tprop,\r\n\t\t\ti = 4;\r\n\t\twhile (i--) {\r\n\t\t\tprop = props[i];\r\n\t\t\tif (options.style[prop] && options.style[prop] !== 'auto') {\r\n\t\t\t\toptions[i < 2 ? 'align' : 'verticalAlign'] = prop;\r\n\t\t\t\toptions[i < 2 ? 'x' : 'y'] = pInt(options.style[prop]) * (i % 2 ? -1 : 1);\r\n\t\t\t}\r\n\t\t}*/\r\n\r\n if (display) {\r\n legendGroup.align(\r\n extend(\r\n {\r\n width: legendWidth,\r\n height: legendHeight\r\n },\r\n options\r\n ),\r\n true,\r\n chart.spacingBox\r\n );\r\n }\r\n\r\n if (!chart.isResizing) {\r\n this.positionCheckboxes();\r\n }\r\n },\r\n\r\n /**\r\n * Set up the overflow handling by adding navigation with up and down arrows below the\r\n * legend.\r\n */\r\n handleOverflow: function(legendHeight) {\r\n var legend = this,\r\n chart = this.chart,\r\n renderer = chart.renderer,\r\n pageCount,\r\n options = this.options,\r\n optionsY = options.y,\r\n alignTop = options.verticalAlign === \"top\",\r\n spaceHeight =\r\n chart.spacingBox.height +\r\n (alignTop ? -optionsY : optionsY) -\r\n this.padding,\r\n maxHeight = options.maxHeight,\r\n clipHeight,\r\n clipRect = this.clipRect,\r\n navOptions = options.navigation,\r\n animation = pick(navOptions.animation, true),\r\n arrowSize = navOptions.arrowSize || 12,\r\n nav = this.nav;\r\n\r\n // Adjust the height\r\n if (options.layout === \"horizontal\") {\r\n spaceHeight /= 2;\r\n }\r\n if (maxHeight) {\r\n spaceHeight = mathMin(spaceHeight, maxHeight);\r\n }\r\n\r\n // Reset the legend height and adjust the clipping rectangle\r\n if (legendHeight > spaceHeight) {\r\n this.clipHeight = clipHeight = spaceHeight - 20;\r\n this.pageCount = pageCount = mathCeil(legendHeight / clipHeight);\r\n this.currentPage = pick(this.currentPage, 1);\r\n this.fullHeight = legendHeight;\r\n\r\n clipRect.attr({\r\n height: clipHeight\r\n });\r\n\r\n // Add navigation elements\r\n if (!nav) {\r\n this.nav = nav = renderer\r\n .g()\r\n .attr({ zIndex: 1 })\r\n .add(this.group);\r\n this.up = renderer\r\n .symbol(\"triangle\", 0, 0, arrowSize, arrowSize)\r\n .on(\"click\", function() {\r\n legend.scroll(-1, animation);\r\n })\r\n .add(nav);\r\n this.pager = renderer\r\n .text(\"\", 15, 10)\r\n .css(navOptions.style)\r\n .add(nav);\r\n this.down = renderer\r\n .symbol(\"triangle-down\", 0, 0, arrowSize, arrowSize)\r\n .on(\"click\", function() {\r\n legend.scroll(1, animation);\r\n })\r\n .add(nav);\r\n }\r\n\r\n // Set initial position\r\n legend.scroll(0);\r\n\r\n legendHeight = spaceHeight;\r\n }\r\n else if (nav) {\r\n clipRect.attr({\r\n height: chart.chartHeight\r\n });\r\n nav.hide();\r\n this.scrollGroup.attr({\r\n translateY: 1\r\n });\r\n this.clipHeight = 0; // #1379\r\n }\r\n\r\n return legendHeight;\r\n },\r\n\r\n /**\r\n * Scroll the legend by a number of pages\r\n * @param {Object} scrollBy\r\n * @param {Object} animation\r\n */\r\n scroll: function(scrollBy, animation) {\r\n var pageCount = this.pageCount,\r\n currentPage = this.currentPage + scrollBy,\r\n clipHeight = this.clipHeight,\r\n navOptions = this.options.navigation,\r\n activeColor = navOptions.activeColor,\r\n inactiveColor = navOptions.inactiveColor,\r\n pager = this.pager,\r\n padding = this.padding,\r\n scrollOffset;\r\n\r\n // When resizing while looking at the last page\r\n if (currentPage > pageCount) {\r\n currentPage = pageCount;\r\n }\r\n\r\n if (currentPage > 0) {\r\n if (animation !== UNDEFINED) {\r\n setAnimation(animation, this.chart);\r\n }\r\n\r\n this.nav.attr({\r\n translateX: padding,\r\n translateY: clipHeight + 7,\r\n visibility: VISIBLE\r\n });\r\n this.up\r\n .attr({\r\n fill: currentPage === 1 ? inactiveColor : activeColor\r\n })\r\n .css({\r\n cursor: currentPage === 1 ? \"default\" : \"pointer\"\r\n });\r\n pager.attr({\r\n text: currentPage + \"/\" + this.pageCount\r\n });\r\n this.down\r\n .attr({\r\n x: 18 + this.pager.getBBox().width, // adjust to text width\r\n fill: currentPage === pageCount ? inactiveColor : activeColor\r\n })\r\n .css({\r\n cursor: currentPage === pageCount ? \"default\" : \"pointer\"\r\n });\r\n\r\n scrollOffset =\r\n -mathMin(\r\n clipHeight * (currentPage - 1),\r\n this.fullHeight - clipHeight + padding\r\n ) + 1;\r\n this.scrollGroup.animate({\r\n translateY: scrollOffset\r\n });\r\n pager.attr({\r\n text: currentPage + \"/\" + pageCount\r\n });\r\n\r\n this.currentPage = currentPage;\r\n this.positionCheckboxes(scrollOffset);\r\n }\r\n }\r\n };\r\n\r\n /**\r\n * The chart class\r\n * @param {Object} options\r\n * @param {Function} callback Function to run when the chart has loaded\r\n */\r\n function Chart() {\r\n this.init.apply(this, arguments);\r\n }\r\n\r\n Chart.prototype = {\r\n /**\r\n * Initialize the chart\r\n */\r\n init: function(userOptions, callback) {\r\n // Handle regular options\r\n var options,\r\n seriesOptions = userOptions.series; // skip merging data points to increase performance\r\n\r\n userOptions.series = null;\r\n options = merge(defaultOptions, userOptions); // do the merge\r\n options.series = userOptions.series = seriesOptions; // set back the series data\r\n\r\n var optionsChart = options.chart,\r\n optionsMargin = optionsChart.margin,\r\n margin = isObject(optionsMargin)\r\n ? optionsMargin\r\n : [optionsMargin, optionsMargin, optionsMargin, optionsMargin];\r\n\r\n this.optionsMarginTop = pick(optionsChart.marginTop, margin[0]);\r\n this.optionsMarginRight = pick(optionsChart.marginRight, margin[1]);\r\n this.optionsMarginBottom = pick(optionsChart.marginBottom, margin[2]);\r\n this.optionsMarginLeft = pick(optionsChart.marginLeft, margin[3]);\r\n\r\n var chartEvents = optionsChart.events;\r\n\r\n this.runChartClick = chartEvents && !!chartEvents.click;\r\n this.callback = callback;\r\n this.isResizing = 0;\r\n this.options = options;\r\n //chartTitleOptions = UNDEFINED;\r\n //chartSubtitleOptions = UNDEFINED;\r\n\r\n this.axes = [];\r\n this.series = [];\r\n this.hasCartesianSeries = optionsChart.showAxes;\r\n //this.axisOffset = UNDEFINED;\r\n //this.maxTicks = UNDEFINED; // handle the greatest amount of ticks on grouped axes\r\n //this.inverted = UNDEFINED;\r\n //this.loadingShown = UNDEFINED;\r\n //this.container = UNDEFINED;\r\n //this.chartWidth = UNDEFINED;\r\n //this.chartHeight = UNDEFINED;\r\n //this.marginRight = UNDEFINED;\r\n //this.marginBottom = UNDEFINED;\r\n //this.containerWidth = UNDEFINED;\r\n //this.containerHeight = UNDEFINED;\r\n //this.oldChartWidth = UNDEFINED;\r\n //this.oldChartHeight = UNDEFINED;\r\n\r\n //this.renderTo = UNDEFINED;\r\n //this.renderToClone = UNDEFINED;\r\n //this.tracker = UNDEFINED;\r\n\r\n //this.spacingBox = UNDEFINED\r\n\r\n //this.legend = UNDEFINED;\r\n\r\n // Elements\r\n //this.chartBackground = UNDEFINED;\r\n //this.plotBackground = UNDEFINED;\r\n //this.plotBGImage = UNDEFINED;\r\n //this.plotBorder = UNDEFINED;\r\n //this.loadingDiv = UNDEFINED;\r\n //this.loadingSpan = UNDEFINED;\r\n\r\n var chart = this,\r\n eventType;\r\n\r\n // Add the chart to the global lookup\r\n chart.index = charts.length;\r\n charts.push(chart);\r\n\r\n // Set up auto resize\r\n if (optionsChart.reflow !== false) {\r\n addEvent(chart, \"load\", chart.initReflow);\r\n }\r\n\r\n // Chart event handlers\r\n if (chartEvents) {\r\n for (eventType in chartEvents) {\r\n addEvent(chart, eventType, chartEvents[eventType]);\r\n }\r\n }\r\n\r\n chart.xAxis = [];\r\n chart.yAxis = [];\r\n\r\n // Expose methods and variables\r\n chart.animation = useCanVG ? false : pick(optionsChart.animation, true);\r\n chart.pointCount = 0;\r\n chart.counters = new ChartCounters();\r\n\r\n chart.firstRender();\r\n },\r\n\r\n /**\r\n * Initialize an individual series, called internally before render time\r\n */\r\n initSeries: function(options) {\r\n var chart = this,\r\n optionsChart = chart.options.chart,\r\n type =\r\n options.type || optionsChart.type || optionsChart.defaultSeriesType,\r\n series = new seriesTypes[type]();\r\n\r\n series.init(this, options);\r\n return series;\r\n },\r\n\r\n /**\r\n * Add a series dynamically after time\r\n *\r\n * @param {Object} options The config options\r\n * @param {Boolean} redraw Whether to redraw the chart after adding. Defaults to true.\r\n * @param {Boolean|Object} animation Whether to apply animation, and optionally animation\r\n * configuration\r\n *\r\n * @return {Object} series The newly created series object\r\n */\r\n addSeries: function(options, redraw, animation) {\r\n var series,\r\n chart = this;\r\n\r\n if (options) {\r\n setAnimation(animation, chart);\r\n redraw = pick(redraw, true); // defaults to true\r\n\r\n fireEvent(chart, \"addSeries\", { options: options }, function() {\r\n series = chart.initSeries(options);\r\n\r\n chart.isDirtyLegend = true; // the series array is out of sync with the display\r\n if (redraw) {\r\n chart.redraw();\r\n }\r\n });\r\n }\r\n\r\n return series;\r\n },\r\n\r\n /**\r\n * Check whether a given point is within the plot area\r\n *\r\n * @param {Number} plotX Pixel x relative to the plot area\r\n * @param {Number} plotY Pixel y relative to the plot area\r\n * @param {Boolean} inverted Whether the chart is inverted\r\n */\r\n isInsidePlot: function(plotX, plotY, inverted) {\r\n var x = inverted ? plotY : plotX,\r\n y = inverted ? plotX : plotY;\r\n\r\n return x >= 0 && x <= this.plotWidth && y >= 0 && y <= this.plotHeight;\r\n },\r\n\r\n /**\r\n * Adjust all axes tick amounts\r\n */\r\n adjustTickAmounts: function() {\r\n if (this.options.chart.alignTicks !== false) {\r\n each(this.axes, function(axis) {\r\n axis.adjustTickAmount();\r\n });\r\n }\r\n this.maxTicks = null;\r\n },\r\n\r\n /**\r\n * Redraw legend, axes or series based on updated data\r\n *\r\n * @param {Boolean|Object} animation Whether to apply animation, and optionally animation\r\n * configuration\r\n */\r\n redraw: function(animation) {\r\n var chart = this,\r\n axes = chart.axes,\r\n series = chart.series,\r\n tracker = chart.tracker,\r\n legend = chart.legend,\r\n redrawLegend = chart.isDirtyLegend,\r\n hasStackedSeries,\r\n isDirtyBox = chart.isDirtyBox, // todo: check if it has actually changed?\r\n seriesLength = series.length,\r\n i = seriesLength,\r\n serie,\r\n renderer = chart.renderer,\r\n isHiddenChart = renderer.isHidden(),\r\n afterRedraw = [];\r\n\r\n setAnimation(animation, chart);\r\n\r\n if (isHiddenChart) {\r\n chart.cloneRenderTo();\r\n }\r\n\r\n // link stacked series\r\n while (i--) {\r\n serie = series[i];\r\n if (serie.isDirty && serie.options.stacking) {\r\n hasStackedSeries = true;\r\n break;\r\n }\r\n }\r\n if (hasStackedSeries) {\r\n // mark others as dirty\r\n i = seriesLength;\r\n while (i--) {\r\n serie = series[i];\r\n if (serie.options.stacking) {\r\n serie.isDirty = true;\r\n }\r\n }\r\n }\r\n\r\n // handle updated data in the series\r\n each(series, function(serie) {\r\n if (serie.isDirty) {\r\n // prepare the data so axis can read it\r\n if (serie.options.legendType === \"point\") {\r\n redrawLegend = true;\r\n }\r\n }\r\n });\r\n\r\n // handle added or removed series\r\n if (redrawLegend && legend.options.enabled) {\r\n // series or pie points are added or removed\r\n // draw legend graphics\r\n legend.render();\r\n\r\n chart.isDirtyLegend = false;\r\n }\r\n\r\n if (chart.hasCartesianSeries) {\r\n if (!chart.isResizing) {\r\n // reset maxTicks\r\n chart.maxTicks = null;\r\n\r\n // set axes scales\r\n each(axes, function(axis) {\r\n axis.setScale();\r\n });\r\n }\r\n chart.adjustTickAmounts();\r\n chart.getMargins();\r\n\r\n // redraw axes\r\n each(axes, function(axis) {\r\n // Fire 'afterSetExtremes' only if extremes are set\r\n if (axis.isDirtyExtremes) {\r\n // #821\r\n axis.isDirtyExtremes = false;\r\n afterRedraw.push(function() {\r\n // prevent a recursive call to chart.redraw() (#1119)\r\n fireEvent(axis, \"afterSetExtremes\", axis.getExtremes()); // #747, #751\r\n });\r\n }\r\n\r\n if (axis.isDirty || isDirtyBox || hasStackedSeries) {\r\n axis.redraw();\r\n isDirtyBox = true; // #792\r\n }\r\n });\r\n }\r\n // the plot areas size has changed\r\n if (isDirtyBox) {\r\n chart.drawChartBox();\r\n }\r\n\r\n // redraw affected series\r\n each(series, function(serie) {\r\n if (\r\n serie.isDirty &&\r\n serie.visible &&\r\n (!serie.isCartesian || serie.xAxis)\r\n ) {\r\n // issue #153\r\n serie.redraw();\r\n }\r\n });\r\n\r\n // move tooltip or reset\r\n if (tracker && tracker.resetTracker) {\r\n tracker.resetTracker(true);\r\n }\r\n\r\n // redraw if canvas\r\n renderer.draw();\r\n\r\n // fire the event\r\n fireEvent(chart, \"redraw\"); // jQuery breaks this when calling it from addEvent. Overwrites chart.redraw\r\n\r\n if (isHiddenChart) {\r\n chart.cloneRenderTo(true);\r\n }\r\n\r\n // Fire callbacks that are put on hold until after the redraw\r\n each(afterRedraw, function(callback) {\r\n callback.call();\r\n });\r\n },\r\n\r\n /**\r\n * Dim the chart and show a loading text or symbol\r\n * @param {String} str An optional text to show in the loading label instead of the default one\r\n */\r\n showLoading: function(str) {\r\n var chart = this,\r\n options = chart.options,\r\n loadingDiv = chart.loadingDiv;\r\n\r\n var loadingOptions = options.loading;\r\n\r\n // create the layer at the first call\r\n if (!loadingDiv) {\r\n chart.loadingDiv = loadingDiv = createElement(\r\n DIV,\r\n {\r\n className: PREFIX + \"loading\"\r\n },\r\n extend(loadingOptions.style, {\r\n left: chart.plotLeft + PX,\r\n top: chart.plotTop + PX,\r\n width: chart.plotWidth + PX,\r\n height: chart.plotHeight + PX,\r\n zIndex: 10,\r\n display: NONE\r\n }),\r\n chart.container\r\n );\r\n\r\n chart.loadingSpan = createElement(\r\n \"span\",\r\n null,\r\n loadingOptions.labelStyle,\r\n loadingDiv\r\n );\r\n }\r\n\r\n // update text\r\n chart.loadingSpan.innerHTML = str || options.lang.loading;\r\n\r\n // show it\r\n if (!chart.loadingShown) {\r\n css(loadingDiv, { opacity: 0, display: \"\" });\r\n animate(\r\n loadingDiv,\r\n {\r\n opacity: loadingOptions.style.opacity\r\n },\r\n {\r\n duration: loadingOptions.showDuration || 0\r\n }\r\n );\r\n chart.loadingShown = true;\r\n }\r\n },\r\n\r\n /**\r\n * Hide the loading layer\r\n */\r\n hideLoading: function() {\r\n var options = this.options,\r\n loadingDiv = this.loadingDiv;\r\n\r\n if (loadingDiv) {\r\n animate(\r\n loadingDiv,\r\n {\r\n opacity: 0\r\n },\r\n {\r\n duration: options.loading.hideDuration || 100,\r\n complete: function() {\r\n css(loadingDiv, { display: NONE });\r\n }\r\n }\r\n );\r\n }\r\n this.loadingShown = false;\r\n },\r\n\r\n /**\r\n * Get an axis, series or point object by id.\r\n * @param id {String} The id as given in the configuration options\r\n */\r\n get: function(id) {\r\n var chart = this,\r\n axes = chart.axes,\r\n series = chart.series;\r\n\r\n var i, j, points;\r\n\r\n // search axes\r\n for (i = 0; i < axes.length; i++) {\r\n if (axes[i].options.id === id) {\r\n return axes[i];\r\n }\r\n }\r\n\r\n // search series\r\n for (i = 0; i < series.length; i++) {\r\n if (series[i].options.id === id) {\r\n return series[i];\r\n }\r\n }\r\n\r\n // search points\r\n for (i = 0; i < series.length; i++) {\r\n points = series[i].points || [];\r\n for (j = 0; j < points.length; j++) {\r\n if (points[j].id === id) {\r\n return points[j];\r\n }\r\n }\r\n }\r\n return null;\r\n },\r\n\r\n /**\r\n * Create the Axis instances based on the config options\r\n */\r\n getAxes: function() {\r\n var chart = this,\r\n options = this.options;\r\n\r\n var xAxisOptions = options.xAxis || {},\r\n yAxisOptions = options.yAxis || {},\r\n optionsArray,\r\n axis;\r\n\r\n // make sure the options are arrays and add some members\r\n xAxisOptions = splat(xAxisOptions);\r\n each(xAxisOptions, function(axis, i) {\r\n axis.index = i;\r\n axis.isX = true;\r\n });\r\n\r\n yAxisOptions = splat(yAxisOptions);\r\n each(yAxisOptions, function(axis, i) {\r\n axis.index = i;\r\n });\r\n\r\n // concatenate all axis options into one array\r\n optionsArray = xAxisOptions.concat(yAxisOptions);\r\n\r\n each(optionsArray, function(axisOptions) {\r\n axis = new Axis(chart, axisOptions);\r\n });\r\n\r\n chart.adjustTickAmounts();\r\n },\r\n\r\n /**\r\n * Get the currently selected points from all series\r\n */\r\n getSelectedPoints: function() {\r\n var points = [];\r\n each(this.series, function(serie) {\r\n points = points.concat(\r\n grep(serie.points, function(point) {\r\n return point.selected;\r\n })\r\n );\r\n });\r\n return points;\r\n },\r\n\r\n /**\r\n * Get the currently selected series\r\n */\r\n getSelectedSeries: function() {\r\n return grep(this.series, function(serie) {\r\n return serie.selected;\r\n });\r\n },\r\n\r\n /**\r\n * Display the zoom button\r\n */\r\n showResetZoom: function() {\r\n var chart = this,\r\n lang = defaultOptions.lang,\r\n btnOptions = chart.options.chart.resetZoomButton,\r\n theme = btnOptions.theme,\r\n states = theme.states,\r\n alignTo = btnOptions.relativeTo === \"chart\" ? null : \"plotBox\";\r\n\r\n this.resetZoomButton = chart.renderer\r\n .button(\r\n lang.resetZoom,\r\n null,\r\n null,\r\n function() {\r\n chart.zoomOut();\r\n },\r\n theme,\r\n states && states.hover\r\n )\r\n .attr({\r\n align: btnOptions.position.align,\r\n title: lang.resetZoomTitle\r\n })\r\n .add()\r\n .align(btnOptions.position, false, chart[alignTo]);\r\n this.resetZoomButton.alignTo = alignTo;\r\n },\r\n\r\n /**\r\n * Zoom out to 1:1\r\n */\r\n zoomOut: function() {\r\n var chart = this,\r\n resetZoomButton = chart.resetZoomButton;\r\n\r\n fireEvent(chart, \"selection\", { resetSelection: true }, function() {\r\n chart.zoom();\r\n });\r\n if (resetZoomButton) {\r\n chart.resetZoomButton = resetZoomButton.destroy();\r\n }\r\n },\r\n\r\n /**\r\n * Zoom into a given portion of the chart given by axis coordinates\r\n * @param {Object} event\r\n */\r\n zoom: function(event) {\r\n var chart = this,\r\n hasZoomed;\r\n\r\n // if zoom is called with no arguments, reset the axes\r\n if (!event || event.resetSelection) {\r\n each(chart.axes, function(axis) {\r\n hasZoomed = axis.zoom();\r\n });\r\n }\r\n else {\r\n // else, zoom in on all axes\r\n each(event.xAxis.concat(event.yAxis), function(axisData) {\r\n var axis = axisData.axis;\r\n\r\n // don't zoom more than minRange\r\n if (chart.tracker[axis.isXAxis ? \"zoomX\" : \"zoomY\"]) {\r\n hasZoomed = axis.zoom(axisData.min, axisData.max);\r\n }\r\n });\r\n }\r\n\r\n // Show the Reset zoom button\r\n if (!chart.resetZoomButton) {\r\n chart.showResetZoom();\r\n }\r\n\r\n // Redraw\r\n if (hasZoomed) {\r\n chart.redraw(\r\n pick(chart.options.chart.animation, chart.pointCount < 100) // animation\r\n );\r\n }\r\n },\r\n\r\n /**\r\n * Pan the chart by dragging the mouse across the pane. This function is called\r\n * on mouse move, and the distance to pan is computed from chartX compared to\r\n * the first chartX position in the dragging operation.\r\n */\r\n pan: function(chartX) {\r\n var chart = this;\r\n\r\n var xAxis = chart.xAxis[0],\r\n mouseDownX = chart.mouseDownX,\r\n halfPointRange = xAxis.pointRange / 2,\r\n extremes = xAxis.getExtremes(),\r\n newMin = xAxis.translate(mouseDownX - chartX, true) + halfPointRange,\r\n newMax =\r\n xAxis.translate(mouseDownX + chart.plotWidth - chartX, true) -\r\n halfPointRange,\r\n hoverPoints = chart.hoverPoints;\r\n\r\n // remove active points for shared tooltip\r\n if (hoverPoints) {\r\n each(hoverPoints, function(point) {\r\n point.setState();\r\n });\r\n }\r\n\r\n if (\r\n xAxis.series.length &&\r\n newMin > mathMin(extremes.dataMin, extremes.min) &&\r\n newMax < mathMax(extremes.dataMax, extremes.max)\r\n ) {\r\n xAxis.setExtremes(newMin, newMax, true, false, { trigger: \"pan\" });\r\n }\r\n\r\n chart.mouseDownX = chartX; // set new reference for next run\r\n css(chart.container, { cursor: \"move\" });\r\n },\r\n\r\n /**\r\n * Show the title and subtitle of the chart\r\n *\r\n * @param titleOptions {Object} New title options\r\n * @param subtitleOptions {Object} New subtitle options\r\n *\r\n */\r\n setTitle: function(titleOptions, subtitleOptions) {\r\n var chart = this,\r\n options = chart.options,\r\n chartTitleOptions,\r\n chartSubtitleOptions;\r\n\r\n chart.chartTitleOptions = chartTitleOptions = merge(\r\n options.title,\r\n titleOptions\r\n );\r\n chart.chartSubtitleOptions = chartSubtitleOptions = merge(\r\n options.subtitle,\r\n subtitleOptions\r\n );\r\n\r\n // add title and subtitle\r\n each(\r\n [\r\n [\"title\", titleOptions, chartTitleOptions],\r\n [\"subtitle\", subtitleOptions, chartSubtitleOptions]\r\n ],\r\n function(arr) {\r\n var name = arr[0],\r\n title = chart[name],\r\n titleOptions = arr[1],\r\n chartTitleOptions = arr[2];\r\n\r\n if (title && titleOptions) {\r\n chart[name] = title = title.destroy(); // remove old\r\n }\r\n\r\n if (chartTitleOptions && chartTitleOptions.text && !title) {\r\n chart[name] = chart.renderer\r\n .text(chartTitleOptions.text, 0, 0, chartTitleOptions.useHTML)\r\n .attr({\r\n align: chartTitleOptions.align,\r\n class: PREFIX + name,\r\n zIndex: chartTitleOptions.zIndex || 4\r\n })\r\n .css(chartTitleOptions.style)\r\n .add()\r\n .align(chartTitleOptions, false, chart.spacingBox);\r\n }\r\n }\r\n );\r\n },\r\n\r\n /**\r\n * Get chart width and height according to options and container size\r\n */\r\n getChartSize: function() {\r\n var chart = this,\r\n optionsChart = chart.options.chart,\r\n renderTo = chart.renderToClone || chart.renderTo;\r\n\r\n // get inner width and height from jQuery (#824)\r\n chart.containerWidth = adapterRun(renderTo, \"width\");\r\n chart.containerHeight = adapterRun(renderTo, \"height\");\r\n\r\n chart.chartWidth = mathMax(\r\n 0,\r\n pick(optionsChart.width, chart.containerWidth, 600)\r\n );\r\n chart.chartHeight = mathMax(\r\n 0,\r\n pick(\r\n optionsChart.height,\r\n // the offsetHeight of an empty container is 0 in standard browsers, but 19 in IE7:\r\n chart.containerHeight > 19 ? chart.containerHeight : 400\r\n )\r\n );\r\n },\r\n\r\n /**\r\n * Create a clone of the chart's renderTo div and place it outside the viewport to allow\r\n * size computation on chart.render and chart.redraw\r\n */\r\n cloneRenderTo: function(revert) {\r\n var clone = this.renderToClone,\r\n container = this.container;\r\n\r\n // Destroy the clone and bring the container back to the real renderTo div\r\n if (revert) {\r\n if (clone) {\r\n this.renderTo.appendChild(container);\r\n discardElement(clone);\r\n delete this.renderToClone;\r\n }\r\n\r\n // Set up the clone\r\n }\r\n else {\r\n if (container) {\r\n this.renderTo.removeChild(container); // do not clone this\r\n }\r\n this.renderToClone = clone = this.renderTo.cloneNode(0);\r\n css(clone, {\r\n position: ABSOLUTE,\r\n top: \"-9999px\",\r\n display: \"block\" // #833\r\n });\r\n doc.body.appendChild(clone);\r\n if (container) {\r\n clone.appendChild(container);\r\n }\r\n }\r\n },\r\n\r\n /**\r\n * Get the containing element, determine the size and create the inner container\r\n * div to hold the chart\r\n */\r\n getContainer: function() {\r\n var chart = this,\r\n container,\r\n optionsChart = chart.options.chart,\r\n chartWidth,\r\n chartHeight,\r\n renderTo,\r\n indexAttrName = \"data-highcharts-chart\",\r\n oldChartIndex,\r\n containerId;\r\n\r\n chart.renderTo = renderTo = optionsChart.renderTo;\r\n containerId = PREFIX + idCounter++;\r\n\r\n if (isString(renderTo)) {\r\n chart.renderTo = renderTo = doc.getElementById(renderTo);\r\n }\r\n\r\n // Display an error if the renderTo is wrong\r\n if (!renderTo) {\r\n error(13, true);\r\n }\r\n\r\n // If the container already holds a chart, destroy it\r\n oldChartIndex = pInt(attr(renderTo, indexAttrName));\r\n if (!isNaN(oldChartIndex) && charts[oldChartIndex]) {\r\n charts[oldChartIndex].destroy();\r\n }\r\n\r\n // Make a reference to the chart from the div\r\n attr(renderTo, indexAttrName, chart.index);\r\n\r\n // remove previous chart\r\n renderTo.innerHTML = \"\";\r\n\r\n // If the container doesn't have an offsetWidth, it has or is a child of a node\r\n // that has display:none. We need to temporarily move it out to a visible\r\n // state to determine the size, else the legend and tooltips won't render\r\n // properly\r\n if (!renderTo.offsetWidth) {\r\n chart.cloneRenderTo();\r\n }\r\n\r\n // get the width and height\r\n chart.getChartSize();\r\n chartWidth = chart.chartWidth;\r\n chartHeight = chart.chartHeight;\r\n\r\n // create the inner container\r\n chart.container = container = createElement(\r\n DIV,\r\n {\r\n className:\r\n PREFIX +\r\n \"container\" +\r\n (optionsChart.className ? \" \" + optionsChart.className : \"\"),\r\n id: containerId\r\n },\r\n extend(\r\n {\r\n position: RELATIVE,\r\n overflow: HIDDEN, // needed for context menu (avoid scrollbars) and\r\n // content overflow in IE\r\n width: chartWidth + PX,\r\n height: chartHeight + PX,\r\n textAlign: \"left\",\r\n lineHeight: \"normal\", // #427\r\n zIndex: 0 // #1072\r\n },\r\n optionsChart.style\r\n ),\r\n chart.renderToClone || renderTo\r\n );\r\n\r\n chart.renderer = optionsChart.forExport // force SVG, used for SVG export\r\n ? new SVGRenderer(container, chartWidth, chartHeight, true)\r\n : new Renderer(container, chartWidth, chartHeight);\r\n\r\n if (useCanVG) {\r\n // If we need canvg library, extend and configure the renderer\r\n // to get the tracker for translating mouse events\r\n chart.renderer.create(chart, container, chartWidth, chartHeight);\r\n }\r\n },\r\n\r\n /**\r\n * Calculate margins by rendering axis labels in a preliminary position. Title,\r\n * subtitle and legend have already been rendered at this stage, but will be\r\n * moved into their final positions\r\n */\r\n getMargins: function() {\r\n var chart = this,\r\n optionsChart = chart.options.chart,\r\n spacingTop = optionsChart.spacingTop,\r\n spacingRight = optionsChart.spacingRight,\r\n spacingBottom = optionsChart.spacingBottom,\r\n spacingLeft = optionsChart.spacingLeft,\r\n axisOffset,\r\n legend = chart.legend,\r\n optionsMarginTop = chart.optionsMarginTop,\r\n optionsMarginLeft = chart.optionsMarginLeft,\r\n optionsMarginRight = chart.optionsMarginRight,\r\n optionsMarginBottom = chart.optionsMarginBottom,\r\n chartTitleOptions = chart.chartTitleOptions,\r\n chartSubtitleOptions = chart.chartSubtitleOptions,\r\n legendOptions = chart.options.legend,\r\n legendMargin = pick(legendOptions.margin, 10),\r\n legendX = legendOptions.x,\r\n legendY = legendOptions.y,\r\n align = legendOptions.align,\r\n verticalAlign = legendOptions.verticalAlign,\r\n titleOffset;\r\n\r\n chart.resetMargins();\r\n axisOffset = chart.axisOffset;\r\n\r\n // adjust for title and subtitle\r\n if ((chart.title || chart.subtitle) && !defined(chart.optionsMarginTop)) {\r\n titleOffset = mathMax(\r\n (chart.title &&\r\n !chartTitleOptions.floating &&\r\n !chartTitleOptions.verticalAlign &&\r\n chartTitleOptions.y) ||\r\n 0,\r\n (chart.subtitle &&\r\n !chartSubtitleOptions.floating &&\r\n !chartSubtitleOptions.verticalAlign &&\r\n chartSubtitleOptions.y) ||\r\n 0\r\n );\r\n if (titleOffset) {\r\n chart.plotTop = mathMax(\r\n chart.plotTop,\r\n titleOffset + pick(chartTitleOptions.margin, 15) + spacingTop\r\n );\r\n }\r\n }\r\n // adjust for legend\r\n if (legend.display && !legendOptions.floating) {\r\n if (align === \"right\") {\r\n // horizontal alignment handled first\r\n if (!defined(optionsMarginRight)) {\r\n chart.marginRight = mathMax(\r\n chart.marginRight,\r\n legend.legendWidth - legendX + legendMargin + spacingRight\r\n );\r\n }\r\n }\r\n else if (align === \"left\") {\r\n if (!defined(optionsMarginLeft)) {\r\n chart.plotLeft = mathMax(\r\n chart.plotLeft,\r\n legend.legendWidth + legendX + legendMargin + spacingLeft\r\n );\r\n }\r\n }\r\n else if (verticalAlign === \"top\") {\r\n if (!defined(optionsMarginTop)) {\r\n chart.plotTop = mathMax(\r\n chart.plotTop,\r\n legend.legendHeight + legendY + legendMargin + spacingTop\r\n );\r\n }\r\n }\r\n else if (verticalAlign === \"bottom\") {\r\n if (!defined(optionsMarginBottom)) {\r\n chart.marginBottom = mathMax(\r\n chart.marginBottom,\r\n legend.legendHeight - legendY + legendMargin + spacingBottom\r\n );\r\n }\r\n }\r\n }\r\n\r\n // adjust for scroller\r\n if (chart.extraBottomMargin) {\r\n chart.marginBottom += chart.extraBottomMargin;\r\n }\r\n if (chart.extraTopMargin) {\r\n chart.plotTop += chart.extraTopMargin;\r\n }\r\n\r\n // pre-render axes to get labels offset width\r\n if (chart.hasCartesianSeries) {\r\n each(chart.axes, function(axis) {\r\n axis.getOffset();\r\n });\r\n }\r\n\r\n if (!defined(optionsMarginLeft)) {\r\n chart.plotLeft += axisOffset[3];\r\n }\r\n if (!defined(optionsMarginTop)) {\r\n chart.plotTop += axisOffset[0];\r\n }\r\n if (!defined(optionsMarginBottom)) {\r\n chart.marginBottom += axisOffset[2];\r\n }\r\n if (!defined(optionsMarginRight)) {\r\n chart.marginRight += axisOffset[1];\r\n }\r\n\r\n chart.setChartSize();\r\n },\r\n\r\n /**\r\n * Add the event handlers necessary for auto resizing\r\n *\r\n */\r\n initReflow: function() {\r\n var chart = this,\r\n optionsChart = chart.options.chart,\r\n renderTo = chart.renderTo,\r\n reflowTimeout;\r\n\r\n function reflow(e) {\r\n var width = optionsChart.width || adapterRun(renderTo, \"width\"),\r\n height = optionsChart.height || adapterRun(renderTo, \"height\"),\r\n target = e ? e.target : win; // #805 - MooTools doesn't supply e\r\n\r\n // Width and height checks for display:none. Target is doc in IE8 and Opera,\r\n // win in Firefox, Chrome and IE9.\r\n if (\r\n !chart.hasUserSize &&\r\n width &&\r\n height &&\r\n (target === win || target === doc)\r\n ) {\r\n if (\r\n width !== chart.containerWidth ||\r\n height !== chart.containerHeight\r\n ) {\r\n clearTimeout(reflowTimeout);\r\n chart.reflowTimeout = reflowTimeout = setTimeout(function() {\r\n if (chart.container) {\r\n // It may have been destroyed in the meantime (#1257)\r\n chart.setSize(width, height, false);\r\n chart.hasUserSize = null;\r\n }\r\n }, 100);\r\n }\r\n chart.containerWidth = width;\r\n chart.containerHeight = height;\r\n }\r\n }\r\n addEvent(win, \"resize\", reflow);\r\n addEvent(chart, \"destroy\", function() {\r\n removeEvent(win, \"resize\", reflow);\r\n });\r\n },\r\n\r\n /**\r\n * Resize the chart to a given width and height\r\n * @param {Number} width\r\n * @param {Number} height\r\n * @param {Object|Boolean} animation\r\n */\r\n setSize: function(width, height, animation) {\r\n var chart = this,\r\n chartWidth,\r\n chartHeight,\r\n spacingBox,\r\n resetZoomButton = chart.resetZoomButton,\r\n chartTitle = chart.title,\r\n chartSubtitle = chart.subtitle,\r\n fireEndResize;\r\n\r\n // Handle the isResizing counter\r\n chart.isResizing += 1;\r\n fireEndResize = function() {\r\n if (chart) {\r\n fireEvent(chart, \"endResize\", null, function() {\r\n chart.isResizing -= 1;\r\n });\r\n }\r\n };\r\n\r\n // set the animation for the current process\r\n setAnimation(animation, chart);\r\n\r\n chart.oldChartHeight = chart.chartHeight;\r\n chart.oldChartWidth = chart.chartWidth;\r\n if (defined(width)) {\r\n chart.chartWidth = chartWidth = mathMax(0, mathRound(width));\r\n chart.hasUserSize = !!chartWidth;\r\n }\r\n if (defined(height)) {\r\n chart.chartHeight = chartHeight = mathMax(0, mathRound(height));\r\n }\r\n\r\n css(chart.container, {\r\n width: chartWidth + PX,\r\n height: chartHeight + PX\r\n });\r\n chart.renderer.setSize(chartWidth, chartHeight, animation);\r\n\r\n // update axis lengths for more correct tick intervals:\r\n chart.plotWidth = chartWidth - chart.plotLeft - chart.marginRight;\r\n chart.plotHeight = chartHeight - chart.plotTop - chart.marginBottom;\r\n\r\n // handle axes\r\n chart.maxTicks = null;\r\n each(chart.axes, function(axis) {\r\n axis.isDirty = true;\r\n axis.setScale();\r\n });\r\n\r\n // make sure non-cartesian series are also handled\r\n each(chart.series, function(serie) {\r\n serie.isDirty = true;\r\n });\r\n\r\n chart.isDirtyLegend = true; // force legend redraw\r\n chart.isDirtyBox = true; // force redraw of plot and chart border\r\n\r\n chart.getMargins();\r\n\r\n // move titles\r\n spacingBox = chart.spacingBox;\r\n if (chartTitle) {\r\n chartTitle.align(null, null, spacingBox);\r\n }\r\n if (chartSubtitle) {\r\n chartSubtitle.align(null, null, spacingBox);\r\n }\r\n\r\n // Move resize button (#1115)\r\n if (resetZoomButton && resetZoomButton.align) {\r\n resetZoomButton.align(null, null, chart[resetZoomButton.alignTo]);\r\n }\r\n\r\n chart.redraw(animation);\r\n\r\n chart.oldChartHeight = null;\r\n fireEvent(chart, \"resize\");\r\n\r\n // fire endResize and set isResizing back\r\n // If animation is disabled, fire without delay\r\n if (globalAnimation === false) {\r\n fireEndResize();\r\n }\r\n else {\r\n // else set a timeout with the animation duration\r\n setTimeout(\r\n fireEndResize,\r\n (globalAnimation && globalAnimation.duration) || 500\r\n );\r\n }\r\n },\r\n\r\n /**\r\n * Set the public chart properties. This is done before and after the pre-render\r\n * to determine margin sizes\r\n */\r\n setChartSize: function() {\r\n var chart = this,\r\n inverted = chart.inverted,\r\n chartWidth = chart.chartWidth,\r\n chartHeight = chart.chartHeight,\r\n optionsChart = chart.options.chart,\r\n spacingTop = optionsChart.spacingTop,\r\n spacingRight = optionsChart.spacingRight,\r\n spacingBottom = optionsChart.spacingBottom,\r\n spacingLeft = optionsChart.spacingLeft,\r\n plotLeft,\r\n plotTop,\r\n plotWidth,\r\n plotHeight,\r\n plotBorderWidth;\r\n\r\n chart.plotLeft = plotLeft = mathRound(chart.plotLeft);\r\n chart.plotTop = plotTop = mathRound(chart.plotTop);\r\n chart.plotWidth = plotWidth = mathMax(\r\n 0,\r\n mathRound(chartWidth - plotLeft - chart.marginRight)\r\n );\r\n chart.plotHeight = plotHeight = mathMax(\r\n 0,\r\n mathRound(chartHeight - plotTop - chart.marginBottom)\r\n );\r\n\r\n chart.plotSizeX = inverted ? plotHeight : plotWidth;\r\n chart.plotSizeY = inverted ? plotWidth : plotHeight;\r\n\r\n chart.plotBorderWidth = plotBorderWidth =\r\n optionsChart.plotBorderWidth || 0;\r\n\r\n // Set boxes used for alignment\r\n chart.spacingBox = {\r\n x: spacingLeft,\r\n y: spacingTop,\r\n width: chartWidth - spacingLeft - spacingRight,\r\n height: chartHeight - spacingTop - spacingBottom\r\n };\r\n chart.plotBox = {\r\n x: plotLeft,\r\n y: plotTop,\r\n width: plotWidth,\r\n height: plotHeight\r\n };\r\n chart.clipBox = {\r\n x: plotBorderWidth / 2,\r\n y: plotBorderWidth / 2,\r\n width: chart.plotSizeX - plotBorderWidth,\r\n height: chart.plotSizeY - plotBorderWidth\r\n };\r\n\r\n each(chart.axes, function(axis) {\r\n axis.setAxisSize();\r\n axis.setAxisTranslation();\r\n });\r\n },\r\n\r\n /**\r\n * Initial margins before auto size margins are applied\r\n */\r\n resetMargins: function() {\r\n var chart = this,\r\n optionsChart = chart.options.chart,\r\n spacingTop = optionsChart.spacingTop,\r\n spacingRight = optionsChart.spacingRight,\r\n spacingBottom = optionsChart.spacingBottom,\r\n spacingLeft = optionsChart.spacingLeft;\r\n\r\n chart.plotTop = pick(chart.optionsMarginTop, spacingTop);\r\n chart.marginRight = pick(chart.optionsMarginRight, spacingRight);\r\n chart.marginBottom = pick(chart.optionsMarginBottom, spacingBottom);\r\n chart.plotLeft = pick(chart.optionsMarginLeft, spacingLeft);\r\n chart.axisOffset = [0, 0, 0, 0]; // top, right, bottom, left\r\n },\r\n\r\n /**\r\n * Draw the borders and backgrounds for chart and plot area\r\n */\r\n drawChartBox: function() {\r\n var chart = this,\r\n optionsChart = chart.options.chart,\r\n renderer = chart.renderer,\r\n chartWidth = chart.chartWidth,\r\n chartHeight = chart.chartHeight,\r\n chartBackground = chart.chartBackground,\r\n plotBackground = chart.plotBackground,\r\n plotBorder = chart.plotBorder,\r\n plotBGImage = chart.plotBGImage,\r\n chartBorderWidth = optionsChart.borderWidth || 0,\r\n chartBackgroundColor = optionsChart.backgroundColor,\r\n plotBackgroundColor = optionsChart.plotBackgroundColor,\r\n plotBackgroundImage = optionsChart.plotBackgroundImage,\r\n plotBorderWidth = optionsChart.plotBorderWidth || 0,\r\n mgn,\r\n bgAttr,\r\n plotLeft = chart.plotLeft,\r\n plotTop = chart.plotTop,\r\n plotWidth = chart.plotWidth,\r\n plotHeight = chart.plotHeight,\r\n plotBox = chart.plotBox,\r\n clipRect = chart.clipRect,\r\n clipBox = chart.clipBox;\r\n\r\n // Chart area\r\n mgn = chartBorderWidth + (optionsChart.shadow ? 8 : 0);\r\n\r\n if (chartBorderWidth || chartBackgroundColor) {\r\n if (!chartBackground) {\r\n bgAttr = {\r\n fill: chartBackgroundColor || NONE\r\n };\r\n if (chartBorderWidth) {\r\n // #980\r\n bgAttr.stroke = optionsChart.borderColor;\r\n bgAttr[\"stroke-width\"] = chartBorderWidth;\r\n }\r\n chart.chartBackground = renderer\r\n .rect(\r\n mgn / 2,\r\n mgn / 2,\r\n chartWidth - mgn,\r\n chartHeight - mgn,\r\n optionsChart.borderRadius,\r\n chartBorderWidth\r\n )\r\n .attr(bgAttr)\r\n .add()\r\n .shadow(optionsChart.shadow);\r\n }\r\n else {\r\n // resize\r\n chartBackground.animate(\r\n chartBackground.crisp(\r\n null,\r\n null,\r\n null,\r\n chartWidth - mgn,\r\n chartHeight - mgn\r\n )\r\n );\r\n }\r\n }\r\n\r\n // Plot background\r\n if (plotBackgroundColor) {\r\n if (!plotBackground) {\r\n chart.plotBackground = renderer\r\n .rect(plotLeft, plotTop, plotWidth, plotHeight, 0)\r\n .attr({\r\n fill: plotBackgroundColor\r\n })\r\n .add()\r\n .shadow(optionsChart.plotShadow);\r\n }\r\n else {\r\n plotBackground.animate(plotBox);\r\n }\r\n }\r\n if (plotBackgroundImage) {\r\n if (!plotBGImage) {\r\n chart.plotBGImage = renderer\r\n .image(\r\n plotBackgroundImage,\r\n plotLeft,\r\n plotTop,\r\n plotWidth,\r\n plotHeight\r\n )\r\n .add();\r\n }\r\n else {\r\n plotBGImage.animate(plotBox);\r\n }\r\n }\r\n\r\n // Plot clip\r\n if (!clipRect) {\r\n chart.clipRect = renderer.clipRect(clipBox);\r\n }\r\n else {\r\n clipRect.animate({\r\n width: clipBox.width,\r\n height: clipBox.height\r\n });\r\n }\r\n\r\n // Plot area border\r\n if (plotBorderWidth) {\r\n if (!plotBorder) {\r\n chart.plotBorder = renderer\r\n .rect(plotLeft, plotTop, plotWidth, plotHeight, 0, plotBorderWidth)\r\n .attr({\r\n stroke: optionsChart.plotBorderColor,\r\n \"stroke-width\": plotBorderWidth,\r\n zIndex: 1\r\n })\r\n .add();\r\n }\r\n else {\r\n plotBorder.animate(\r\n plotBorder.crisp(null, plotLeft, plotTop, plotWidth, plotHeight)\r\n );\r\n }\r\n }\r\n\r\n // reset\r\n chart.isDirtyBox = false;\r\n },\r\n\r\n /**\r\n * Detect whether a certain chart property is needed based on inspecting its options\r\n * and series. This mainly applies to the chart.invert property, and in extensions to\r\n * the chart.angular and chart.polar properties.\r\n */\r\n propFromSeries: function() {\r\n var chart = this,\r\n optionsChart = chart.options.chart,\r\n klass,\r\n seriesOptions = chart.options.series,\r\n i,\r\n value;\r\n\r\n each([\"inverted\", \"angular\", \"polar\"], function(key) {\r\n // The default series type's class\r\n klass =\r\n seriesTypes[optionsChart.type || optionsChart.defaultSeriesType];\r\n\r\n // Get the value from available chart-wide properties\r\n value =\r\n chart[key] || // 1. it is set before\r\n optionsChart[key] || // 2. it is set in the options\r\n (klass && klass.prototype[key]); // 3. it's default series class requires it\r\n\r\n // 4. Check if any the chart's series require it\r\n i = seriesOptions && seriesOptions.length;\r\n while (!value && i--) {\r\n klass = seriesTypes[seriesOptions[i].type];\r\n if (klass && klass.prototype[key]) {\r\n value = true;\r\n }\r\n }\r\n\r\n // Set the chart property\r\n chart[key] = value;\r\n });\r\n },\r\n\r\n /**\r\n * Render all graphics for the chart\r\n */\r\n render: function() {\r\n var chart = this,\r\n axes = chart.axes,\r\n renderer = chart.renderer,\r\n options = chart.options;\r\n\r\n var labels = options.labels,\r\n credits = options.credits,\r\n creditsHref;\r\n\r\n // Title\r\n chart.setTitle();\r\n\r\n // Legend\r\n chart.legend = new Legend(chart);\r\n\r\n // Get margins by pre-rendering axes\r\n // set axes scales\r\n each(axes, function(axis) {\r\n axis.setScale();\r\n });\r\n chart.getMargins();\r\n\r\n chart.maxTicks = null; // reset for second pass\r\n each(axes, function(axis) {\r\n axis.setTickPositions(true); // update to reflect the new margins\r\n axis.setMaxTicks();\r\n });\r\n chart.adjustTickAmounts();\r\n chart.getMargins(); // second pass to check for new labels\r\n\r\n // Draw the borders and backgrounds\r\n chart.drawChartBox();\r\n\r\n // Axes\r\n if (chart.hasCartesianSeries) {\r\n each(axes, function(axis) {\r\n axis.render();\r\n });\r\n }\r\n\r\n // The series\r\n if (!chart.seriesGroup) {\r\n chart.seriesGroup = renderer\r\n .g(\"series-group\")\r\n .attr({ zIndex: 3 })\r\n .add();\r\n }\r\n each(chart.series, function(serie) {\r\n serie.translate();\r\n serie.setTooltipPoints();\r\n serie.render();\r\n });\r\n\r\n // Labels\r\n if (labels.items) {\r\n each(labels.items, function(label) {\r\n var style = extend(labels.style, label.style),\r\n x = pInt(style.left) + chart.plotLeft,\r\n y = pInt(style.top) + chart.plotTop + 12;\r\n\r\n // delete to prevent rewriting in IE\r\n delete style.left;\r\n delete style.top;\r\n\r\n renderer\r\n .text(label.html, x, y)\r\n .attr({ zIndex: 2 })\r\n .css(style)\r\n .add();\r\n });\r\n }\r\n\r\n // Credits\r\n if (credits.enabled && !chart.credits) {\r\n creditsHref = credits.href;\r\n chart.credits = renderer\r\n .text(credits.text, 0, 0)\r\n .on(\"click\", function() {\r\n if (creditsHref) {\r\n location.href = creditsHref;\r\n }\r\n })\r\n .attr({\r\n align: credits.position.align,\r\n zIndex: 8\r\n })\r\n .css(credits.style)\r\n .add()\r\n .align(credits.position);\r\n }\r\n\r\n // Set flag\r\n chart.hasRendered = true;\r\n },\r\n\r\n /**\r\n * Clean up memory usage\r\n */\r\n destroy: function() {\r\n var chart = this,\r\n axes = chart.axes,\r\n series = chart.series,\r\n container = chart.container,\r\n i,\r\n parentNode = container && container.parentNode;\r\n\r\n // fire the chart.destoy event\r\n fireEvent(chart, \"destroy\");\r\n\r\n // Delete the chart from charts lookup array\r\n charts[chart.index] = UNDEFINED;\r\n chart.renderTo.removeAttribute(\"data-highcharts-chart\");\r\n\r\n // remove events\r\n removeEvent(chart);\r\n\r\n // ==== Destroy collections:\r\n // Destroy axes\r\n i = axes.length;\r\n while (i--) {\r\n axes[i] = axes[i].destroy();\r\n }\r\n\r\n // Destroy each series\r\n i = series.length;\r\n while (i--) {\r\n series[i] = series[i].destroy();\r\n }\r\n\r\n // ==== Destroy chart properties:\r\n each(\r\n [\r\n \"title\",\r\n \"subtitle\",\r\n \"chartBackground\",\r\n \"plotBackground\",\r\n \"plotBGImage\",\r\n \"plotBorder\",\r\n \"seriesGroup\",\r\n \"clipRect\",\r\n \"credits\",\r\n \"tracker\",\r\n \"scroller\",\r\n \"rangeSelector\",\r\n \"legend\",\r\n \"resetZoomButton\",\r\n \"tooltip\",\r\n \"renderer\"\r\n ],\r\n function(name) {\r\n var prop = chart[name];\r\n\r\n if (prop && prop.destroy) {\r\n chart[name] = prop.destroy();\r\n }\r\n }\r\n );\r\n\r\n // remove container and all SVG\r\n if (container) {\r\n // can break in IE when destroyed before finished loading\r\n container.innerHTML = \"\";\r\n removeEvent(container);\r\n if (parentNode) {\r\n discardElement(container);\r\n }\r\n }\r\n\r\n // clean it all up\r\n for (i in chart) {\r\n delete chart[i];\r\n }\r\n },\r\n\r\n /**\r\n * VML namespaces can't be added until after complete. Listening\r\n * for Perini's doScroll hack is not enough.\r\n */\r\n isReadyToRender: function() {\r\n var chart = this;\r\n\r\n // Note: in spite of JSLint's complaints, win == win.top is required\r\n /*jslint eqeq: true*/\r\n if (\r\n (!hasSVG && (win == win.top && doc.readyState !== \"complete\")) ||\r\n (useCanVG && !win.canvg)\r\n ) {\r\n /*jslint eqeq: false*/\r\n if (useCanVG) {\r\n // Delay rendering until canvg library is downloaded and ready\r\n CanVGController.push(function() {\r\n chart.firstRender();\r\n }, chart.options.global.canvasToolsURL);\r\n }\r\n else {\r\n doc.attachEvent(\"onreadystatechange\", function() {\r\n doc.detachEvent(\"onreadystatechange\", chart.firstRender);\r\n if (doc.readyState === \"complete\") {\r\n chart.firstRender();\r\n }\r\n });\r\n }\r\n return false;\r\n }\r\n return true;\r\n },\r\n\r\n /**\r\n * Prepare for first rendering after all data are loaded\r\n */\r\n firstRender: function() {\r\n var chart = this,\r\n options = chart.options,\r\n callback = chart.callback;\r\n\r\n // Check whether the chart is ready to render\r\n if (!chart.isReadyToRender()) {\r\n return;\r\n }\r\n\r\n // Create the container\r\n chart.getContainer();\r\n\r\n // Run an early event after the container and renderer are established\r\n fireEvent(chart, \"init\");\r\n\r\n // Initialize range selector for stock charts\r\n if (Highcharts.RangeSelector && options.rangeSelector.enabled) {\r\n chart.rangeSelector = new Highcharts.RangeSelector(chart);\r\n }\r\n\r\n chart.resetMargins();\r\n chart.setChartSize();\r\n\r\n // Set the common chart properties (mainly invert) from the given series\r\n chart.propFromSeries();\r\n\r\n // get axes\r\n chart.getAxes();\r\n\r\n // Initialize the series\r\n each(options.series || [], function(serieOptions) {\r\n chart.initSeries(serieOptions);\r\n });\r\n\r\n // Run an event where series and axes can be added\r\n //fireEvent(chart, 'beforeRender');\r\n\r\n // Initialize scroller for stock charts\r\n if (\r\n Highcharts.Scroller &&\r\n (options.navigator.enabled || options.scrollbar.enabled)\r\n ) {\r\n chart.scroller = new Highcharts.Scroller(chart);\r\n }\r\n\r\n // depends on inverted and on margins being set\r\n chart.tracker = new MouseTracker(chart, options);\r\n\r\n chart.render();\r\n\r\n // add canvas\r\n chart.renderer.draw();\r\n // run callbacks\r\n if (callback) {\r\n callback.apply(chart, [chart]);\r\n }\r\n each(chart.callbacks, function(fn) {\r\n fn.apply(chart, [chart]);\r\n });\r\n\r\n // If the chart was rendered outside the top container, put it back in\r\n chart.cloneRenderTo(true);\r\n\r\n fireEvent(chart, \"load\");\r\n }\r\n }; // end Chart\r\n\r\n // Hook for exporting module\r\n Chart.prototype.callbacks = [];\r\n /**\r\n * The Point object and prototype. Inheritable and used as base for PiePoint\r\n */\r\n var Point = function() {};\r\n Point.prototype = {\r\n /**\r\n * Initialize the point\r\n * @param {Object} series The series object containing this point\r\n * @param {Object} options The data in either number, array or object format\r\n */\r\n init: function(series, options, x) {\r\n var point = this,\r\n counters = series.chart.counters,\r\n defaultColors;\r\n point.series = series;\r\n point.applyOptions(options, x);\r\n point.pointAttr = {};\r\n\r\n if (series.options.colorByPoint) {\r\n defaultColors = series.chart.options.colors;\r\n point.color = point.color || defaultColors[counters.color++];\r\n // loop back to zero\r\n counters.wrapColor(defaultColors.length);\r\n }\r\n\r\n series.chart.pointCount++;\r\n return point;\r\n },\r\n /**\r\n * Apply the options containing the x and y data and possible some extra properties.\r\n * This is called on point init or from point.update.\r\n *\r\n * @param {Object} options\r\n */\r\n applyOptions: function(options, x) {\r\n var point = this,\r\n series = point.series,\r\n optionsType = typeof options;\r\n\r\n point.config = options;\r\n\r\n // onedimensional array input\r\n if (optionsType === \"number\" || options === null) {\r\n point.y = options;\r\n }\r\n else if (typeof options[0] === \"number\") {\r\n // two-dimentional array\r\n point.x = options[0];\r\n point.y = options[1];\r\n }\r\n else if (\r\n optionsType === \"object\" &&\r\n typeof options.length !== \"number\"\r\n ) {\r\n // object input\r\n // copy options directly to point\r\n extend(point, options);\r\n point.options = options;\r\n\r\n // This is the fastest way to detect if there are individual point dataLabels that need\r\n // to be considered in drawDataLabels. These can only occur in object configs.\r\n if (options.dataLabels) {\r\n series._hasPointLabels = true;\r\n }\r\n\r\n // Same approach as above for markers\r\n if (options.marker) {\r\n series._hasPointMarkers = true;\r\n }\r\n }\r\n else if (typeof options[0] === \"string\") {\r\n // categorized data with name in first position\r\n point.name = options[0];\r\n point.y = options[1];\r\n }\r\n\r\n /*\r\n * If no x is set by now, get auto incremented value. All points must have an\r\n * x value, however the y value can be null to create a gap in the series\r\n */\r\n // todo: skip this? It is only used in applyOptions, in translate it should not be used\r\n if (point.x === UNDEFINED) {\r\n point.x = x === UNDEFINED ? series.autoIncrement() : x;\r\n }\r\n },\r\n\r\n /**\r\n * Destroy a point to clear memory. Its reference still stays in series.data.\r\n */\r\n destroy: function() {\r\n var point = this,\r\n series = point.series,\r\n chart = series.chart,\r\n hoverPoints = chart.hoverPoints,\r\n prop;\r\n\r\n chart.pointCount--;\r\n\r\n if (hoverPoints) {\r\n point.setState();\r\n erase(hoverPoints, point);\r\n if (!hoverPoints.length) {\r\n chart.hoverPoints = null;\r\n }\r\n }\r\n if (point === chart.hoverPoint) {\r\n point.onMouseOut();\r\n }\r\n\r\n // remove all events\r\n if (point.graphic || point.dataLabel) {\r\n // removeEvent and destroyElements are performance expensive\r\n removeEvent(point);\r\n point.destroyElements();\r\n }\r\n\r\n if (point.legendItem) {\r\n // pies have legend items\r\n chart.legend.destroyItem(point);\r\n }\r\n\r\n for (prop in point) {\r\n point[prop] = null;\r\n }\r\n },\r\n\r\n /**\r\n * Destroy SVG elements associated with the point\r\n */\r\n destroyElements: function() {\r\n var point = this,\r\n props = [\r\n \"graphic\",\r\n \"tracker\",\r\n \"dataLabel\",\r\n \"dataLabelUpper\",\r\n \"group\",\r\n \"connector\",\r\n \"shadowGroup\"\r\n ],\r\n prop,\r\n i = 6;\r\n while (i--) {\r\n prop = props[i];\r\n if (point[prop]) {\r\n point[prop] = point[prop].destroy();\r\n }\r\n }\r\n },\r\n\r\n /**\r\n * Return the configuration hash needed for the data label and tooltip formatters\r\n */\r\n getLabelConfig: function() {\r\n var point = this;\r\n return {\r\n x: point.category,\r\n y: point.y,\r\n key: point.name || point.category,\r\n series: point.series,\r\n point: point,\r\n percentage: point.percentage,\r\n total: point.total || point.stackTotal\r\n };\r\n },\r\n\r\n /**\r\n * Toggle the selection status of a point\r\n * @param {Boolean} selected Whether to select or unselect the point.\r\n * @param {Boolean} accumulate Whether to add to the previous selection. By default,\r\n * this happens if the control key (Cmd on Mac) was pressed during clicking.\r\n */\r\n select: function(selected, accumulate) {\r\n var point = this,\r\n series = point.series,\r\n chart = series.chart;\r\n\r\n selected = pick(selected, !point.selected);\r\n\r\n // fire the event with the defalut handler\r\n point.firePointEvent(\r\n selected ? \"select\" : \"unselect\",\r\n { accumulate: accumulate },\r\n function() {\r\n point.selected = selected;\r\n point.setState(selected && SELECT_STATE);\r\n\r\n // unselect all other points unless Ctrl or Cmd + click\r\n if (!accumulate) {\r\n each(chart.getSelectedPoints(), function(loopPoint) {\r\n if (loopPoint.selected && loopPoint !== point) {\r\n loopPoint.selected = false;\r\n loopPoint.setState(NORMAL_STATE);\r\n loopPoint.firePointEvent(\"unselect\");\r\n }\r\n });\r\n }\r\n }\r\n );\r\n },\r\n\r\n onMouseOver: function() {\r\n var point = this,\r\n series = point.series,\r\n chart = series.chart,\r\n tooltip = chart.tooltip,\r\n hoverPoint = chart.hoverPoint;\r\n\r\n // set normal state to previous series\r\n if (hoverPoint && hoverPoint !== point) {\r\n hoverPoint.onMouseOut();\r\n }\r\n\r\n // trigger the event\r\n point.firePointEvent(\"mouseOver\");\r\n\r\n // update the tooltip\r\n if (tooltip && (!tooltip.shared || series.noSharedTooltip)) {\r\n tooltip.refresh(point);\r\n }\r\n\r\n // hover this\r\n point.setState(HOVER_STATE);\r\n chart.hoverPoint = point;\r\n },\r\n\r\n onMouseOut: function() {\r\n var chart = this.series.chart,\r\n hoverPoints = chart.hoverPoints;\r\n\r\n if (!hoverPoints || inArray(this, hoverPoints) === -1) {\r\n // #887\r\n this.firePointEvent(\"mouseOut\");\r\n\r\n this.setState();\r\n chart.hoverPoint = null;\r\n }\r\n },\r\n\r\n /**\r\n * Extendable method for formatting each point's tooltip line\r\n *\r\n * @return {String} A string to be concatenated in to the common tooltip text\r\n */\r\n tooltipFormatter: function(pointFormat) {\r\n var point = this,\r\n series = point.series,\r\n seriesTooltipOptions = series.tooltipOptions,\r\n match = pointFormat.match(/\\{(series|point)\\.[a-zA-Z]+\\}/g),\r\n splitter = /[{\\.}]/,\r\n obj,\r\n key,\r\n replacement,\r\n repOptionKey,\r\n parts,\r\n prop,\r\n i,\r\n cfg = {\r\n y: 0, // 0: use 'value' for repOptionKey\r\n open: 0,\r\n high: 0,\r\n low: 0,\r\n close: 0,\r\n percentage: 1, // 1: use the self name for repOptionKey\r\n total: 1\r\n };\r\n\r\n // Backwards compatibility to y naming in early Highstock\r\n seriesTooltipOptions.valuePrefix =\r\n seriesTooltipOptions.valuePrefix || seriesTooltipOptions.yPrefix;\r\n seriesTooltipOptions.valueDecimals = pick(\r\n seriesTooltipOptions.valueDecimals,\r\n seriesTooltipOptions.yDecimals\r\n ); // #1248\r\n seriesTooltipOptions.valueSuffix =\r\n seriesTooltipOptions.valueSuffix || seriesTooltipOptions.ySuffix;\r\n\r\n // loop over the variables defined on the form {series.name}, {point.y} etc\r\n for (i in match) {\r\n key = match[i];\r\n if (isString(key) && key !== pointFormat) {\r\n // IE matches more than just the variables\r\n\r\n // Split it further into parts\r\n parts = (\" \" + key).split(splitter); // add empty string because IE and the rest handles it differently\r\n obj = { point: point, series: series }[parts[1]];\r\n prop = parts[2];\r\n\r\n // Add some preformatting\r\n if (obj === point && cfg.hasOwnProperty(prop)) {\r\n repOptionKey = cfg[prop] ? prop : \"value\";\r\n replacement =\r\n (seriesTooltipOptions[repOptionKey + \"Prefix\"] || \"\") +\r\n numberFormat(\r\n point[prop],\r\n pick(seriesTooltipOptions[repOptionKey + \"Decimals\"], -1)\r\n ) +\r\n (seriesTooltipOptions[repOptionKey + \"Suffix\"] || \"\");\r\n\r\n // Automatic replacement\r\n }\r\n else {\r\n replacement = obj[prop];\r\n }\r\n\r\n pointFormat = pointFormat.replace(key, replacement);\r\n }\r\n }\r\n\r\n return pointFormat;\r\n },\r\n\r\n /**\r\n * Update the point with new options (typically x/y data) and optionally redraw the series.\r\n *\r\n * @param {Object} options Point options as defined in the series.data array\r\n * @param {Boolean} redraw Whether to redraw the chart or wait for an explicit call\r\n * @param {Boolean|Object} animation Whether to apply animation, and optionally animation\r\n * configuration\r\n *\r\n */\r\n update: function(options, redraw, animation) {\r\n var point = this,\r\n series = point.series,\r\n graphic = point.graphic,\r\n i,\r\n data = series.data,\r\n dataLength = data.length,\r\n chart = series.chart;\r\n\r\n redraw = pick(redraw, true);\r\n\r\n // fire the event with a default handler of doing the update\r\n point.firePointEvent(\"update\", { options: options }, function() {\r\n point.applyOptions(options);\r\n\r\n // update visuals\r\n if (isObject(options)) {\r\n series.getAttribs();\r\n if (graphic) {\r\n graphic.attr(point.pointAttr[series.state]);\r\n }\r\n }\r\n\r\n // record changes in the parallel arrays\r\n for (i = 0; i < dataLength; i++) {\r\n if (data[i] === point) {\r\n series.xData[i] = point.x;\r\n series.yData[i] = point.toYData ? point.toYData() : point.y;\r\n series.options.data[i] = options;\r\n break;\r\n }\r\n }\r\n\r\n // redraw\r\n series.isDirty = true;\r\n series.isDirtyData = true;\r\n if (redraw) {\r\n chart.redraw(animation);\r\n }\r\n });\r\n },\r\n\r\n /**\r\n * Remove a point and optionally redraw the series and if necessary the axes\r\n * @param {Boolean} redraw Whether to redraw the chart or wait for an explicit call\r\n * @param {Boolean|Object} animation Whether to apply animation, and optionally animation\r\n * configuration\r\n */\r\n remove: function(redraw, animation) {\r\n var point = this,\r\n series = point.series,\r\n chart = series.chart,\r\n i,\r\n data = series.data,\r\n dataLength = data.length;\r\n\r\n setAnimation(animation, chart);\r\n redraw = pick(redraw, true);\r\n\r\n // fire the event with a default handler of removing the point\r\n point.firePointEvent(\"remove\", null, function() {\r\n //erase(series.data, point);\r\n\r\n for (i = 0; i < dataLength; i++) {\r\n if (data[i] === point) {\r\n // splice all the parallel arrays\r\n data.splice(i, 1);\r\n series.options.data.splice(i, 1);\r\n series.xData.splice(i, 1);\r\n series.yData.splice(i, 1);\r\n break;\r\n }\r\n }\r\n\r\n point.destroy();\r\n\r\n // redraw\r\n series.isDirty = true;\r\n series.isDirtyData = true;\r\n if (redraw) {\r\n chart.redraw();\r\n }\r\n });\r\n },\r\n\r\n /**\r\n * Fire an event on the Point object. Must not be renamed to fireEvent, as this\r\n * causes a name clash in MooTools\r\n * @param {String} eventType\r\n * @param {Object} eventArgs Additional event arguments\r\n * @param {Function} defaultFunction Default event handler\r\n */\r\n firePointEvent: function(eventType, eventArgs, defaultFunction) {\r\n var point = this,\r\n series = this.series,\r\n seriesOptions = series.options;\r\n\r\n // load event handlers on demand to save time on mouseover/out\r\n if (\r\n seriesOptions.point.events[eventType] ||\r\n (point.options &&\r\n point.options.events &&\r\n point.options.events[eventType])\r\n ) {\r\n this.importEvents();\r\n }\r\n\r\n // add default handler if in selection mode\r\n if (eventType === \"click\" && seriesOptions.allowPointSelect) {\r\n defaultFunction = function(event) {\r\n // Control key is for Windows, meta (= Cmd key) for Mac, Shift for Opera\r\n point.select(null, event.ctrlKey || event.metaKey || event.shiftKey);\r\n };\r\n }\r\n\r\n fireEvent(this, eventType, eventArgs, defaultFunction);\r\n },\r\n /**\r\n * Import events from the series' and point's options. Only do it on\r\n * demand, to save processing time on hovering.\r\n */\r\n importEvents: function() {\r\n if (!this.hasImportedEvents) {\r\n var point = this,\r\n options = merge(point.series.options.point, point.options),\r\n events = options.events,\r\n eventType;\r\n\r\n point.events = events;\r\n\r\n for (eventType in events) {\r\n addEvent(point, eventType, events[eventType]);\r\n }\r\n this.hasImportedEvents = true;\r\n }\r\n },\r\n\r\n /**\r\n * Set the point's state\r\n * @param {String} state\r\n */\r\n setState: function(state) {\r\n var point = this,\r\n plotX = point.plotX,\r\n plotY = point.plotY,\r\n series = point.series,\r\n stateOptions = series.options.states,\r\n markerOptions =\r\n defaultPlotOptions[series.type].marker && series.options.marker,\r\n normalDisabled = markerOptions && !markerOptions.enabled,\r\n markerStateOptions = markerOptions && markerOptions.states[state],\r\n stateDisabled =\r\n markerStateOptions && markerStateOptions.enabled === false,\r\n stateMarkerGraphic = series.stateMarkerGraphic,\r\n chart = series.chart,\r\n radius,\r\n pointAttr = point.pointAttr;\r\n\r\n state = state || NORMAL_STATE; // empty string\r\n\r\n if (\r\n // already has this state\r\n state === point.state ||\r\n // selected points don't respond to hover\r\n (point.selected && state !== SELECT_STATE) ||\r\n // series' state options is disabled\r\n (stateOptions[state] && stateOptions[state].enabled === false) ||\r\n // point marker's state options is disabled\r\n (state &&\r\n (stateDisabled || (normalDisabled && !markerStateOptions.enabled)))\r\n ) {\r\n return;\r\n }\r\n\r\n // apply hover styles to the existing point\r\n if (point.graphic) {\r\n radius =\r\n markerOptions && point.graphic.symbolName && pointAttr[state].r;\r\n point.graphic.attr(\r\n merge(\r\n pointAttr[state],\r\n radius\r\n ? {\r\n // new symbol attributes (#507, #612)\r\n x: plotX - radius,\r\n y: plotY - radius,\r\n width: 2 * radius,\r\n height: 2 * radius\r\n }\r\n : {}\r\n )\r\n );\r\n }\r\n else {\r\n // if a graphic is not applied to each point in the normal state, create a shared\r\n // graphic for the hover state\r\n if (state && markerStateOptions) {\r\n radius = markerStateOptions.radius;\r\n if (!stateMarkerGraphic) {\r\n // add\r\n series.stateMarkerGraphic = stateMarkerGraphic = chart.renderer\r\n .symbol(\r\n series.symbol,\r\n plotX - radius,\r\n plotY - radius,\r\n 2 * radius,\r\n 2 * radius\r\n )\r\n .attr(pointAttr[state])\r\n .add(series.markerGroup);\r\n }\r\n else {\r\n // update\r\n stateMarkerGraphic.attr({\r\n // #1054\r\n x: plotX - radius,\r\n y: plotY - radius\r\n });\r\n }\r\n }\r\n\r\n if (stateMarkerGraphic) {\r\n stateMarkerGraphic[\r\n state && chart.isInsidePlot(plotX, plotY) ? \"show\" : \"hide\"\r\n ]();\r\n }\r\n }\r\n\r\n point.state = state;\r\n }\r\n };\r\n\r\n /**\r\n * @classDescription The base function which all other series types inherit from. The data in the series is stored\r\n * in various arrays.\r\n *\r\n * - First, series.options.data contains all the original config options for\r\n * each point whether added by options or methods like series.addPoint.\r\n * - Next, series.data contains those values converted to points, but in case the series data length\r\n * exceeds the cropThreshold, or if the data is grouped, series.data doesn't contain all the points. It\r\n * only contains the points that have been created on demand.\r\n * - Then there's series.points that contains all currently visible point objects. In case of cropping,\r\n * the cropped-away points are not part of this array. The series.points array starts at series.cropStart\r\n * compared to series.data and series.options.data. If however the series data is grouped, these can't\r\n * be correlated one to one.\r\n * - series.xData and series.processedXData contain clean x values, equivalent to series.data and series.points.\r\n * - series.yData and series.processedYData contain clean x values, equivalent to series.data and series.points.\r\n *\r\n * @param {Object} chart\r\n * @param {Object} options\r\n */\r\n var Series = function() {};\r\n\r\n Series.prototype = {\r\n isCartesian: true,\r\n type: \"line\",\r\n pointClass: Point,\r\n sorted: true, // requires the data to be sorted\r\n requireSorting: true,\r\n pointAttrToOptions: {\r\n // mapping between SVG attributes and the corresponding options\r\n stroke: \"lineColor\",\r\n \"stroke-width\": \"lineWidth\",\r\n fill: \"fillColor\",\r\n r: \"radius\"\r\n },\r\n init: function(chart, options) {\r\n var series = this,\r\n eventType,\r\n events;\r\n\r\n series.chart = chart;\r\n series.options = options = series.setOptions(options); // merge with plotOptions\r\n\r\n // bind the axes\r\n series.bindAxes();\r\n\r\n // set some variables\r\n extend(series, {\r\n name: options.name,\r\n state: NORMAL_STATE,\r\n pointAttr: {},\r\n visible: options.visible !== false, // true by default\r\n selected: options.selected === true // false by default\r\n });\r\n\r\n // special\r\n if (useCanVG) {\r\n options.animation = false;\r\n }\r\n\r\n // register event listeners\r\n events = options.events;\r\n for (eventType in events) {\r\n addEvent(series, eventType, events[eventType]);\r\n }\r\n if (\r\n (events && events.click) ||\r\n (options.point && options.point.events && options.point.events.click) ||\r\n options.allowPointSelect\r\n ) {\r\n chart.runTrackerClick = true;\r\n }\r\n\r\n series.getColor();\r\n series.getSymbol();\r\n\r\n // set the data\r\n series.setData(options.data, false);\r\n\r\n // Mark cartesian\r\n if (series.isCartesian) {\r\n chart.hasCartesianSeries = true;\r\n }\r\n\r\n // Register it in the chart\r\n chart.series.push(series);\r\n\r\n // Sort series according to index option (#248, #1123)\r\n stableSort(chart.series, function(a, b) {\r\n return (a.options.index || 0) - (b.options.index || 0);\r\n });\r\n each(chart.series, function(series, i) {\r\n series.index = i;\r\n series.name = series.name || \"Series \" + (i + 1);\r\n });\r\n },\r\n\r\n /**\r\n * Set the xAxis and yAxis properties of cartesian series, and register the series\r\n * in the axis.series array\r\n */\r\n bindAxes: function() {\r\n var series = this,\r\n seriesOptions = series.options,\r\n chart = series.chart,\r\n axisOptions;\r\n\r\n if (series.isCartesian) {\r\n each([\"xAxis\", \"yAxis\"], function(AXIS) {\r\n // repeat for xAxis and yAxis\r\n\r\n each(chart[AXIS], function(axis) {\r\n // loop through the chart's axis objects\r\n\r\n axisOptions = axis.options;\r\n\r\n // apply if the series xAxis or yAxis option mathches the number of the\r\n // axis, or if undefined, use the first axis\r\n if (\r\n seriesOptions[AXIS] === axisOptions.index ||\r\n (seriesOptions[AXIS] === UNDEFINED && axisOptions.index === 0)\r\n ) {\r\n // register this series in the axis.series lookup\r\n axis.series.push(series);\r\n\r\n // set this series.xAxis or series.yAxis reference\r\n series[AXIS] = axis;\r\n\r\n // mark dirty for redraw\r\n axis.isDirty = true;\r\n }\r\n });\r\n });\r\n }\r\n },\r\n\r\n /**\r\n * Return an auto incremented x value based on the pointStart and pointInterval options.\r\n * This is only used if an x value is not given for the point that calls autoIncrement.\r\n */\r\n autoIncrement: function() {\r\n var series = this,\r\n options = series.options,\r\n xIncrement = series.xIncrement;\r\n\r\n xIncrement = pick(xIncrement, options.pointStart, 0);\r\n\r\n series.pointInterval = pick(\r\n series.pointInterval,\r\n options.pointInterval,\r\n 1\r\n );\r\n\r\n series.xIncrement = xIncrement + series.pointInterval;\r\n return xIncrement;\r\n },\r\n\r\n /**\r\n * Divide the series data into segments divided by null values.\r\n */\r\n getSegments: function() {\r\n var series = this,\r\n lastNull = -1,\r\n segments = [],\r\n i,\r\n points = series.points,\r\n pointsLength = points.length;\r\n\r\n if (pointsLength) {\r\n // no action required for []\r\n\r\n // if connect nulls, just remove null points\r\n if (series.options.connectNulls) {\r\n i = pointsLength;\r\n while (i--) {\r\n if (points[i].y === null) {\r\n points.splice(i, 1);\r\n }\r\n }\r\n if (points.length) {\r\n segments = [points];\r\n }\r\n\r\n // else, split on null points\r\n }\r\n else {\r\n each(points, function(point, i) {\r\n if (point.y === null) {\r\n if (i > lastNull + 1) {\r\n segments.push(points.slice(lastNull + 1, i));\r\n }\r\n lastNull = i;\r\n }\r\n else if (i === pointsLength - 1) {\r\n // last value\r\n segments.push(points.slice(lastNull + 1, i + 1));\r\n }\r\n });\r\n }\r\n }\r\n\r\n // register it\r\n series.segments = segments;\r\n },\r\n /**\r\n * Set the series options by merging from the options tree\r\n * @param {Object} itemOptions\r\n */\r\n setOptions: function(itemOptions) {\r\n var chart = this.chart,\r\n chartOptions = chart.options,\r\n plotOptions = chartOptions.plotOptions,\r\n typeOptions = plotOptions[this.type],\r\n data = itemOptions.data,\r\n options;\r\n\r\n itemOptions.data = null; // remove from merge to prevent looping over the data set\r\n\r\n options = merge(typeOptions, plotOptions.series, itemOptions);\r\n\r\n // Re-insert the data array to the options and the original config (#717)\r\n options.data = itemOptions.data = data;\r\n\r\n // the tooltip options are merged between global and series specific options\r\n this.tooltipOptions = merge(chartOptions.tooltip, options.tooltip);\r\n\r\n // Delte marker object if not allowed (#1125)\r\n if (typeOptions.marker === null) {\r\n delete options.marker;\r\n }\r\n\r\n return options;\r\n },\r\n /**\r\n * Get the series' color\r\n */\r\n getColor: function() {\r\n var options = this.options,\r\n defaultColors = this.chart.options.colors,\r\n counters = this.chart.counters;\r\n this.color =\r\n options.color ||\r\n (!options.colorByPoint && defaultColors[counters.color++]) ||\r\n \"gray\";\r\n counters.wrapColor(defaultColors.length);\r\n },\r\n /**\r\n * Get the series' symbol\r\n */\r\n getSymbol: function() {\r\n var series = this,\r\n seriesMarkerOption = series.options.marker,\r\n chart = series.chart,\r\n defaultSymbols = chart.options.symbols,\r\n counters = chart.counters;\r\n series.symbol =\r\n seriesMarkerOption.symbol || defaultSymbols[counters.symbol++];\r\n\r\n // don't substract radius in image symbols (#604)\r\n if (/^url/.test(series.symbol)) {\r\n seriesMarkerOption.radius = 0;\r\n }\r\n counters.wrapSymbol(defaultSymbols.length);\r\n },\r\n\r\n /**\r\n * Get the series' symbol in the legend. This method should be overridable to create custom\r\n * symbols through Highcharts.seriesTypes[type].prototype.drawLegendSymbols.\r\n *\r\n * @param {Object} legend The legend object\r\n */\r\n drawLegendSymbol: function(legend) {\r\n var options = this.options,\r\n markerOptions = options.marker,\r\n radius,\r\n legendOptions = legend.options,\r\n legendSymbol,\r\n symbolWidth = legendOptions.symbolWidth,\r\n renderer = this.chart.renderer,\r\n legendItemGroup = this.legendGroup,\r\n baseline = legend.baseline,\r\n attr;\r\n\r\n // Draw the line\r\n if (options.lineWidth) {\r\n attr = {\r\n \"stroke-width\": options.lineWidth\r\n };\r\n if (options.dashStyle) {\r\n attr.dashstyle = options.dashStyle;\r\n }\r\n this.legendLine = renderer\r\n .path([M, 0, baseline - 4, L, symbolWidth, baseline - 4])\r\n .attr(attr)\r\n .add(legendItemGroup);\r\n }\r\n\r\n // Draw the marker\r\n if (markerOptions && markerOptions.enabled) {\r\n radius = markerOptions.radius;\r\n this.legendSymbol = legendSymbol = renderer\r\n .symbol(\r\n this.symbol,\r\n symbolWidth / 2 - radius,\r\n baseline - 4 - radius,\r\n 2 * radius,\r\n 2 * radius\r\n )\r\n .add(legendItemGroup);\r\n }\r\n },\r\n\r\n /**\r\n * Add a point dynamically after chart load time\r\n * @param {Object} options Point options as given in series.data\r\n * @param {Boolean} redraw Whether to redraw the chart or wait for an explicit call\r\n * @param {Boolean} shift If shift is true, a point is shifted off the start\r\n * of the series as one is appended to the end.\r\n * @param {Boolean|Object} animation Whether to apply animation, and optionally animation\r\n * configuration\r\n */\r\n addPoint: function(options, redraw, shift, animation) {\r\n var series = this,\r\n seriesOptions = series.options,\r\n data = series.data,\r\n graph = series.graph,\r\n area = series.area,\r\n chart = series.chart,\r\n xData = series.xData,\r\n yData = series.yData,\r\n currentShift = (graph && graph.shift) || 0,\r\n dataOptions = seriesOptions.data,\r\n point,\r\n proto = series.pointClass.prototype;\r\n\r\n setAnimation(animation, chart);\r\n\r\n // Make graph animate sideways\r\n if (graph && shift) {\r\n graph.shift = currentShift + 1;\r\n }\r\n if (area) {\r\n if (shift) {\r\n // #780\r\n area.shift = currentShift + 1;\r\n }\r\n area.isArea = true; // needed in animation, both with and without shift\r\n }\r\n\r\n // Optional redraw, defaults to true\r\n redraw = pick(redraw, true);\r\n\r\n // Get options and push the point to xData, yData and series.options. In series.generatePoints\r\n // the Point instance will be created on demand and pushed to the series.data array.\r\n point = { series: series };\r\n proto.applyOptions.apply(point, [options]);\r\n xData.push(point.x);\r\n yData.push(proto.toYData ? proto.toYData.call(point) : point.y);\r\n dataOptions.push(options);\r\n\r\n // Generate points to be added to the legend (#1329)\r\n if (seriesOptions.legendType === \"point\") {\r\n series.generatePoints();\r\n }\r\n\r\n // Shift the first point off the parallel arrays\r\n // todo: consider series.removePoint(i) method\r\n if (shift) {\r\n if (data[0] && data[0].remove) {\r\n data[0].remove(false);\r\n }\r\n else {\r\n data.shift();\r\n xData.shift();\r\n yData.shift();\r\n dataOptions.shift();\r\n }\r\n }\r\n series.getAttribs();\r\n\r\n // redraw\r\n series.isDirty = true;\r\n series.isDirtyData = true;\r\n if (redraw) {\r\n chart.redraw();\r\n }\r\n },\r\n\r\n /**\r\n * Replace the series data with a new set of data\r\n * @param {Object} data\r\n * @param {Object} redraw\r\n */\r\n setData: function(data, redraw) {\r\n var series = this,\r\n oldData = series.points,\r\n options = series.options,\r\n initialColor = series.initialColor,\r\n chart = series.chart,\r\n firstPoint = null,\r\n xAxis = series.xAxis,\r\n i,\r\n pointProto = series.pointClass.prototype;\r\n\r\n // reset properties\r\n series.xIncrement = null;\r\n series.pointRange = xAxis && xAxis.categories ? 1 : options.pointRange;\r\n\r\n if (defined(initialColor)) {\r\n // reset colors for pie\r\n chart.counters.color = initialColor;\r\n }\r\n\r\n // parallel arrays\r\n var xData = [],\r\n yData = [],\r\n dataLength = data ? data.length : [],\r\n turboThreshold = options.turboThreshold || 1000,\r\n pt,\r\n pointArrayMap = series.pointArrayMap,\r\n valueCount = pointArrayMap && pointArrayMap.length;\r\n\r\n // In turbo mode, only one- or twodimensional arrays of numbers are allowed. The\r\n // first value is tested, and we assume that all the rest are defined the same\r\n // way. Although the 'for' loops are similar, they are repeated inside each\r\n // if-else conditional for max performance.\r\n if (dataLength > turboThreshold) {\r\n // find the first non-null point\r\n i = 0;\r\n while (firstPoint === null && i < dataLength) {\r\n firstPoint = data[i];\r\n i++;\r\n }\r\n\r\n if (isNumber(firstPoint)) {\r\n // assume all points are numbers\r\n var x = pick(options.pointStart, 0),\r\n pointInterval = pick(options.pointInterval, 1);\r\n\r\n for (i = 0; i < dataLength; i++) {\r\n xData[i] = x;\r\n yData[i] = data[i];\r\n x += pointInterval;\r\n }\r\n series.xIncrement = x;\r\n }\r\n else if (isArray(firstPoint)) {\r\n // assume all points are arrays\r\n if (valueCount) {\r\n // [x, low, high] or [x, o, h, l, c]\r\n for (i = 0; i < dataLength; i++) {\r\n pt = data[i];\r\n xData[i] = pt[0];\r\n yData[i] = pt.slice(1, valueCount + 1);\r\n }\r\n }\r\n else {\r\n // [x, y]\r\n for (i = 0; i < dataLength; i++) {\r\n pt = data[i];\r\n xData[i] = pt[0];\r\n yData[i] = pt[1];\r\n }\r\n }\r\n } /* else {\r\n\t\t\t\terror(12); // Highcharts expects configs to be numbers or arrays in turbo mode\r\n\t\t\t}*/\r\n }\r\n else {\r\n for (i = 0; i < dataLength; i++) {\r\n pt = { series: series };\r\n pointProto.applyOptions.apply(pt, [data[i]]);\r\n xData[i] = pt.x;\r\n yData[i] = pointProto.toYData ? pointProto.toYData.call(pt) : pt.y;\r\n }\r\n }\r\n\r\n // Unsorted data is not supported by the line tooltip as well as data grouping and\r\n // navigation in Stock charts (#725)\r\n if (series.requireSorting && xData.length > 1 && xData[1] < xData[0]) {\r\n error(15);\r\n }\r\n\r\n // Forgetting to cast strings to numbers is a common caveat when handling CSV or JSON\r\n if (isString(yData[0])) {\r\n error(14, true);\r\n }\r\n\r\n series.data = [];\r\n series.options.data = data;\r\n series.xData = xData;\r\n series.yData = yData;\r\n\r\n // destroy old points\r\n i = (oldData && oldData.length) || 0;\r\n while (i--) {\r\n if (oldData[i] && oldData[i].destroy) {\r\n oldData[i].destroy();\r\n }\r\n }\r\n\r\n // reset minRange (#878)\r\n if (xAxis) {\r\n xAxis.minRange = xAxis.userMinRange;\r\n }\r\n\r\n // redraw\r\n series.isDirty = series.isDirtyData = chart.isDirtyBox = true;\r\n if (pick(redraw, true)) {\r\n chart.redraw(false);\r\n }\r\n },\r\n\r\n /**\r\n * Remove a series and optionally redraw the chart\r\n *\r\n * @param {Boolean} redraw Whether to redraw the chart or wait for an explicit call\r\n * @param {Boolean|Object} animation Whether to apply animation, and optionally animation\r\n * configuration\r\n */\r\n\r\n remove: function(redraw, animation) {\r\n var series = this,\r\n chart = series.chart;\r\n redraw = pick(redraw, true);\r\n\r\n if (!series.isRemoving) {\r\n /* prevent triggering native event in jQuery\r\n\t\t\t\t(calling the remove function from the remove event) */\r\n series.isRemoving = true;\r\n\r\n // fire the event with a default handler of removing the point\r\n fireEvent(series, \"remove\", null, function() {\r\n // destroy elements\r\n series.destroy();\r\n\r\n // redraw\r\n chart.isDirtyLegend = chart.isDirtyBox = true;\r\n if (redraw) {\r\n chart.redraw(animation);\r\n }\r\n });\r\n }\r\n series.isRemoving = false;\r\n },\r\n\r\n /**\r\n * Process the data by cropping away unused data points if the series is longer\r\n * than the crop threshold. This saves computing time for lage series.\r\n */\r\n processData: function(force) {\r\n var series = this,\r\n processedXData = series.xData, // copied during slice operation below\r\n processedYData = series.yData,\r\n dataLength = processedXData.length,\r\n cropStart = 0,\r\n cropEnd = dataLength,\r\n cropped,\r\n distance,\r\n closestPointRange,\r\n xAxis = series.xAxis,\r\n i, // loop variable\r\n options = series.options,\r\n cropThreshold = options.cropThreshold,\r\n isCartesian = series.isCartesian;\r\n\r\n // If the series data or axes haven't changed, don't go through this. Return false to pass\r\n // the message on to override methods like in data grouping.\r\n if (\r\n isCartesian &&\r\n !series.isDirty &&\r\n !xAxis.isDirty &&\r\n !series.yAxis.isDirty &&\r\n !force\r\n ) {\r\n return false;\r\n }\r\n\r\n // optionally filter out points outside the plot area\r\n if (\r\n isCartesian &&\r\n series.sorted &&\r\n (!cropThreshold || dataLength > cropThreshold || series.forceCrop)\r\n ) {\r\n var extremes = xAxis.getExtremes(),\r\n min = extremes.min,\r\n max = extremes.max;\r\n\r\n // it's outside current extremes\r\n if (processedXData[dataLength - 1] < min || processedXData[0] > max) {\r\n processedXData = [];\r\n processedYData = [];\r\n\r\n // only crop if it's actually spilling out\r\n }\r\n else if (\r\n processedXData[0] < min ||\r\n processedXData[dataLength - 1] > max\r\n ) {\r\n // iterate up to find slice start\r\n for (i = 0; i < dataLength; i++) {\r\n if (processedXData[i] >= min) {\r\n cropStart = mathMax(0, i - 1);\r\n break;\r\n }\r\n }\r\n // proceed to find slice end\r\n for (; i < dataLength; i++) {\r\n if (processedXData[i] > max) {\r\n cropEnd = i + 1;\r\n break;\r\n }\r\n }\r\n processedXData = processedXData.slice(cropStart, cropEnd);\r\n processedYData = processedYData.slice(cropStart, cropEnd);\r\n cropped = true;\r\n }\r\n }\r\n\r\n // Find the closest distance between processed points\r\n for (i = processedXData.length - 1; i > 0; i--) {\r\n distance = processedXData[i] - processedXData[i - 1];\r\n if (\r\n distance > 0 &&\r\n (closestPointRange === UNDEFINED || distance < closestPointRange)\r\n ) {\r\n closestPointRange = distance;\r\n }\r\n }\r\n\r\n // Record the properties\r\n series.cropped = cropped; // undefined or true\r\n series.cropStart = cropStart;\r\n series.processedXData = processedXData;\r\n series.processedYData = processedYData;\r\n\r\n if (options.pointRange === null) {\r\n // null means auto, as for columns, candlesticks and OHLC\r\n series.pointRange = closestPointRange || 1;\r\n }\r\n series.closestPointRange = closestPointRange;\r\n },\r\n\r\n /**\r\n * Generate the data point after the data has been processed by cropping away\r\n * unused points and optionally grouped in Highcharts Stock.\r\n */\r\n generatePoints: function() {\r\n var series = this,\r\n options = series.options,\r\n dataOptions = options.data,\r\n data = series.data,\r\n dataLength,\r\n processedXData = series.processedXData,\r\n processedYData = series.processedYData,\r\n pointClass = series.pointClass,\r\n processedDataLength = processedXData.length,\r\n cropStart = series.cropStart || 0,\r\n cursor,\r\n hasGroupedData = series.hasGroupedData,\r\n point,\r\n points = [],\r\n i;\r\n\r\n if (!data && !hasGroupedData) {\r\n var arr = [];\r\n arr.length = dataOptions.length;\r\n data = series.data = arr;\r\n }\r\n\r\n for (i = 0; i < processedDataLength; i++) {\r\n cursor = cropStart + i;\r\n if (!hasGroupedData) {\r\n if (data[cursor]) {\r\n point = data[cursor];\r\n }\r\n else if (dataOptions[cursor] !== UNDEFINED) {\r\n // #970\r\n data[cursor] = point = new pointClass().init(\r\n series,\r\n dataOptions[cursor],\r\n processedXData[i]\r\n );\r\n }\r\n points[i] = point;\r\n }\r\n else {\r\n // splat the y data in case of ohlc data array\r\n points[i] = new pointClass().init(\r\n series,\r\n [processedXData[i]].concat(splat(processedYData[i]))\r\n );\r\n }\r\n }\r\n\r\n // Hide cropped-away points - this only runs when the number of points is above cropThreshold, or when\r\n // swithching view from non-grouped data to grouped data (#637)\r\n if (\r\n data &&\r\n (processedDataLength !== (dataLength = data.length) || hasGroupedData)\r\n ) {\r\n for (i = 0; i < dataLength; i++) {\r\n if (i === cropStart && !hasGroupedData) {\r\n // when has grouped data, clear all points\r\n i += processedDataLength;\r\n }\r\n if (data[i]) {\r\n data[i].destroyElements();\r\n data[i].plotX = UNDEFINED; // #1003\r\n }\r\n }\r\n }\r\n\r\n series.data = data;\r\n series.points = points;\r\n },\r\n\r\n /**\r\n * Translate data points from raw data values to chart specific positioning data\r\n * needed later in drawPoints, drawGraph and drawTracker.\r\n */\r\n translate: function() {\r\n if (!this.processedXData) {\r\n // hidden series\r\n this.processData();\r\n }\r\n this.generatePoints();\r\n var series = this,\r\n chart = series.chart,\r\n options = series.options,\r\n stacking = options.stacking,\r\n xAxis = series.xAxis,\r\n categories = xAxis.categories,\r\n yAxis = series.yAxis,\r\n points = series.points,\r\n dataLength = points.length,\r\n hasModifyValue = !!series.modifyValue,\r\n isBottomSeries,\r\n allStackSeries = yAxis.series,\r\n i = allStackSeries.length,\r\n placeBetween = options.pointPlacement === \"between\";\r\n //nextSeriesDown;\r\n\r\n // Is it the last visible series?\r\n while (i--) {\r\n if (allStackSeries[i].visible) {\r\n if (allStackSeries[i] === series) {\r\n // #809\r\n isBottomSeries = true;\r\n }\r\n break;\r\n }\r\n }\r\n\r\n // Translate each point\r\n for (i = 0; i < dataLength; i++) {\r\n var point = points[i],\r\n xValue = point.x,\r\n yValue = point.y,\r\n yBottom = point.low,\r\n stack =\r\n yAxis.stacks[\r\n (yValue < options.threshold ? \"-\" : \"\") + series.stackKey\r\n ],\r\n pointStack,\r\n pointStackTotal;\r\n\r\n // get the plotX translation\r\n //point.plotX = mathRound(xAxis.translate(xValue, 0, 0, 0, 1) * 10) / 10; // Math.round fixes #591\r\n point.plotX = xAxis.translate(xValue, 0, 0, 0, 1, placeBetween); // Math.round fixes #591\r\n\r\n // calculate the bottom y value for stacked series\r\n if (stacking && series.visible && stack && stack[xValue]) {\r\n pointStack = stack[xValue];\r\n pointStackTotal = pointStack.total;\r\n pointStack.cum = yBottom = pointStack.cum - yValue; // start from top\r\n yValue = yBottom + yValue;\r\n\r\n if (isBottomSeries) {\r\n yBottom = pick(options.threshold, yAxis.min);\r\n }\r\n\r\n if (yAxis.isLog && yBottom <= 0) {\r\n // #1200, #1232\r\n yBottom = null;\r\n }\r\n\r\n if (stacking === \"percent\") {\r\n yBottom = pointStackTotal ? (yBottom * 100) / pointStackTotal : 0;\r\n yValue = pointStackTotal ? (yValue * 100) / pointStackTotal : 0;\r\n }\r\n\r\n point.percentage = pointStackTotal\r\n ? (point.y * 100) / pointStackTotal\r\n : 0;\r\n point.total = point.stackTotal = pointStackTotal;\r\n point.stackY = yValue;\r\n }\r\n\r\n // Set translated yBottom or remove it\r\n point.yBottom = defined(yBottom)\r\n ? yAxis.translate(yBottom, 0, 1, 0, 1)\r\n : null;\r\n\r\n // general hook, used for Highstock compare mode\r\n if (hasModifyValue) {\r\n yValue = series.modifyValue(yValue, point);\r\n }\r\n\r\n // Set the the plotY value, reset it for redraws\r\n point.plotY =\r\n typeof yValue === \"number\"\r\n ? mathRound(yAxis.translate(yValue, 0, 1, 0, 1) * 10) / 10 // Math.round fixes #591\r\n : UNDEFINED;\r\n\r\n // set client related positions for mouse tracking\r\n point.clientX = chart.inverted\r\n ? chart.plotHeight - point.plotX\r\n : point.plotX; // for mouse tracking\r\n\r\n // some API data\r\n point.category =\r\n categories && categories[point.x] !== UNDEFINED\r\n ? categories[point.x]\r\n : point.x;\r\n }\r\n\r\n // now that we have the cropped data, build the segments\r\n series.getSegments();\r\n },\r\n /**\r\n * Memoize tooltip texts and positions\r\n */\r\n setTooltipPoints: function(renew) {\r\n var series = this,\r\n points = [],\r\n pointsLength,\r\n low,\r\n high,\r\n xAxis = series.xAxis,\r\n axisLength = xAxis\r\n ? xAxis.tooltipLen || xAxis.len\r\n : series.chart.plotSizeX, // tooltipLen and tooltipPosName used in polar\r\n plotX = (xAxis && xAxis.tooltipPosName) || \"plotX\",\r\n point,\r\n i,\r\n tooltipPoints = []; // a lookup array for each pixel in the x dimension\r\n\r\n // don't waste resources if tracker is disabled\r\n if (series.options.enableMouseTracking === false) {\r\n return;\r\n }\r\n\r\n // renew\r\n if (renew) {\r\n series.tooltipPoints = null;\r\n }\r\n\r\n // concat segments to overcome null values\r\n each(series.segments || series.points, function(segment) {\r\n points = points.concat(segment);\r\n });\r\n\r\n // Reverse the points in case the X axis is reversed\r\n if (xAxis && xAxis.reversed) {\r\n points = points.reverse();\r\n }\r\n\r\n // Assign each pixel position to the nearest point\r\n pointsLength = points.length;\r\n for (i = 0; i < pointsLength; i++) {\r\n point = points[i];\r\n // Set this range's low to the last range's high plus one\r\n low = points[i - 1] ? high + 1 : 0;\r\n // Now find the new high\r\n high = points[i + 1]\r\n ? mathMax(\r\n 0,\r\n mathFloor(\r\n (point[plotX] +\r\n (points[i + 1] ? points[i + 1][plotX] : axisLength)) /\r\n 2\r\n )\r\n )\r\n : axisLength;\r\n\r\n while (low >= 0 && low <= high) {\r\n tooltipPoints[low++] = point;\r\n }\r\n }\r\n series.tooltipPoints = tooltipPoints;\r\n },\r\n\r\n /**\r\n * Format the header of the tooltip\r\n */\r\n tooltipHeaderFormatter: function(key) {\r\n var series = this,\r\n tooltipOptions = series.tooltipOptions,\r\n xDateFormat = tooltipOptions.xDateFormat,\r\n xAxis = series.xAxis,\r\n isDateTime = xAxis && xAxis.options.type === \"datetime\",\r\n n;\r\n\r\n // Guess the best date format based on the closest point distance (#568)\r\n if (isDateTime && !xDateFormat) {\r\n for (n in timeUnits) {\r\n if (timeUnits[n] >= xAxis.closestPointRange) {\r\n xDateFormat = tooltipOptions.dateTimeLabelFormats[n];\r\n break;\r\n }\r\n }\r\n }\r\n\r\n return tooltipOptions.headerFormat\r\n .replace(\r\n \"{point.key}\",\r\n isDateTime && isNumber(key) ? dateFormat(xDateFormat, key) : key\r\n )\r\n .replace(\"{series.name}\", series.name)\r\n .replace(\"{series.color}\", series.color);\r\n },\r\n\r\n /**\r\n * Series mouse over handler\r\n */\r\n onMouseOver: function() {\r\n var series = this,\r\n chart = series.chart,\r\n hoverSeries = chart.hoverSeries;\r\n\r\n // set normal state to previous series\r\n if (hoverSeries && hoverSeries !== series) {\r\n hoverSeries.onMouseOut();\r\n }\r\n\r\n // trigger the event, but to save processing time,\r\n // only if defined\r\n if (series.options.events.mouseOver) {\r\n fireEvent(series, \"mouseOver\");\r\n }\r\n\r\n // hover this\r\n series.setState(HOVER_STATE);\r\n chart.hoverSeries = series;\r\n },\r\n\r\n /**\r\n * Series mouse out handler\r\n */\r\n onMouseOut: function() {\r\n // trigger the event only if listeners exist\r\n var series = this,\r\n options = series.options,\r\n chart = series.chart,\r\n tooltip = chart.tooltip,\r\n hoverPoint = chart.hoverPoint;\r\n\r\n // trigger mouse out on the point, which must be in this series\r\n if (hoverPoint) {\r\n hoverPoint.onMouseOut();\r\n }\r\n\r\n // fire the mouse out event\r\n if (series && options.events.mouseOut) {\r\n fireEvent(series, \"mouseOut\");\r\n }\r\n\r\n // hide the tooltip\r\n if (tooltip && !options.stickyTracking && !tooltip.shared) {\r\n tooltip.hide();\r\n }\r\n\r\n // set normal state\r\n series.setState();\r\n chart.hoverSeries = null;\r\n },\r\n\r\n /**\r\n * Animate in the series\r\n */\r\n animate: function(init) {\r\n var series = this,\r\n chart = series.chart,\r\n renderer = chart.renderer,\r\n clipRect,\r\n markerClipRect,\r\n animation = series.options.animation,\r\n clipBox = chart.clipBox,\r\n inverted = chart.inverted,\r\n sharedClipKey;\r\n\r\n // Animation option is set to true\r\n if (animation && !isObject(animation)) {\r\n animation = defaultPlotOptions[series.type].animation;\r\n }\r\n sharedClipKey = \"_sharedClip\" + animation.duration + animation.easing;\r\n\r\n // Initialize the animation. Set up the clipping rectangle.\r\n if (init) {\r\n // If a clipping rectangle with the same properties is currently present in the chart, use that.\r\n clipRect = chart[sharedClipKey];\r\n markerClipRect = chart[sharedClipKey + \"m\"];\r\n if (!clipRect) {\r\n chart[sharedClipKey] = clipRect = renderer.clipRect(\r\n extend(clipBox, { width: 0 })\r\n );\r\n\r\n chart[sharedClipKey + \"m\"] = markerClipRect = renderer.clipRect(\r\n -99, // include the width of the first marker\r\n inverted ? -chart.plotLeft : -chart.plotTop,\r\n 99,\r\n inverted ? chart.chartWidth : chart.chartHeight\r\n );\r\n }\r\n series.group.clip(clipRect);\r\n series.markerGroup.clip(markerClipRect);\r\n series.sharedClipKey = sharedClipKey;\r\n\r\n // Run the animation\r\n }\r\n else {\r\n clipRect = chart[sharedClipKey];\r\n if (clipRect) {\r\n clipRect.animate(\r\n {\r\n width: chart.plotSizeX\r\n },\r\n animation\r\n );\r\n chart[sharedClipKey + \"m\"].animate(\r\n {\r\n width: chart.plotSizeX + 99\r\n },\r\n animation\r\n );\r\n }\r\n\r\n // Delete this function to allow it only once\r\n series.animate = null;\r\n\r\n // Call the afterAnimate function on animation complete (but don't overwrite the animation.complete option\r\n // which should be available to the user).\r\n series.animationTimeout = setTimeout(function() {\r\n series.afterAnimate();\r\n }, animation.duration);\r\n }\r\n },\r\n\r\n /**\r\n * This runs after animation to land on the final plot clipping\r\n */\r\n afterAnimate: function() {\r\n var chart = this.chart,\r\n sharedClipKey = this.sharedClipKey,\r\n group = this.group,\r\n trackerGroup = this.trackerGroup;\r\n\r\n if (group && this.options.clip !== false) {\r\n group.clip(chart.clipRect);\r\n if (trackerGroup) {\r\n trackerGroup.clip(chart.clipRect); // #484\r\n }\r\n this.markerGroup.clip(); // no clip\r\n }\r\n\r\n // Remove the shared clipping rectancgle when all series are shown\r\n setTimeout(function() {\r\n if (sharedClipKey && chart[sharedClipKey]) {\r\n chart[sharedClipKey] = chart[sharedClipKey].destroy();\r\n chart[sharedClipKey + \"m\"] = chart[sharedClipKey + \"m\"].destroy();\r\n }\r\n }, 100);\r\n },\r\n\r\n /**\r\n * Draw the markers\r\n */\r\n drawPoints: function() {\r\n var series = this,\r\n pointAttr,\r\n points = series.points,\r\n chart = series.chart,\r\n plotX,\r\n plotY,\r\n i,\r\n point,\r\n radius,\r\n symbol,\r\n isImage,\r\n graphic,\r\n options = series.options,\r\n seriesMarkerOptions = options.marker,\r\n pointMarkerOptions,\r\n enabled,\r\n isInside,\r\n markerGroup = series.markerGroup;\r\n\r\n if (seriesMarkerOptions.enabled || series._hasPointMarkers) {\r\n i = points.length;\r\n while (i--) {\r\n point = points[i];\r\n plotX = point.plotX;\r\n plotY = point.plotY;\r\n graphic = point.graphic;\r\n pointMarkerOptions = point.marker || {};\r\n enabled =\r\n (seriesMarkerOptions.enabled &&\r\n pointMarkerOptions.enabled === UNDEFINED) ||\r\n pointMarkerOptions.enabled;\r\n isInside = chart.isInsidePlot(plotX, plotY, chart.inverted);\r\n\r\n // only draw the point if y is defined\r\n if (enabled && plotY !== UNDEFINED && !isNaN(plotY)) {\r\n // shortcuts\r\n pointAttr =\r\n point.pointAttr[point.selected ? SELECT_STATE : NORMAL_STATE];\r\n radius = pointAttr.r;\r\n symbol = pick(pointMarkerOptions.symbol, series.symbol);\r\n isImage = symbol.indexOf(\"url\") === 0;\r\n\r\n if (graphic) {\r\n // update\r\n graphic\r\n .attr({\r\n // Since the marker group isn't clipped, each individual marker must be toggled\r\n visibility: isInside ? (hasSVG ? \"inherit\" : VISIBLE) : HIDDEN\r\n })\r\n .animate(\r\n extend(\r\n {\r\n x: plotX - radius,\r\n y: plotY - radius\r\n },\r\n graphic.symbolName\r\n ? {\r\n // don't apply to image symbols #507\r\n width: 2 * radius,\r\n height: 2 * radius\r\n }\r\n : {}\r\n )\r\n );\r\n }\r\n else if (isInside && (radius > 0 || isImage)) {\r\n point.graphic = graphic = chart.renderer\r\n .symbol(\r\n symbol,\r\n plotX - radius,\r\n plotY - radius,\r\n 2 * radius,\r\n 2 * radius\r\n )\r\n .attr(pointAttr)\r\n .add(markerGroup);\r\n }\r\n }\r\n else if (graphic) {\r\n point.graphic = graphic.destroy(); // #1269\r\n }\r\n }\r\n }\r\n },\r\n\r\n /**\r\n * Convert state properties from API naming conventions to SVG attributes\r\n *\r\n * @param {Object} options API options object\r\n * @param {Object} base1 SVG attribute object to inherit from\r\n * @param {Object} base2 Second level SVG attribute object to inherit from\r\n */\r\n convertAttribs: function(options, base1, base2, base3) {\r\n var conversion = this.pointAttrToOptions,\r\n attr,\r\n option,\r\n obj = {};\r\n\r\n options = options || {};\r\n base1 = base1 || {};\r\n base2 = base2 || {};\r\n base3 = base3 || {};\r\n\r\n for (attr in conversion) {\r\n option = conversion[attr];\r\n obj[attr] = pick(\r\n options[option],\r\n base1[attr],\r\n base2[attr],\r\n base3[attr]\r\n );\r\n }\r\n return obj;\r\n },\r\n\r\n /**\r\n * Get the state attributes. Each series type has its own set of attributes\r\n * that are allowed to change on a point's state change. Series wide attributes are stored for\r\n * all series, and additionally point specific attributes are stored for all\r\n * points with individual marker options. If such options are not defined for the point,\r\n * a reference to the series wide attributes is stored in point.pointAttr.\r\n */\r\n getAttribs: function() {\r\n var series = this,\r\n normalOptions = defaultPlotOptions[series.type].marker\r\n ? series.options.marker\r\n : series.options,\r\n stateOptions = normalOptions.states,\r\n stateOptionsHover = stateOptions[HOVER_STATE],\r\n pointStateOptionsHover,\r\n seriesColor = series.color,\r\n normalDefaults = {\r\n stroke: seriesColor,\r\n fill: seriesColor\r\n },\r\n points = series.points || [], // #927\r\n i,\r\n point,\r\n seriesPointAttr = [],\r\n pointAttr,\r\n pointAttrToOptions = series.pointAttrToOptions,\r\n hasPointSpecificOptions,\r\n key;\r\n\r\n // series type specific modifications\r\n if (series.options.marker) {\r\n // line, spline, area, areaspline, scatter\r\n\r\n // if no hover radius is given, default to normal radius + 2\r\n stateOptionsHover.radius =\r\n stateOptionsHover.radius || normalOptions.radius + 2;\r\n stateOptionsHover.lineWidth =\r\n stateOptionsHover.lineWidth || normalOptions.lineWidth + 1;\r\n }\r\n else {\r\n // column, bar, pie\r\n\r\n // if no hover color is given, brighten the normal color\r\n stateOptionsHover.color =\r\n stateOptionsHover.color ||\r\n Color(stateOptionsHover.color || seriesColor)\r\n .brighten(stateOptionsHover.brightness)\r\n .get();\r\n }\r\n\r\n // general point attributes for the series normal state\r\n seriesPointAttr[NORMAL_STATE] = series.convertAttribs(\r\n normalOptions,\r\n normalDefaults\r\n );\r\n\r\n // HOVER_STATE and SELECT_STATE states inherit from normal state except the default radius\r\n each([HOVER_STATE, SELECT_STATE], function(state) {\r\n seriesPointAttr[state] = series.convertAttribs(\r\n stateOptions[state],\r\n seriesPointAttr[NORMAL_STATE]\r\n );\r\n });\r\n\r\n // set it\r\n series.pointAttr = seriesPointAttr;\r\n\r\n // Generate the point-specific attribute collections if specific point\r\n // options are given. If not, create a referance to the series wide point\r\n // attributes\r\n i = points.length;\r\n while (i--) {\r\n point = points[i];\r\n normalOptions =\r\n (point.options && point.options.marker) || point.options;\r\n if (normalOptions && normalOptions.enabled === false) {\r\n normalOptions.radius = 0;\r\n }\r\n hasPointSpecificOptions = series.options.colorByPoint; // #868\r\n\r\n // check if the point has specific visual options\r\n if (point.options) {\r\n for (key in pointAttrToOptions) {\r\n if (defined(normalOptions[pointAttrToOptions[key]])) {\r\n hasPointSpecificOptions = true;\r\n }\r\n }\r\n }\r\n\r\n // a specific marker config object is defined for the individual point:\r\n // create it's own attribute collection\r\n if (hasPointSpecificOptions) {\r\n normalOptions = normalOptions || {};\r\n pointAttr = [];\r\n stateOptions = normalOptions.states || {}; // reassign for individual point\r\n pointStateOptionsHover = stateOptions[HOVER_STATE] =\r\n stateOptions[HOVER_STATE] || {};\r\n\r\n // Handle colors for column and pies\r\n if (!series.options.marker) {\r\n // column, bar, point\r\n // if no hover color is given, brighten the normal color\r\n pointStateOptionsHover.color = Color(\r\n pointStateOptionsHover.color || point.color\r\n )\r\n .brighten(\r\n pointStateOptionsHover.brightness ||\r\n stateOptionsHover.brightness\r\n )\r\n .get();\r\n }\r\n\r\n // normal point state inherits series wide normal state\r\n pointAttr[NORMAL_STATE] = series.convertAttribs(\r\n extend(\r\n {\r\n color: point.color // #868\r\n },\r\n normalOptions\r\n ),\r\n seriesPointAttr[NORMAL_STATE]\r\n );\r\n\r\n // inherit from point normal and series hover\r\n pointAttr[HOVER_STATE] = series.convertAttribs(\r\n stateOptions[HOVER_STATE],\r\n seriesPointAttr[HOVER_STATE],\r\n pointAttr[NORMAL_STATE]\r\n );\r\n // inherit from point normal and series hover\r\n pointAttr[SELECT_STATE] = series.convertAttribs(\r\n stateOptions[SELECT_STATE],\r\n seriesPointAttr[SELECT_STATE],\r\n pointAttr[NORMAL_STATE]\r\n );\r\n\r\n // no marker config object is created: copy a reference to the series-wide\r\n // attribute collection\r\n }\r\n else {\r\n pointAttr = seriesPointAttr;\r\n }\r\n\r\n point.pointAttr = pointAttr;\r\n }\r\n },\r\n\r\n /**\r\n * Clear DOM objects and free up memory\r\n */\r\n destroy: function() {\r\n var series = this,\r\n chart = series.chart,\r\n issue134 = /AppleWebKit\\/533/.test(userAgent),\r\n destroy,\r\n i,\r\n data = series.data || [],\r\n point,\r\n prop,\r\n axis;\r\n\r\n // add event hook\r\n fireEvent(series, \"destroy\");\r\n\r\n // remove all events\r\n removeEvent(series);\r\n\r\n // erase from axes\r\n each([\"xAxis\", \"yAxis\"], function(AXIS) {\r\n axis = series[AXIS];\r\n if (axis) {\r\n erase(axis.series, series);\r\n axis.isDirty = true;\r\n }\r\n });\r\n\r\n // remove legend items\r\n if (series.legendItem) {\r\n series.chart.legend.destroyItem(series);\r\n }\r\n\r\n // destroy all points with their elements\r\n i = data.length;\r\n while (i--) {\r\n point = data[i];\r\n if (point && point.destroy) {\r\n point.destroy();\r\n }\r\n }\r\n series.points = null;\r\n\r\n // Clear the animation timeout if we are destroying the series during initial animation\r\n clearTimeout(series.animationTimeout);\r\n\r\n // destroy all SVGElements associated to the series\r\n each(\r\n [\r\n \"area\",\r\n \"graph\",\r\n \"dataLabelsGroup\",\r\n \"group\",\r\n \"markerGroup\",\r\n \"tracker\",\r\n \"trackerGroup\"\r\n ],\r\n function(prop) {\r\n if (series[prop]) {\r\n // issue 134 workaround\r\n destroy = issue134 && prop === \"group\" ? \"hide\" : \"destroy\";\r\n\r\n series[prop][destroy]();\r\n }\r\n }\r\n );\r\n\r\n // remove from hoverSeries\r\n if (chart.hoverSeries === series) {\r\n chart.hoverSeries = null;\r\n }\r\n erase(chart.series, series);\r\n\r\n // clear all members\r\n for (prop in series) {\r\n delete series[prop];\r\n }\r\n },\r\n\r\n /**\r\n * Draw the data labels\r\n */\r\n drawDataLabels: function() {\r\n var series = this,\r\n seriesOptions = series.options,\r\n options = seriesOptions.dataLabels,\r\n points = series.points,\r\n pointOptions,\r\n generalOptions,\r\n str,\r\n dataLabelsGroup;\r\n\r\n if (options.enabled || series._hasPointLabels) {\r\n // Process default alignment of data labels for columns\r\n if (series.dlProcessOptions) {\r\n series.dlProcessOptions(options);\r\n }\r\n\r\n // Create a separate group for the data labels to avoid rotation\r\n dataLabelsGroup = series.plotGroup(\r\n \"dataLabelsGroup\",\r\n \"data-labels\",\r\n series.visible ? VISIBLE : HIDDEN,\r\n options.zIndex || 6\r\n );\r\n\r\n // Make the labels for each point\r\n generalOptions = options;\r\n each(points, function(point) {\r\n var enabled,\r\n dataLabel = point.dataLabel,\r\n attr,\r\n name,\r\n rotation,\r\n isNew = true;\r\n\r\n // Determine if each data label is enabled\r\n pointOptions = point.options && point.options.dataLabels;\r\n enabled =\r\n generalOptions.enabled || (pointOptions && pointOptions.enabled);\r\n\r\n // If the point is outside the plot area, destroy it. #678, #820\r\n if (dataLabel && !enabled) {\r\n point.dataLabel = dataLabel.destroy();\r\n\r\n // Individual labels are disabled if the are explicitly disabled\r\n // in the point options, or if they fall outside the plot area.\r\n }\r\n else if (enabled) {\r\n rotation = options.rotation;\r\n\r\n // Create individual options structure that can be extended without\r\n // affecting others\r\n options = merge(generalOptions, pointOptions);\r\n\r\n // Get the string\r\n str = options.formatter.call(point.getLabelConfig(), options);\r\n\r\n // Determine the color\r\n options.style.color = pick(\r\n options.color,\r\n options.style.color,\r\n series.color,\r\n \"black\"\r\n );\r\n\r\n // update existing label\r\n if (dataLabel) {\r\n // vertically centered\r\n dataLabel.attr({\r\n text: str\r\n });\r\n isNew = false;\r\n // create new label\r\n }\r\n else if (defined(str)) {\r\n attr = {\r\n //align: align,\r\n fill: options.backgroundColor,\r\n stroke: options.borderColor,\r\n \"stroke-width\": options.borderWidth,\r\n r: options.borderRadius || 0,\r\n rotation: rotation,\r\n padding: options.padding,\r\n zIndex: 1\r\n };\r\n // Remove unused attributes (#947)\r\n for (name in attr) {\r\n if (attr[name] === UNDEFINED) {\r\n delete attr[name];\r\n }\r\n }\r\n\r\n dataLabel = point.dataLabel = series.chart.renderer[\r\n rotation ? \"text\" : \"label\"\r\n ](\r\n // labels don't support rotation\r\n str,\r\n 0,\r\n -999,\r\n null,\r\n null,\r\n null,\r\n options.useHTML\r\n )\r\n .attr(attr)\r\n .css(options.style)\r\n .add(dataLabelsGroup)\r\n .shadow(options.shadow);\r\n }\r\n\r\n // Now the data label is created and placed at 0,0, so we need to align it\r\n if (dataLabel) {\r\n series.alignDataLabel(point, dataLabel, options, null, isNew);\r\n }\r\n }\r\n });\r\n }\r\n },\r\n\r\n /**\r\n * Align each individual data label\r\n */\r\n alignDataLabel: function(point, dataLabel, options, alignTo, isNew) {\r\n var chart = this.chart,\r\n inverted = chart.inverted,\r\n plotX = pick(point.plotX, -999),\r\n plotY = pick(point.plotY, -999),\r\n bBox = dataLabel.getBBox(),\r\n alignAttr; // the final position;\r\n\r\n // The alignment box is a singular point\r\n alignTo = extend(\r\n {\r\n x: inverted ? chart.plotWidth - plotY : plotX,\r\n y: mathRound(inverted ? chart.plotHeight - plotX : plotY),\r\n width: 0,\r\n height: 0\r\n },\r\n alignTo\r\n );\r\n\r\n // Add the text size for alignment calculation\r\n extend(options, {\r\n width: bBox.width,\r\n height: bBox.height\r\n });\r\n\r\n // Allow a hook for changing alignment in the last moment, then do the alignment\r\n if (options.rotation) {\r\n // Fancy box alignment isn't supported for rotated text\r\n alignAttr = {\r\n align: options.align,\r\n x: alignTo.x + options.x + alignTo.width / 2,\r\n y: alignTo.y + options.y + alignTo.height / 2\r\n };\r\n dataLabel[isNew ? \"attr\" : \"animate\"](alignAttr);\r\n }\r\n else {\r\n dataLabel.align(options, null, alignTo);\r\n alignAttr = dataLabel.alignAttr;\r\n }\r\n\r\n // Show or hide based on the final aligned position\r\n dataLabel.attr({\r\n visibility:\r\n options.crop === false ||\r\n chart.isInsidePlot(alignAttr.x, alignAttr.y) ||\r\n chart.isInsidePlot(plotX, plotY, inverted)\r\n ? chart.renderer.isSVG\r\n ? \"inherit\"\r\n : VISIBLE\r\n : HIDDEN\r\n });\r\n },\r\n\r\n /**\r\n * Return the graph path of a segment\r\n */\r\n getSegmentPath: function(segment) {\r\n var series = this,\r\n segmentPath = [],\r\n step = series.options.step;\r\n\r\n // build the segment line\r\n each(segment, function(point, i) {\r\n var plotX = point.plotX,\r\n plotY = point.plotY,\r\n lastPoint;\r\n\r\n if (series.getPointSpline) {\r\n // generate the spline as defined in the SplineSeries object\r\n segmentPath.push.apply(\r\n segmentPath,\r\n series.getPointSpline(segment, point, i)\r\n );\r\n }\r\n else {\r\n // moveTo or lineTo\r\n segmentPath.push(i ? L : M);\r\n\r\n // step line?\r\n if (step && i) {\r\n lastPoint = segment[i - 1];\r\n if (step === \"right\") {\r\n segmentPath.push(lastPoint.plotX, plotY);\r\n }\r\n else if (step === \"center\") {\r\n segmentPath.push(\r\n (lastPoint.plotX + plotX) / 2,\r\n lastPoint.plotY,\r\n (lastPoint.plotX + plotX) / 2,\r\n plotY\r\n );\r\n }\r\n else {\r\n segmentPath.push(plotX, lastPoint.plotY);\r\n }\r\n }\r\n\r\n // normal line to next point\r\n segmentPath.push(point.plotX, point.plotY);\r\n }\r\n });\r\n\r\n return segmentPath;\r\n },\r\n\r\n /**\r\n * Get the graph path\r\n */\r\n getGraphPath: function() {\r\n var series = this,\r\n graphPath = [],\r\n segmentPath,\r\n singlePoints = []; // used in drawTracker\r\n\r\n // Divide into segments and build graph and area paths\r\n each(series.segments, function(segment) {\r\n segmentPath = series.getSegmentPath(segment);\r\n\r\n // add the segment to the graph, or a single point for tracking\r\n if (segment.length > 1) {\r\n graphPath = graphPath.concat(segmentPath);\r\n }\r\n else {\r\n singlePoints.push(segment[0]);\r\n }\r\n });\r\n\r\n // Record it for use in drawGraph and drawTracker, and return graphPath\r\n series.singlePoints = singlePoints;\r\n series.graphPath = graphPath;\r\n\r\n return graphPath;\r\n },\r\n\r\n /**\r\n * Draw the actual graph\r\n */\r\n drawGraph: function() {\r\n var options = this.options,\r\n graph = this.graph,\r\n group = this.group,\r\n color = options.lineColor || this.color,\r\n lineWidth = options.lineWidth,\r\n dashStyle = options.dashStyle,\r\n attribs,\r\n graphPath = this.getGraphPath();\r\n\r\n // draw the graph\r\n if (graph) {\r\n stop(graph); // cancel running animations, #459\r\n graph.animate({ d: graphPath });\r\n }\r\n else {\r\n if (lineWidth) {\r\n attribs = {\r\n stroke: color,\r\n \"stroke-width\": lineWidth,\r\n zIndex: 1 // #1069\r\n };\r\n if (dashStyle) {\r\n attribs.dashstyle = dashStyle;\r\n }\r\n\r\n this.graph = this.chart.renderer\r\n .path(graphPath)\r\n .attr(attribs)\r\n .add(group)\r\n .shadow(options.shadow);\r\n }\r\n }\r\n },\r\n\r\n /**\r\n * Initialize and perform group inversion on series.group and series.trackerGroup\r\n */\r\n invertGroups: function() {\r\n var series = this,\r\n chart = series.chart;\r\n\r\n // A fixed size is needed for inversion to work\r\n function setInvert() {\r\n var size = {\r\n width: series.yAxis.len,\r\n height: series.xAxis.len\r\n };\r\n\r\n each([\"group\", \"trackerGroup\", \"markerGroup\"], function(groupName) {\r\n if (series[groupName]) {\r\n series[groupName].attr(size).invert();\r\n }\r\n });\r\n }\r\n\r\n addEvent(chart, \"resize\", setInvert); // do it on resize\r\n addEvent(series, \"destroy\", function() {\r\n removeEvent(chart, \"resize\", setInvert);\r\n });\r\n\r\n // Do it now\r\n setInvert(); // do it now\r\n\r\n // On subsequent render and redraw, just do setInvert without setting up events again\r\n series.invertGroups = setInvert;\r\n },\r\n\r\n /**\r\n * General abstraction for creating plot groups like series.group, series.trackerGroup, series.dataLabelsGroup and\r\n * series.markerGroup. On subsequent calls, the group will only be adjusted to the updated plot size.\r\n */\r\n plotGroup: function(prop, name, visibility, zIndex, parent) {\r\n var group = this[prop],\r\n chart = this.chart,\r\n xAxis = this.xAxis,\r\n yAxis = this.yAxis;\r\n\r\n // Generate it on first call\r\n if (!group) {\r\n this[prop] = group = chart.renderer\r\n .g(name)\r\n .attr({\r\n visibility: visibility,\r\n zIndex: zIndex || 0.1 // IE8 needs this\r\n })\r\n .add(parent);\r\n }\r\n // Place it on first and subsequent (redraw) calls\r\n group.translate(\r\n xAxis ? xAxis.left : chart.plotLeft,\r\n yAxis ? yAxis.top : chart.plotTop\r\n );\r\n\r\n return group;\r\n },\r\n\r\n /**\r\n * Render the graph and markers\r\n */\r\n render: function() {\r\n var series = this,\r\n chart = series.chart,\r\n group,\r\n options = series.options,\r\n animation = options.animation,\r\n doAnimation = animation && !!series.animate,\r\n visibility = series.visible ? VISIBLE : HIDDEN,\r\n zIndex = options.zIndex,\r\n hasRendered = series.hasRendered,\r\n chartSeriesGroup = chart.seriesGroup;\r\n\r\n // the group\r\n group = series.plotGroup(\r\n \"group\",\r\n \"series\",\r\n visibility,\r\n zIndex,\r\n chartSeriesGroup\r\n );\r\n\r\n series.markerGroup = series.plotGroup(\r\n \"markerGroup\",\r\n \"markers\",\r\n visibility,\r\n zIndex,\r\n chartSeriesGroup\r\n );\r\n\r\n // initiate the animation\r\n if (doAnimation) {\r\n series.animate(true);\r\n }\r\n\r\n // cache attributes for shapes\r\n series.getAttribs();\r\n\r\n // SVGRenderer needs to know this before drawing elements (#1089)\r\n group.inverted = chart.inverted;\r\n\r\n // draw the graph if any\r\n if (series.drawGraph) {\r\n series.drawGraph();\r\n }\r\n\r\n // draw the points\r\n series.drawPoints();\r\n\r\n // draw the data labels\r\n series.drawDataLabels();\r\n\r\n // draw the mouse tracking area\r\n if (series.options.enableMouseTracking !== false) {\r\n series.drawTracker();\r\n }\r\n\r\n // Handle inverted series and tracker groups\r\n if (chart.inverted) {\r\n series.invertGroups();\r\n }\r\n\r\n // Initial clipping, must be defined after inverting groups for VML\r\n if (options.clip !== false && !series.sharedClipKey && !hasRendered) {\r\n group.clip(chart.clipRect);\r\n if (this.trackerGroup) {\r\n this.trackerGroup.clip(chart.clipRect);\r\n }\r\n }\r\n\r\n // Run the animation\r\n if (doAnimation) {\r\n series.animate();\r\n }\r\n else if (!hasRendered) {\r\n series.afterAnimate();\r\n }\r\n\r\n series.isDirty = series.isDirtyData = false; // means data is in accordance with what you see\r\n // (See #322) series.isDirty = series.isDirtyData = false; // means data is in accordance with what you see\r\n series.hasRendered = true;\r\n },\r\n\r\n /**\r\n * Redraw the series after an update in the axes.\r\n */\r\n redraw: function() {\r\n var series = this,\r\n chart = series.chart,\r\n wasDirtyData = series.isDirtyData, // cache it here as it is set to false in render, but used after\r\n group = series.group;\r\n\r\n // reposition on resize\r\n if (group) {\r\n if (chart.inverted) {\r\n group.attr({\r\n width: chart.plotWidth,\r\n height: chart.plotHeight\r\n });\r\n }\r\n\r\n group.animate({\r\n translateX: series.xAxis.left,\r\n translateY: series.yAxis.top\r\n });\r\n }\r\n\r\n series.translate();\r\n series.setTooltipPoints(true);\r\n\r\n series.render();\r\n if (wasDirtyData) {\r\n fireEvent(series, \"updatedData\");\r\n }\r\n },\r\n\r\n /**\r\n * Set the state of the graph\r\n */\r\n setState: function(state) {\r\n var series = this,\r\n options = series.options,\r\n graph = series.graph,\r\n stateOptions = options.states,\r\n lineWidth = options.lineWidth;\r\n\r\n state = state || NORMAL_STATE;\r\n\r\n if (series.state !== state) {\r\n series.state = state;\r\n\r\n if (stateOptions[state] && stateOptions[state].enabled === false) {\r\n return;\r\n }\r\n\r\n if (state) {\r\n lineWidth = stateOptions[state].lineWidth || lineWidth + 1;\r\n }\r\n\r\n if (graph && !graph.dashstyle) {\r\n // hover is turned off for dashed lines in VML\r\n graph.attr(\r\n {\r\n // use attr because animate will cause any other animation on the graph to stop\r\n \"stroke-width\": lineWidth\r\n },\r\n state ? 0 : 500\r\n );\r\n }\r\n }\r\n },\r\n\r\n /**\r\n * Set the visibility of the graph\r\n *\r\n * @param vis {Boolean} True to show the series, false to hide. If UNDEFINED,\r\n * the visibility is toggled.\r\n */\r\n setVisible: function(vis, redraw) {\r\n var series = this,\r\n chart = series.chart,\r\n legendItem = series.legendItem,\r\n seriesGroup = series.group,\r\n seriesTracker = series.tracker,\r\n dataLabelsGroup = series.dataLabelsGroup,\r\n markerGroup = series.markerGroup,\r\n showOrHide,\r\n i,\r\n points = series.points,\r\n point,\r\n ignoreHiddenSeries = chart.options.chart.ignoreHiddenSeries,\r\n oldVisibility = series.visible;\r\n\r\n // if called without an argument, toggle visibility\r\n series.visible = vis = vis === UNDEFINED ? !oldVisibility : vis;\r\n showOrHide = vis ? \"show\" : \"hide\";\r\n\r\n // show or hide series\r\n if (seriesGroup) {\r\n // pies don't have one\r\n seriesGroup[showOrHide]();\r\n }\r\n if (markerGroup) {\r\n markerGroup[showOrHide]();\r\n }\r\n\r\n // show or hide trackers\r\n if (seriesTracker) {\r\n seriesTracker[showOrHide]();\r\n }\r\n else if (points) {\r\n i = points.length;\r\n while (i--) {\r\n point = points[i];\r\n if (point.tracker) {\r\n point.tracker[showOrHide]();\r\n }\r\n }\r\n }\r\n\r\n // hide tooltip (#1361)\r\n if (chart.hoverSeries === series) {\r\n series.onMouseOut();\r\n }\r\n\r\n if (dataLabelsGroup) {\r\n dataLabelsGroup[showOrHide]();\r\n }\r\n\r\n if (legendItem) {\r\n chart.legend.colorizeItem(series, vis);\r\n }\r\n\r\n // rescale or adapt to resized chart\r\n series.isDirty = true;\r\n // in a stack, all other series are affected\r\n if (series.options.stacking) {\r\n each(chart.series, function(otherSeries) {\r\n if (otherSeries.options.stacking && otherSeries.visible) {\r\n otherSeries.isDirty = true;\r\n }\r\n });\r\n }\r\n\r\n if (ignoreHiddenSeries) {\r\n chart.isDirtyBox = true;\r\n }\r\n if (redraw !== false) {\r\n chart.redraw();\r\n }\r\n\r\n fireEvent(series, showOrHide);\r\n },\r\n\r\n /**\r\n * Show the graph\r\n */\r\n show: function() {\r\n this.setVisible(true);\r\n },\r\n\r\n /**\r\n * Hide the graph\r\n */\r\n hide: function() {\r\n this.setVisible(false);\r\n },\r\n\r\n /**\r\n * Set the selected state of the graph\r\n *\r\n * @param selected {Boolean} True to select the series, false to unselect. If\r\n * UNDEFINED, the selection state is toggled.\r\n */\r\n select: function(selected) {\r\n var series = this;\r\n // if called without an argument, toggle\r\n series.selected = selected =\r\n selected === UNDEFINED ? !series.selected : selected;\r\n\r\n if (series.checkbox) {\r\n series.checkbox.checked = selected;\r\n }\r\n\r\n fireEvent(series, selected ? \"select\" : \"unselect\");\r\n },\r\n\r\n /**\r\n * Draw the tracker object that sits above all data labels and markers to\r\n * track mouse events on the graph or points. For the line type charts\r\n * the tracker uses the same graphPath, but with a greater stroke width\r\n * for better control.\r\n */\r\n drawTracker: function() {\r\n var series = this,\r\n options = series.options,\r\n trackByArea = options.trackByArea,\r\n trackerPath = [].concat(\r\n trackByArea ? series.areaPath : series.graphPath\r\n ),\r\n trackerPathLength = trackerPath.length,\r\n chart = series.chart,\r\n renderer = chart.renderer,\r\n snap = chart.options.tooltip.snap,\r\n tracker = series.tracker,\r\n cursor = options.cursor,\r\n css = cursor && { cursor: cursor },\r\n singlePoints = series.singlePoints,\r\n trackerGroup =\r\n this.isCartesian &&\r\n this.plotGroup(\r\n \"trackerGroup\",\r\n null,\r\n VISIBLE,\r\n options.zIndex || 1,\r\n chart.trackerGroup\r\n ),\r\n singlePoint,\r\n i,\r\n onMouseOver = function() {\r\n if (chart.hoverSeries !== series) {\r\n series.onMouseOver();\r\n }\r\n },\r\n onMouseOut = function() {\r\n if (!options.stickyTracking) {\r\n series.onMouseOut();\r\n }\r\n };\r\n\r\n // Extend end points. A better way would be to use round linecaps,\r\n // but those are not clickable in VML.\r\n if (trackerPathLength && !trackByArea) {\r\n i = trackerPathLength + 1;\r\n while (i--) {\r\n if (trackerPath[i] === M) {\r\n // extend left side\r\n trackerPath.splice(\r\n i + 1,\r\n 0,\r\n trackerPath[i + 1] - snap,\r\n trackerPath[i + 2],\r\n L\r\n );\r\n }\r\n if ((i && trackerPath[i] === M) || i === trackerPathLength) {\r\n // extend right side\r\n trackerPath.splice(\r\n i,\r\n 0,\r\n L,\r\n trackerPath[i - 2] + snap,\r\n trackerPath[i - 1]\r\n );\r\n }\r\n }\r\n }\r\n\r\n // handle single points\r\n for (i = 0; i < singlePoints.length; i++) {\r\n singlePoint = singlePoints[i];\r\n trackerPath.push(\r\n M,\r\n singlePoint.plotX - snap,\r\n singlePoint.plotY,\r\n L,\r\n singlePoint.plotX + snap,\r\n singlePoint.plotY\r\n );\r\n }\r\n\r\n // draw the tracker\r\n if (tracker) {\r\n tracker.attr({ d: trackerPath });\r\n }\r\n else {\r\n // create\r\n\r\n series.tracker = tracker = renderer\r\n .path(trackerPath)\r\n .attr({\r\n isTracker: true,\r\n \"stroke-linejoin\": \"round\", // #1225\r\n visibility: series.visible ? VISIBLE : HIDDEN,\r\n stroke: TRACKER_FILL,\r\n fill: trackByArea ? TRACKER_FILL : NONE,\r\n \"stroke-width\": options.lineWidth + (trackByArea ? 0 : 2 * snap)\r\n })\r\n .on(\"mouseover\", onMouseOver)\r\n .on(\"mouseout\", onMouseOut)\r\n .css(css)\r\n .add(trackerGroup);\r\n\r\n if (hasTouch) {\r\n tracker.on(\"touchstart\", onMouseOver);\r\n }\r\n }\r\n }\r\n }; // end Series prototype\r\n\r\n /**\r\n * LineSeries object\r\n */\r\n var LineSeries = extendClass(Series);\r\n seriesTypes.line = LineSeries;\r\n\r\n /**\r\n * Set the default options for area\r\n */\r\n defaultPlotOptions.area = merge(defaultSeriesOptions, {\r\n threshold: 0\r\n // trackByArea: false,\r\n // lineColor: null, // overrides color, but lets fillColor be unaltered\r\n // fillOpacity: 0.75,\r\n // fillColor: null\r\n });\r\n\r\n /**\r\n * AreaSeries object\r\n */\r\n var AreaSeries = extendClass(Series, {\r\n type: \"area\",\r\n\r\n /**\r\n * Extend the base Series getSegmentPath method by adding the path for the area.\r\n * This path is pushed to the series.areaPath property.\r\n */\r\n getSegmentPath: function(segment) {\r\n var segmentPath = Series.prototype.getSegmentPath.call(this, segment), // call base method\r\n areaSegmentPath = [].concat(segmentPath), // work on a copy for the area path\r\n i,\r\n options = this.options,\r\n segLength = segmentPath.length;\r\n\r\n if (segLength === 3) {\r\n // for animation from 1 to two points\r\n areaSegmentPath.push(L, segmentPath[1], segmentPath[2]);\r\n }\r\n if (options.stacking && !this.closedStacks) {\r\n // Follow stack back. Todo: implement areaspline. A general solution could be to\r\n // reverse the entire graphPath of the previous series, though may be hard with\r\n // splines and with series with different extremes\r\n for (i = segment.length - 1; i >= 0; i--) {\r\n // step line?\r\n if (i < segment.length - 1 && options.step) {\r\n areaSegmentPath.push(segment[i + 1].plotX, segment[i].yBottom);\r\n }\r\n\r\n areaSegmentPath.push(segment[i].plotX, segment[i].yBottom);\r\n }\r\n }\r\n else {\r\n // follow zero line back\r\n this.closeSegment(areaSegmentPath, segment);\r\n }\r\n this.areaPath = this.areaPath.concat(areaSegmentPath);\r\n\r\n return segmentPath;\r\n },\r\n\r\n /**\r\n * Extendable method to close the segment path of an area. This is overridden in polar\r\n * charts.\r\n */\r\n closeSegment: function(path, segment) {\r\n var translatedThreshold = this.yAxis.getThreshold(this.options.threshold);\r\n path.push(\r\n L,\r\n segment[segment.length - 1].plotX,\r\n translatedThreshold,\r\n L,\r\n segment[0].plotX,\r\n translatedThreshold\r\n );\r\n },\r\n\r\n /**\r\n * Draw the graph and the underlying area. This method calls the Series base\r\n * function and adds the area. The areaPath is calculated in the getSegmentPath\r\n * method called from Series.prototype.drawGraph.\r\n */\r\n drawGraph: function() {\r\n // Define or reset areaPath\r\n this.areaPath = [];\r\n\r\n // Call the base method\r\n Series.prototype.drawGraph.apply(this);\r\n\r\n // Define local variables\r\n var areaPath = this.areaPath,\r\n options = this.options,\r\n area = this.area;\r\n\r\n // Create or update the area\r\n if (area) {\r\n // update\r\n area.animate({ d: areaPath });\r\n }\r\n else {\r\n // create\r\n this.area = this.chart.renderer\r\n .path(areaPath)\r\n .attr({\r\n fill: pick(\r\n options.fillColor,\r\n Color(this.color)\r\n .setOpacity(options.fillOpacity || 0.75)\r\n .get()\r\n ),\r\n zIndex: 0 // #1069\r\n })\r\n .add(this.group);\r\n }\r\n },\r\n\r\n /**\r\n * Get the series' symbol in the legend\r\n *\r\n * @param {Object} legend The legend object\r\n * @param {Object} item The series (this) or point\r\n */\r\n drawLegendSymbol: function(legend, item) {\r\n item.legendSymbol = this.chart.renderer\r\n .rect(0, legend.baseline - 11, legend.options.symbolWidth, 12, 2)\r\n .attr({\r\n zIndex: 3\r\n })\r\n .add(item.legendGroup);\r\n }\r\n });\r\n\r\n seriesTypes.area = AreaSeries;\r\n /**\r\n * Set the default options for spline\r\n */\r\n defaultPlotOptions.spline = merge(defaultSeriesOptions);\r\n\r\n /**\r\n * SplineSeries object\r\n */\r\n var SplineSeries = extendClass(Series, {\r\n type: \"spline\",\r\n\r\n /**\r\n * Get the spline segment from a given point's previous neighbour to the given point\r\n */\r\n getPointSpline: function(segment, point, i) {\r\n var smoothing = 1.5, // 1 means control points midway between points, 2 means 1/3 from the point, 3 is 1/4 etc\r\n denom = smoothing + 1,\r\n plotX = point.plotX,\r\n plotY = point.plotY,\r\n lastPoint = segment[i - 1],\r\n nextPoint = segment[i + 1],\r\n leftContX,\r\n leftContY,\r\n rightContX,\r\n rightContY,\r\n ret;\r\n\r\n // find control points\r\n if (lastPoint && nextPoint) {\r\n var lastX = lastPoint.plotX,\r\n lastY = lastPoint.plotY,\r\n nextX = nextPoint.plotX,\r\n nextY = nextPoint.plotY,\r\n correction;\r\n\r\n leftContX = (smoothing * plotX + lastX) / denom;\r\n leftContY = (smoothing * plotY + lastY) / denom;\r\n rightContX = (smoothing * plotX + nextX) / denom;\r\n rightContY = (smoothing * plotY + nextY) / denom;\r\n\r\n // have the two control points make a straight line through main point\r\n correction =\r\n ((rightContY - leftContY) * (rightContX - plotX)) /\r\n (rightContX - leftContX) +\r\n plotY -\r\n rightContY;\r\n\r\n leftContY += correction;\r\n rightContY += correction;\r\n\r\n // to prevent false extremes, check that control points are between\r\n // neighbouring points' y values\r\n if (leftContY > lastY && leftContY > plotY) {\r\n leftContY = mathMax(lastY, plotY);\r\n rightContY = 2 * plotY - leftContY; // mirror of left control point\r\n }\r\n else if (leftContY < lastY && leftContY < plotY) {\r\n leftContY = mathMin(lastY, plotY);\r\n rightContY = 2 * plotY - leftContY;\r\n }\r\n if (rightContY > nextY && rightContY > plotY) {\r\n rightContY = mathMax(nextY, plotY);\r\n leftContY = 2 * plotY - rightContY;\r\n }\r\n else if (rightContY < nextY && rightContY < plotY) {\r\n rightContY = mathMin(nextY, plotY);\r\n leftContY = 2 * plotY - rightContY;\r\n }\r\n\r\n // record for drawing in next point\r\n point.rightContX = rightContX;\r\n point.rightContY = rightContY;\r\n }\r\n\r\n // Visualize control points for debugging\r\n /*\r\n\t\tif (leftContX) {\r\n\t\t\tthis.chart.renderer.circle(leftContX + this.chart.plotLeft, leftContY + this.chart.plotTop, 2)\r\n\t\t\t\t.attr({\r\n\t\t\t\t\tstroke: 'red',\r\n\t\t\t\t\t'stroke-width': 1,\r\n\t\t\t\t\tfill: 'none'\r\n\t\t\t\t})\r\n\t\t\t\t.add();\r\n\t\t\tthis.chart.renderer.path(['M', leftContX + this.chart.plotLeft, leftContY + this.chart.plotTop,\r\n\t\t\t\t'L', plotX + this.chart.plotLeft, plotY + this.chart.plotTop])\r\n\t\t\t\t.attr({\r\n\t\t\t\t\tstroke: 'red',\r\n\t\t\t\t\t'stroke-width': 1\r\n\t\t\t\t})\r\n\t\t\t\t.add();\r\n\t\t\tthis.chart.renderer.circle(rightContX + this.chart.plotLeft, rightContY + this.chart.plotTop, 2)\r\n\t\t\t\t.attr({\r\n\t\t\t\t\tstroke: 'green',\r\n\t\t\t\t\t'stroke-width': 1,\r\n\t\t\t\t\tfill: 'none'\r\n\t\t\t\t})\r\n\t\t\t\t.add();\r\n\t\t\tthis.chart.renderer.path(['M', rightContX + this.chart.plotLeft, rightContY + this.chart.plotTop,\r\n\t\t\t\t'L', plotX + this.chart.plotLeft, plotY + this.chart.plotTop])\r\n\t\t\t\t.attr({\r\n\t\t\t\t\tstroke: 'green',\r\n\t\t\t\t\t'stroke-width': 1\r\n\t\t\t\t})\r\n\t\t\t\t.add();\r\n\t\t}\r\n\t\t// */\r\n\r\n // moveTo or lineTo\r\n if (!i) {\r\n ret = [M, plotX, plotY];\r\n }\r\n else {\r\n // curve from last point to this\r\n ret = [\r\n \"C\",\r\n lastPoint.rightContX || lastPoint.plotX,\r\n lastPoint.rightContY || lastPoint.plotY,\r\n leftContX || plotX,\r\n leftContY || plotY,\r\n plotX,\r\n plotY\r\n ];\r\n lastPoint.rightContX = lastPoint.rightContY = null; // reset for updating series later\r\n }\r\n return ret;\r\n }\r\n });\r\n seriesTypes.spline = SplineSeries;\r\n\r\n /**\r\n * Set the default options for areaspline\r\n */\r\n defaultPlotOptions.areaspline = merge(defaultPlotOptions.area);\r\n\r\n /**\r\n * AreaSplineSeries object\r\n */\r\n var areaProto = AreaSeries.prototype,\r\n AreaSplineSeries = extendClass(SplineSeries, {\r\n type: \"areaspline\",\r\n closedStacks: true, // instead of following the previous graph back, follow the threshold back\r\n\r\n // Mix in methods from the area series\r\n getSegmentPath: areaProto.getSegmentPath,\r\n closeSegment: areaProto.closeSegment,\r\n drawGraph: areaProto.drawGraph\r\n });\r\n seriesTypes.areaspline = AreaSplineSeries;\r\n\r\n /**\r\n * Set the default options for column\r\n */\r\n defaultPlotOptions.column = merge(defaultSeriesOptions, {\r\n borderColor: \"#FFFFFF\",\r\n borderWidth: 1,\r\n borderRadius: 0,\r\n //colorByPoint: undefined,\r\n groupPadding: 0.2,\r\n //grouping: true,\r\n marker: null, // point options are specified in the base options\r\n pointPadding: 0.1,\r\n //pointWidth: null,\r\n minPointLength: 0,\r\n cropThreshold: 50, // when there are more points, they will not animate out of the chart on xAxis.setExtremes\r\n pointRange: null, // null means auto, meaning 1 in a categorized axis and least distance between points if not categories\r\n states: {\r\n hover: {\r\n brightness: 0.1,\r\n shadow: false\r\n },\r\n select: {\r\n color: \"#C0C0C0\",\r\n borderColor: \"#000000\",\r\n shadow: false\r\n }\r\n },\r\n dataLabels: {\r\n align: null, // auto\r\n verticalAlign: null, // auto\r\n y: null\r\n },\r\n threshold: 0\r\n });\r\n\r\n /**\r\n * ColumnSeries object\r\n */\r\n var ColumnSeries = extendClass(Series, {\r\n type: \"column\",\r\n tooltipOutsidePlot: true,\r\n pointAttrToOptions: {\r\n // mapping between SVG attributes and the corresponding options\r\n stroke: \"borderColor\",\r\n \"stroke-width\": \"borderWidth\",\r\n fill: \"color\",\r\n r: \"borderRadius\"\r\n },\r\n\r\n /**\r\n * Initialize the series\r\n */\r\n init: function() {\r\n Series.prototype.init.apply(this, arguments);\r\n\r\n var series = this,\r\n chart = series.chart;\r\n\r\n // if the series is added dynamically, force redraw of other\r\n // series affected by a new column\r\n if (chart.hasRendered) {\r\n each(chart.series, function(otherSeries) {\r\n if (otherSeries.type === series.type) {\r\n otherSeries.isDirty = true;\r\n }\r\n });\r\n }\r\n },\r\n\r\n /**\r\n * Translate each point to the plot area coordinate system and find shape positions\r\n */\r\n translate: function() {\r\n var series = this,\r\n chart = series.chart,\r\n options = series.options,\r\n stacking = options.stacking,\r\n borderWidth = options.borderWidth,\r\n columnCount = 0,\r\n xAxis = series.xAxis,\r\n yAxis = series.yAxis,\r\n reversedXAxis = xAxis.reversed,\r\n stackGroups = {},\r\n stackKey,\r\n columnIndex;\r\n\r\n Series.prototype.translate.apply(series);\r\n\r\n // Get the total number of column type series.\r\n // This is called on every series. Consider moving this logic to a\r\n // chart.orderStacks() function and call it on init, addSeries and removeSeries\r\n if (options.grouping === false) {\r\n columnCount = 1;\r\n }\r\n else {\r\n each(chart.series, function(otherSeries) {\r\n var otherOptions = otherSeries.options;\r\n if (\r\n otherSeries.type === series.type &&\r\n otherSeries.visible &&\r\n series.options.group === otherOptions.group\r\n ) {\r\n // used in Stock charts navigator series\r\n if (otherOptions.stacking) {\r\n stackKey = otherSeries.stackKey;\r\n if (stackGroups[stackKey] === UNDEFINED) {\r\n stackGroups[stackKey] = columnCount++;\r\n }\r\n columnIndex = stackGroups[stackKey];\r\n }\r\n else if (otherOptions.grouping !== false) {\r\n // #1162\r\n columnIndex = columnCount++;\r\n }\r\n otherSeries.columnIndex = columnIndex;\r\n }\r\n });\r\n }\r\n\r\n // calculate the width and position of each column based on\r\n // the number of column series in the plot, the groupPadding\r\n // and the pointPadding options\r\n var points = series.points,\r\n categoryWidth =\r\n mathAbs(xAxis.transA) *\r\n (xAxis.ordinalSlope ||\r\n options.pointRange ||\r\n xAxis.closestPointRange ||\r\n 1),\r\n groupPadding = categoryWidth * options.groupPadding,\r\n groupWidth = categoryWidth - 2 * groupPadding,\r\n pointOffsetWidth = groupWidth / columnCount,\r\n optionPointWidth = options.pointWidth,\r\n pointPadding = defined(optionPointWidth)\r\n ? (pointOffsetWidth - optionPointWidth) / 2\r\n : pointOffsetWidth * options.pointPadding,\r\n pointWidth = pick(\r\n optionPointWidth,\r\n pointOffsetWidth - 2 * pointPadding\r\n ), // exact point width, used in polar charts\r\n barW = mathCeil(mathMax(pointWidth, 1 + 2 * borderWidth)), // rounded and postprocessed for border width\r\n colIndex =\r\n (reversedXAxis\r\n ? columnCount - (series.columnIndex || 0) // #1251\r\n : series.columnIndex) || 0,\r\n pointXOffset =\r\n pointPadding +\r\n (groupPadding + colIndex * pointOffsetWidth - categoryWidth / 2) *\r\n (reversedXAxis ? -1 : 1),\r\n threshold = options.threshold,\r\n translatedThreshold = (series.translatedThreshold = yAxis.getThreshold(\r\n threshold\r\n )),\r\n minPointLength = pick(options.minPointLength, 5);\r\n\r\n // record the new values\r\n each(points, function(point) {\r\n var plotY = mathMin(mathMax(-999, point.plotY), yAxis.len + 999), // Don't draw too far outside plot area (#1303)\r\n yBottom = pick(point.yBottom, translatedThreshold),\r\n barX = point.plotX + pointXOffset,\r\n barY = mathCeil(mathMin(plotY, yBottom)),\r\n barH = mathCeil(mathMax(plotY, yBottom) - barY),\r\n stack = yAxis.stacks[(point.y < 0 ? \"-\" : \"\") + series.stackKey],\r\n shapeArgs;\r\n\r\n // Record the offset'ed position and width of the bar to be able to align the stacking total correctly\r\n if (stacking && series.visible && stack && stack[point.x]) {\r\n stack[point.x].setOffset(pointXOffset, barW);\r\n }\r\n\r\n // handle options.minPointLength\r\n if (mathAbs(barH) < minPointLength) {\r\n if (minPointLength) {\r\n barH = minPointLength;\r\n barY =\r\n mathAbs(barY - translatedThreshold) > minPointLength // stacked\r\n ? yBottom - minPointLength // keep position\r\n : translatedThreshold -\r\n (plotY <= translatedThreshold ? minPointLength : 0);\r\n }\r\n }\r\n\r\n point.barX = barX;\r\n point.pointWidth = pointWidth;\r\n\r\n // create shape type and shape args that are reused in drawPoints and drawTracker\r\n point.shapeType = \"rect\";\r\n point.shapeArgs = shapeArgs = chart.renderer.Element.prototype.crisp.call(\r\n 0,\r\n borderWidth,\r\n barX,\r\n barY,\r\n barW,\r\n barH\r\n );\r\n\r\n if (borderWidth % 2) {\r\n // correct for shorting in crisp method, visible in stacked columns with 1px border\r\n shapeArgs.y -= 1;\r\n shapeArgs.height += 1;\r\n }\r\n\r\n // make small columns responsive to mouse\r\n point.trackerArgs =\r\n mathAbs(barH) < 3 &&\r\n merge(point.shapeArgs, {\r\n height: 6,\r\n y: barY - 3\r\n });\r\n });\r\n },\r\n\r\n getSymbol: noop,\r\n\r\n /**\r\n * Use a solid rectangle like the area series types\r\n */\r\n drawLegendSymbol: AreaSeries.prototype.drawLegendSymbol,\r\n\r\n /**\r\n * Columns have no graph\r\n */\r\n drawGraph: noop,\r\n\r\n /**\r\n * Draw the columns. For bars, the series.group is rotated, so the same coordinates\r\n * apply for columns and bars. This method is inherited by scatter series.\r\n *\r\n */\r\n drawPoints: function() {\r\n var series = this,\r\n options = series.options,\r\n renderer = series.chart.renderer,\r\n shapeArgs;\r\n\r\n // draw the columns\r\n each(series.points, function(point) {\r\n var plotY = point.plotY,\r\n graphic = point.graphic;\r\n if (plotY !== UNDEFINED && !isNaN(plotY) && point.y !== null) {\r\n shapeArgs = point.shapeArgs;\r\n if (graphic) {\r\n // update\r\n stop(graphic);\r\n graphic.animate(merge(shapeArgs));\r\n }\r\n else {\r\n point.graphic = graphic = renderer[point.shapeType](shapeArgs)\r\n .attr(\r\n point.pointAttr[point.selected ? SELECT_STATE : NORMAL_STATE]\r\n )\r\n .add(series.group)\r\n .shadow(\r\n options.shadow,\r\n null,\r\n options.stacking && !options.borderRadius\r\n );\r\n }\r\n }\r\n else if (graphic) {\r\n point.graphic = graphic.destroy(); // #1269\r\n }\r\n });\r\n },\r\n /**\r\n * Draw the individual tracker elements.\r\n * This method is inherited by pie charts too.\r\n */\r\n drawTracker: function() {\r\n var series = this,\r\n chart = series.chart,\r\n renderer = chart.renderer,\r\n shapeArgs,\r\n tracker,\r\n trackerLabel = +new Date(),\r\n options = series.options,\r\n cursor = options.cursor,\r\n css = cursor && { cursor: cursor },\r\n trackerGroup =\r\n series.isCartesian &&\r\n series.plotGroup(\r\n \"trackerGroup\",\r\n null,\r\n VISIBLE,\r\n options.zIndex || 1,\r\n chart.trackerGroup\r\n ),\r\n rel,\r\n plotY,\r\n validPlotY,\r\n points = series.points,\r\n point,\r\n i = points.length,\r\n onMouseOver = function(event) {\r\n rel = event.relatedTarget || event.fromElement;\r\n if (\r\n chart.hoverSeries !== series &&\r\n attr(rel, \"isTracker\") !== trackerLabel\r\n ) {\r\n series.onMouseOver();\r\n }\r\n points[event.target._i].onMouseOver();\r\n },\r\n onMouseOut = function(event) {\r\n if (!options.stickyTracking) {\r\n rel = event.relatedTarget || event.toElement;\r\n if (attr(rel, \"isTracker\") !== trackerLabel) {\r\n series.onMouseOut();\r\n }\r\n }\r\n };\r\n\r\n while (i--) {\r\n point = points[i];\r\n tracker = point.tracker;\r\n shapeArgs = point.trackerArgs || point.shapeArgs;\r\n plotY = point.plotY;\r\n validPlotY =\r\n !series.isCartesian || (plotY !== UNDEFINED && !isNaN(plotY));\r\n delete shapeArgs.strokeWidth;\r\n if (point.y !== null && validPlotY) {\r\n if (tracker) {\r\n // update\r\n tracker.attr(shapeArgs);\r\n }\r\n else {\r\n point.tracker = tracker = renderer[point.shapeType](shapeArgs)\r\n .attr({\r\n isTracker: trackerLabel,\r\n fill: TRACKER_FILL,\r\n visibility: series.visible ? VISIBLE : HIDDEN\r\n })\r\n .on(\"mouseover\", onMouseOver)\r\n .on(\"mouseout\", onMouseOut)\r\n .css(css)\r\n .add(point.group || trackerGroup); // pies have point group - see issue #118\r\n\r\n if (hasTouch) {\r\n tracker.on(\"touchstart\", onMouseOver);\r\n }\r\n }\r\n tracker.element._i = i;\r\n }\r\n }\r\n },\r\n\r\n /**\r\n * Override the basic data label alignment by adjusting for the position of the column\r\n */\r\n alignDataLabel: function(point, dataLabel, options, alignTo, isNew) {\r\n var chart = this.chart,\r\n inverted = chart.inverted,\r\n below =\r\n point.below ||\r\n point.plotY > pick(this.translatedThreshold, chart.plotSizeY),\r\n inside = this.options.stacking || options.inside; // draw it inside the box?\r\n\r\n // Align to the column itself, or the top of it\r\n if (point.shapeArgs) {\r\n // Area range uses this method but not alignTo\r\n alignTo = merge(point.shapeArgs);\r\n if (inverted) {\r\n alignTo = {\r\n x: chart.plotWidth - alignTo.y - alignTo.height,\r\n y: chart.plotHeight - alignTo.x - alignTo.width,\r\n width: alignTo.height,\r\n height: alignTo.width\r\n };\r\n }\r\n\r\n // Compute the alignment box\r\n if (!inside) {\r\n if (inverted) {\r\n alignTo.x += below ? 0 : alignTo.width;\r\n alignTo.width = 0;\r\n }\r\n else {\r\n alignTo.y += below ? alignTo.height : 0;\r\n alignTo.height = 0;\r\n }\r\n }\r\n }\r\n\r\n // When alignment is undefined (typically columns and bars), display the individual\r\n // point below or above the point depending on the threshold\r\n options.align = pick(\r\n options.align,\r\n !inverted || inside ? \"center\" : below ? \"right\" : \"left\"\r\n );\r\n options.verticalAlign = pick(\r\n options.verticalAlign,\r\n inverted || inside ? \"middle\" : below ? \"top\" : \"bottom\"\r\n );\r\n\r\n // Call the parent method\r\n Series.prototype.alignDataLabel.call(\r\n this,\r\n point,\r\n dataLabel,\r\n options,\r\n alignTo,\r\n isNew\r\n );\r\n },\r\n\r\n /**\r\n * Animate the column heights one by one from zero\r\n * @param {Boolean} init Whether to initialize the animation or run it\r\n */\r\n animate: function(init) {\r\n var series = this,\r\n points = series.points,\r\n options = series.options;\r\n\r\n if (!init) {\r\n // run the animation\r\n /*\r\n * Note: Ideally the animation should be initialized by calling\r\n * series.group.hide(), and then calling series.group.show()\r\n * after the animation was started. But this rendered the shadows\r\n * invisible in IE8 standards mode. If the columns flicker on large\r\n * datasets, this is the cause.\r\n */\r\n\r\n each(points, function(point) {\r\n var graphic = point.graphic,\r\n shapeArgs = point.shapeArgs,\r\n yAxis = series.yAxis,\r\n threshold = options.threshold;\r\n\r\n if (graphic) {\r\n // start values\r\n graphic.attr({\r\n height: 0,\r\n y: defined(threshold)\r\n ? yAxis.getThreshold(threshold)\r\n : yAxis.translate(yAxis.getExtremes().min, 0, 1, 0, 1)\r\n });\r\n\r\n // animate\r\n graphic.animate(\r\n {\r\n height: shapeArgs.height,\r\n y: shapeArgs.y\r\n },\r\n options.animation\r\n );\r\n }\r\n });\r\n\r\n // delete this function to allow it only once\r\n series.animate = null;\r\n }\r\n },\r\n\r\n /**\r\n * Remove this series from the chart\r\n */\r\n remove: function() {\r\n var series = this,\r\n chart = series.chart;\r\n\r\n // column and bar series affects other series of the same type\r\n // as they are either stacked or grouped\r\n if (chart.hasRendered) {\r\n each(chart.series, function(otherSeries) {\r\n if (otherSeries.type === series.type) {\r\n otherSeries.isDirty = true;\r\n }\r\n });\r\n }\r\n\r\n Series.prototype.remove.apply(series, arguments);\r\n }\r\n });\r\n seriesTypes.column = ColumnSeries;\r\n /**\r\n * Set the default options for bar\r\n */\r\n defaultPlotOptions.bar = merge(defaultPlotOptions.column);\r\n /**\r\n * The Bar series class\r\n */\r\n var BarSeries = extendClass(ColumnSeries, {\r\n type: \"bar\",\r\n inverted: true\r\n });\r\n seriesTypes.bar = BarSeries;\r\n\r\n /**\r\n * Set the default options for scatter\r\n */\r\n defaultPlotOptions.scatter = merge(defaultSeriesOptions, {\r\n lineWidth: 0,\r\n states: {\r\n hover: {\r\n lineWidth: 0\r\n }\r\n },\r\n tooltip: {\r\n headerFormat:\r\n '{series.name}
',\r\n pointFormat: \"x: {point.x}
y: {point.y}
\"\r\n }\r\n });\r\n\r\n /**\r\n * The scatter series class\r\n */\r\n var ScatterSeries = extendClass(Series, {\r\n type: \"scatter\",\r\n sorted: false,\r\n requireSorting: false,\r\n /**\r\n * Extend the base Series' translate method by adding shape type and\r\n * arguments for the point trackers\r\n */\r\n translate: function() {\r\n var series = this;\r\n\r\n Series.prototype.translate.apply(series);\r\n\r\n each(series.points, function(point) {\r\n point.shapeType = \"circle\";\r\n point.shapeArgs = {\r\n x: point.plotX,\r\n y: point.plotY,\r\n r: series.chart.options.tooltip.snap\r\n };\r\n });\r\n },\r\n\r\n /**\r\n * Add tracking event listener to the series group, so the point graphics\r\n * themselves act as trackers\r\n */\r\n drawTracker: function() {\r\n var series = this,\r\n cursor = series.options.cursor,\r\n css = cursor && { cursor: cursor },\r\n points = series.points,\r\n i = points.length,\r\n graphic,\r\n markerGroup = series.markerGroup,\r\n onMouseOver = function(e) {\r\n series.onMouseOver();\r\n if (e.target._i !== UNDEFINED) {\r\n // undefined on graph in scatterchart\r\n points[e.target._i].onMouseOver();\r\n }\r\n },\r\n onMouseOut = function() {\r\n if (!series.options.stickyTracking) {\r\n series.onMouseOut();\r\n }\r\n };\r\n\r\n // Set an expando property for the point index, used below\r\n while (i--) {\r\n graphic = points[i].graphic;\r\n if (graphic) {\r\n // doesn't exist for null points\r\n graphic.element._i = i;\r\n }\r\n }\r\n\r\n // Add the event listeners, we need to do this only once\r\n if (!series._hasTracking) {\r\n markerGroup\r\n .attr({\r\n isTracker: true\r\n })\r\n .on(\"mouseover\", onMouseOver)\r\n .on(\"mouseout\", onMouseOut)\r\n .css(css);\r\n if (hasTouch) {\r\n markerGroup.on(\"touchstart\", onMouseOver);\r\n }\r\n }\r\n else {\r\n series._hasTracking = true;\r\n }\r\n },\r\n\r\n setTooltipPoints: noop\r\n });\r\n seriesTypes.scatter = ScatterSeries;\r\n\r\n /**\r\n * Set the default options for pie\r\n */\r\n defaultPlotOptions.pie = merge(defaultSeriesOptions, {\r\n borderColor: \"#FFFFFF\",\r\n borderWidth: 1,\r\n center: [\"50%\", \"50%\"],\r\n colorByPoint: true, // always true for pies\r\n dataLabels: {\r\n // align: null,\r\n // connectorWidth: 1,\r\n // connectorColor: point.color,\r\n // connectorPadding: 5,\r\n distance: 30,\r\n enabled: true,\r\n formatter: function() {\r\n return this.point.name;\r\n }\r\n // softConnector: true,\r\n //y: 0\r\n },\r\n //innerSize: 0,\r\n legendType: \"point\",\r\n marker: null, // point options are specified in the base options\r\n size: \"75%\",\r\n showInLegend: false,\r\n slicedOffset: 10,\r\n states: {\r\n hover: {\r\n brightness: 0.1,\r\n shadow: false\r\n }\r\n }\r\n });\r\n\r\n /**\r\n * Extended point object for pies\r\n */\r\n var PiePoint = extendClass(Point, {\r\n /**\r\n * Initiate the pie slice\r\n */\r\n init: function() {\r\n Point.prototype.init.apply(this, arguments);\r\n\r\n var point = this,\r\n toggleSlice;\r\n\r\n //visible: options.visible !== false,\r\n extend(point, {\r\n visible: point.visible !== false,\r\n name: pick(point.name, \"Slice\")\r\n });\r\n\r\n // add event listener for select\r\n toggleSlice = function() {\r\n point.slice();\r\n };\r\n addEvent(point, \"select\", toggleSlice);\r\n addEvent(point, \"unselect\", toggleSlice);\r\n\r\n return point;\r\n },\r\n\r\n /**\r\n * Toggle the visibility of the pie slice\r\n * @param {Boolean} vis Whether to show the slice or not. If undefined, the\r\n * visibility is toggled\r\n */\r\n setVisible: function(vis) {\r\n var point = this,\r\n series = point.series,\r\n chart = series.chart,\r\n tracker = point.tracker,\r\n dataLabel = point.dataLabel,\r\n connector = point.connector,\r\n shadowGroup = point.shadowGroup,\r\n method;\r\n\r\n // if called without an argument, toggle visibility\r\n point.visible = vis = vis === UNDEFINED ? !point.visible : vis;\r\n\r\n method = vis ? \"show\" : \"hide\";\r\n\r\n point.group[method]();\r\n if (tracker) {\r\n tracker[method]();\r\n }\r\n if (dataLabel) {\r\n dataLabel[method]();\r\n }\r\n if (connector) {\r\n connector[method]();\r\n }\r\n if (shadowGroup) {\r\n shadowGroup[method]();\r\n }\r\n if (point.legendItem) {\r\n chart.legend.colorizeItem(point, vis);\r\n }\r\n\r\n // Handle ignore hidden slices\r\n if (!series.isDirty && series.options.ignoreHiddenPoint) {\r\n series.isDirty = true;\r\n chart.redraw();\r\n }\r\n },\r\n\r\n /**\r\n * Set or toggle whether the slice is cut out from the pie\r\n * @param {Boolean} sliced When undefined, the slice state is toggled\r\n * @param {Boolean} redraw Whether to redraw the chart. True by default.\r\n */\r\n slice: function(sliced, redraw, animation) {\r\n var point = this,\r\n series = point.series,\r\n chart = series.chart,\r\n slicedTranslation = point.slicedTranslation,\r\n translation;\r\n\r\n setAnimation(animation, chart);\r\n\r\n // redraw is true by default\r\n redraw = pick(redraw, true);\r\n\r\n // if called without an argument, toggle\r\n sliced = point.sliced = defined(sliced) ? sliced : !point.sliced;\r\n\r\n translation = {\r\n translateX: sliced ? slicedTranslation[0] : chart.plotLeft,\r\n translateY: sliced ? slicedTranslation[1] : chart.plotTop\r\n };\r\n point.group.animate(translation);\r\n if (point.shadowGroup) {\r\n point.shadowGroup.animate(translation);\r\n }\r\n }\r\n });\r\n\r\n /**\r\n * The Pie series class\r\n */\r\n var PieSeries = {\r\n type: \"pie\",\r\n isCartesian: false,\r\n pointClass: PiePoint,\r\n requireSorting: false,\r\n pointAttrToOptions: {\r\n // mapping between SVG attributes and the corresponding options\r\n stroke: \"borderColor\",\r\n \"stroke-width\": \"borderWidth\",\r\n fill: \"color\"\r\n },\r\n\r\n /**\r\n * Pies have one color each point\r\n */\r\n getColor: function() {\r\n // record first color for use in setData\r\n this.initialColor = this.chart.counters.color;\r\n },\r\n\r\n /**\r\n * Animate the pies in\r\n */\r\n animate: function() {\r\n var series = this,\r\n points = series.points,\r\n startAngleRad = series.startAngleRad;\r\n\r\n each(points, function(point) {\r\n var graphic = point.graphic,\r\n args = point.shapeArgs;\r\n\r\n if (graphic) {\r\n // start values\r\n graphic.attr({\r\n r: series.center[3] / 2, // animate from inner radius (#779)\r\n start: startAngleRad,\r\n end: startAngleRad\r\n });\r\n\r\n // animate\r\n graphic.animate(\r\n {\r\n r: args.r,\r\n start: args.start,\r\n end: args.end\r\n },\r\n series.options.animation\r\n );\r\n }\r\n });\r\n\r\n // delete this function to allow it only once\r\n series.animate = null;\r\n },\r\n\r\n /**\r\n * Extend the basic setData method by running processData and generatePoints immediately,\r\n * in order to access the points from the legend.\r\n */\r\n setData: function(data, redraw) {\r\n Series.prototype.setData.call(this, data, false);\r\n this.processData();\r\n this.generatePoints();\r\n if (pick(redraw, true)) {\r\n this.chart.redraw();\r\n }\r\n },\r\n\r\n /**\r\n * Get the center of the pie based on the size and center options relative to the\r\n * plot area. Borrowed by the polar and gauge series types.\r\n */\r\n getCenter: function() {\r\n var options = this.options,\r\n chart = this.chart,\r\n plotWidth = chart.plotWidth,\r\n plotHeight = chart.plotHeight,\r\n positions = options.center.concat([\r\n options.size,\r\n options.innerSize || 0\r\n ]),\r\n smallestSize = mathMin(plotWidth, plotHeight),\r\n isPercent;\r\n\r\n return map(positions, function(length, i) {\r\n isPercent = /%$/.test(length);\r\n return isPercent\r\n ? // i == 0: centerX, relative to width\r\n // i == 1: centerY, relative to height\r\n // i == 2: size, relative to smallestSize\r\n // i == 4: innerSize, relative to smallestSize\r\n ([plotWidth, plotHeight, smallestSize, smallestSize][i] *\r\n pInt(length)) /\r\n 100\r\n : length;\r\n });\r\n },\r\n\r\n /**\r\n * Do translation for pie slices\r\n */\r\n translate: function() {\r\n this.generatePoints();\r\n\r\n var total = 0,\r\n series = this,\r\n cumulative = 0,\r\n precision = 1000, // issue #172\r\n options = series.options,\r\n slicedOffset = options.slicedOffset,\r\n connectorOffset = slicedOffset + options.borderWidth,\r\n positions,\r\n chart = series.chart,\r\n start,\r\n end,\r\n angle,\r\n startAngleRad = (series.startAngleRad =\r\n (mathPI / 180) * (((options.startAngle || 0) % 360) - 90)),\r\n points = series.points,\r\n circ = 2 * mathPI,\r\n fraction,\r\n radiusX, // the x component of the radius vector for a given point\r\n radiusY,\r\n labelDistance = options.dataLabels.distance,\r\n ignoreHiddenPoint = options.ignoreHiddenPoint,\r\n i,\r\n len = points.length,\r\n point;\r\n\r\n // get positions - either an integer or a percentage string must be given\r\n series.center = positions = series.getCenter();\r\n\r\n // utility for getting the x value from a given y, used for anticollision logic in data labels\r\n series.getX = function(y, left) {\r\n angle = math.asin(\r\n (y - positions[1]) / (positions[2] / 2 + labelDistance)\r\n );\r\n\r\n return (\r\n positions[0] +\r\n (left ? -1 : 1) *\r\n (mathCos(angle) * (positions[2] / 2 + labelDistance))\r\n );\r\n };\r\n\r\n // get the total sum\r\n for (i = 0; i < len; i++) {\r\n point = points[i];\r\n total += ignoreHiddenPoint && !point.visible ? 0 : point.y;\r\n }\r\n\r\n // Calculate the geometry for each point\r\n for (i = 0; i < len; i++) {\r\n point = points[i];\r\n\r\n // set start and end angle\r\n fraction = total ? point.y / total : 0;\r\n start =\r\n mathRound((startAngleRad + cumulative * circ) * precision) /\r\n precision;\r\n if (!ignoreHiddenPoint || point.visible) {\r\n cumulative += fraction;\r\n }\r\n end =\r\n mathRound((startAngleRad + cumulative * circ) * precision) /\r\n precision;\r\n\r\n // set the shape\r\n point.shapeType = \"arc\";\r\n point.shapeArgs = {\r\n x: positions[0],\r\n y: positions[1],\r\n r: positions[2] / 2,\r\n innerR: positions[3] / 2,\r\n start: start,\r\n end: end\r\n };\r\n\r\n // center for the sliced out slice\r\n angle = (end + start) / 2;\r\n if (angle > 0.75 * circ) {\r\n angle -= 2 * mathPI;\r\n }\r\n point.slicedTranslation = map(\r\n [\r\n mathCos(angle) * slicedOffset + chart.plotLeft,\r\n mathSin(angle) * slicedOffset + chart.plotTop\r\n ],\r\n mathRound\r\n );\r\n\r\n // set the anchor point for tooltips\r\n radiusX = (mathCos(angle) * positions[2]) / 2;\r\n radiusY = (mathSin(angle) * positions[2]) / 2;\r\n point.tooltipPos = [\r\n positions[0] + radiusX * 0.7,\r\n positions[1] + radiusY * 0.7\r\n ];\r\n\r\n point.half = angle < circ / 4 ? 0 : 1;\r\n point.angle = angle;\r\n\r\n // set the anchor point for data labels\r\n point.labelPos = [\r\n positions[0] + radiusX + mathCos(angle) * labelDistance, // first break of connector\r\n positions[1] + radiusY + mathSin(angle) * labelDistance, // a/a\r\n positions[0] + radiusX + mathCos(angle) * connectorOffset, // second break, right outside pie\r\n positions[1] + radiusY + mathSin(angle) * connectorOffset, // a/a\r\n positions[0] + radiusX, // landing point for connector\r\n positions[1] + radiusY, // a/a\r\n labelDistance < 0 // alignment\r\n ? \"center\"\r\n : point.half\r\n ? \"right\"\r\n : \"left\", // alignment\r\n angle // center angle\r\n ];\r\n\r\n // API properties\r\n point.percentage = fraction * 100;\r\n point.total = total;\r\n }\r\n\r\n this.setTooltipPoints();\r\n },\r\n\r\n /**\r\n * Render the slices\r\n */\r\n render: function() {\r\n var series = this;\r\n\r\n // cache attributes for shapes\r\n series.getAttribs();\r\n\r\n this.drawPoints();\r\n\r\n // draw the mouse tracking area\r\n if (series.options.enableMouseTracking !== false) {\r\n series.drawTracker();\r\n }\r\n\r\n this.drawDataLabels();\r\n\r\n if (series.options.animation && series.animate) {\r\n series.animate();\r\n }\r\n\r\n // (See #322) series.isDirty = series.isDirtyData = false; // means data is in accordance with what you see\r\n series.isDirty = false; // means data is in accordance with what you see\r\n },\r\n\r\n /**\r\n * Draw the data points\r\n */\r\n drawPoints: function() {\r\n var series = this,\r\n chart = series.chart,\r\n renderer = chart.renderer,\r\n groupTranslation,\r\n //center,\r\n graphic,\r\n group,\r\n shadow = series.options.shadow,\r\n shadowGroup,\r\n shapeArgs;\r\n\r\n // draw the slices\r\n each(series.points, function(point) {\r\n graphic = point.graphic;\r\n shapeArgs = point.shapeArgs;\r\n group = point.group;\r\n shadowGroup = point.shadowGroup;\r\n\r\n // put the shadow behind all points\r\n if (shadow && !shadowGroup) {\r\n shadowGroup = point.shadowGroup = renderer\r\n .g(\"shadow\")\r\n .attr({ zIndex: 4 })\r\n .add();\r\n }\r\n\r\n // create the group the first time\r\n if (!group) {\r\n group = point.group = renderer\r\n .g(\"point\")\r\n .attr({ zIndex: 5 })\r\n .add();\r\n }\r\n\r\n // if the point is sliced, use special translation, else use plot area traslation\r\n groupTranslation = point.sliced\r\n ? point.slicedTranslation\r\n : [chart.plotLeft, chart.plotTop];\r\n group.translate(groupTranslation[0], groupTranslation[1]);\r\n if (shadowGroup) {\r\n shadowGroup.translate(groupTranslation[0], groupTranslation[1]);\r\n }\r\n\r\n // draw the slice\r\n if (graphic) {\r\n graphic.animate(shapeArgs);\r\n }\r\n else {\r\n point.graphic = graphic = renderer\r\n .arc(shapeArgs)\r\n .setRadialReference(series.center)\r\n .attr(\r\n extend(point.pointAttr[NORMAL_STATE], {\r\n \"stroke-linejoin\": \"round\"\r\n })\r\n )\r\n .add(point.group)\r\n .shadow(shadow, shadowGroup);\r\n }\r\n\r\n // detect point specific visibility\r\n if (point.visible === false) {\r\n point.setVisible(false);\r\n }\r\n });\r\n },\r\n\r\n /**\r\n * Override the base drawDataLabels method by pie specific functionality\r\n */\r\n drawDataLabels: function() {\r\n var series = this,\r\n data = series.data,\r\n point,\r\n chart = series.chart,\r\n options = series.options.dataLabels,\r\n connectorPadding = pick(options.connectorPadding, 10),\r\n connectorWidth = pick(options.connectorWidth, 1),\r\n connector,\r\n connectorPath,\r\n softConnector = pick(options.softConnector, true),\r\n distanceOption = options.distance,\r\n seriesCenter = series.center,\r\n radius = seriesCenter[2] / 2,\r\n centerY = seriesCenter[1],\r\n outside = distanceOption > 0,\r\n dataLabel,\r\n labelPos,\r\n labelHeight,\r\n halves = [\r\n // divide the points into right and left halves for anti collision\r\n [], // right\r\n [] // left\r\n ],\r\n x,\r\n y,\r\n visibility,\r\n rankArr,\r\n i = 2,\r\n j,\r\n sort = function(a, b) {\r\n return b.y - a.y;\r\n },\r\n sortByAngle = function(points, sign) {\r\n points.sort(function(a, b) {\r\n return (b.angle - a.angle) * sign;\r\n });\r\n };\r\n\r\n // get out if not enabled\r\n if (!options.enabled && !series._hasPointLabels) {\r\n return;\r\n }\r\n\r\n // run parent method\r\n Series.prototype.drawDataLabels.apply(series);\r\n\r\n // arrange points for detection collision\r\n each(data, function(point) {\r\n if (point.dataLabel) {\r\n // it may have been cancelled in the base method (#407)\r\n halves[point.half].push(point);\r\n }\r\n });\r\n\r\n // assume equal label heights\r\n labelHeight =\r\n halves[0][0] &&\r\n halves[0][0].dataLabel &&\r\n (halves[0][0].dataLabel.getBBox().height || 21); // 21 is for #968\r\n\r\n /* Loop over the points in each half, starting from the top and bottom\r\n * of the pie to detect overlapping labels.\r\n */\r\n while (i--) {\r\n var slots = [],\r\n slotsLength,\r\n usedSlots = [],\r\n points = halves[i],\r\n pos,\r\n length = points.length,\r\n slotIndex;\r\n\r\n // Sort by angle\r\n sortByAngle(points, i - 0.5);\r\n\r\n // Only do anti-collision when we are outside the pie and have connectors (#856)\r\n if (distanceOption > 0) {\r\n // build the slots\r\n for (\r\n pos = centerY - radius - distanceOption;\r\n pos <= centerY + radius + distanceOption;\r\n pos += labelHeight\r\n ) {\r\n slots.push(pos);\r\n // visualize the slot\r\n /*\r\n\t\t\t\t\tvar slotX = series.getX(pos, i) + chart.plotLeft - (i ? 100 : 0),\r\n\t\t\t\t\t\tslotY = pos + chart.plotTop;\r\n\t\t\t\t\tif (!isNaN(slotX)) {\r\n\t\t\t\t\t\tchart.renderer.rect(slotX, slotY - 7, 100, labelHeight)\r\n\t\t\t\t\t\t\t.attr({\r\n\t\t\t\t\t\t\t\t'stroke-width': 1,\r\n\t\t\t\t\t\t\t\tstroke: 'silver'\r\n\t\t\t\t\t\t\t})\r\n\t\t\t\t\t\t\t.add();\r\n\t\t\t\t\t\tchart.renderer.text('Slot '+ (slots.length - 1), slotX, slotY + 4)\r\n\t\t\t\t\t\t\t.attr({\r\n\t\t\t\t\t\t\t\tfill: 'silver'\r\n\t\t\t\t\t\t\t}).add();\r\n\t\t\t\t\t}\r\n\t\t\t\t\t// */\r\n }\r\n slotsLength = slots.length;\r\n\r\n // if there are more values than available slots, remove lowest values\r\n if (length > slotsLength) {\r\n // create an array for sorting and ranking the points within each quarter\r\n rankArr = [].concat(points);\r\n rankArr.sort(sort);\r\n j = length;\r\n while (j--) {\r\n rankArr[j].rank = j;\r\n }\r\n j = length;\r\n while (j--) {\r\n if (points[j].rank >= slotsLength) {\r\n points.splice(j, 1);\r\n }\r\n }\r\n length = points.length;\r\n }\r\n\r\n // The label goes to the nearest open slot, but not closer to the edge than\r\n // the label's index.\r\n for (j = 0; j < length; j++) {\r\n point = points[j];\r\n labelPos = point.labelPos;\r\n\r\n var closest = 9999,\r\n distance,\r\n slotI;\r\n\r\n // find the closest slot index\r\n for (slotI = 0; slotI < slotsLength; slotI++) {\r\n distance = mathAbs(slots[slotI] - labelPos[1]);\r\n if (distance < closest) {\r\n closest = distance;\r\n slotIndex = slotI;\r\n }\r\n }\r\n\r\n // if that slot index is closer to the edges of the slots, move it\r\n // to the closest appropriate slot\r\n if (slotIndex < j && slots[j] !== null) {\r\n // cluster at the top\r\n slotIndex = j;\r\n }\r\n else if (\r\n slotsLength < length - j + slotIndex &&\r\n slots[j] !== null\r\n ) {\r\n // cluster at the bottom\r\n slotIndex = slotsLength - length + j;\r\n while (slots[slotIndex] === null) {\r\n // make sure it is not taken\r\n slotIndex++;\r\n }\r\n }\r\n else {\r\n // Slot is taken, find next free slot below. In the next run, the next slice will find the\r\n // slot above these, because it is the closest one\r\n while (slots[slotIndex] === null) {\r\n // make sure it is not taken\r\n slotIndex++;\r\n }\r\n }\r\n\r\n usedSlots.push({ i: slotIndex, y: slots[slotIndex] });\r\n slots[slotIndex] = null; // mark as taken\r\n }\r\n // sort them in order to fill in from the top\r\n usedSlots.sort(sort);\r\n }\r\n\r\n // now the used slots are sorted, fill them up sequentially\r\n for (j = 0; j < length; j++) {\r\n var slot, naturalY;\r\n\r\n point = points[j];\r\n labelPos = point.labelPos;\r\n dataLabel = point.dataLabel;\r\n visibility = point.visible === false ? HIDDEN : VISIBLE;\r\n naturalY = labelPos[1];\r\n\r\n if (distanceOption > 0) {\r\n slot = usedSlots.pop();\r\n slotIndex = slot.i;\r\n\r\n // if the slot next to currrent slot is free, the y value is allowed\r\n // to fall back to the natural position\r\n y = slot.y;\r\n if (\r\n (naturalY > y && slots[slotIndex + 1] !== null) ||\r\n (naturalY < y && slots[slotIndex - 1] !== null)\r\n ) {\r\n y = naturalY;\r\n }\r\n }\r\n else {\r\n y = naturalY;\r\n }\r\n\r\n // get the x - use the natural x position for first and last slot, to prevent the top\r\n // and botton slice connectors from touching each other on either side\r\n x = options.justify\r\n ? seriesCenter[0] + (i ? -1 : 1) * (radius + distanceOption)\r\n : series.getX(\r\n slotIndex === 0 || slotIndex === slots.length - 1\r\n ? naturalY\r\n : y,\r\n i\r\n );\r\n\r\n // move or place the data label\r\n dataLabel\r\n .attr({\r\n visibility: visibility,\r\n align: labelPos[6]\r\n })\r\n [dataLabel.moved ? \"animate\" : \"attr\"]({\r\n x:\r\n x +\r\n options.x +\r\n ({ left: connectorPadding, right: -connectorPadding }[\r\n labelPos[6]\r\n ] || 0),\r\n y: y + options.y - 10 // 10 is for the baseline (label vs text)\r\n });\r\n dataLabel.moved = true;\r\n\r\n // draw the connector\r\n if (outside && connectorWidth) {\r\n connector = point.connector;\r\n\r\n connectorPath = softConnector\r\n ? [\r\n M,\r\n x + (labelPos[6] === \"left\" ? 5 : -5),\r\n y, // end of the string at the label\r\n \"C\",\r\n x,\r\n y, // first break, next to the label\r\n 2 * labelPos[2] - labelPos[4],\r\n 2 * labelPos[3] - labelPos[5],\r\n labelPos[2],\r\n labelPos[3], // second break\r\n L,\r\n labelPos[4],\r\n labelPos[5] // base\r\n ]\r\n : [\r\n M,\r\n x + (labelPos[6] === \"left\" ? 5 : -5),\r\n y, // end of the string at the label\r\n L,\r\n labelPos[2],\r\n labelPos[3], // second break\r\n L,\r\n labelPos[4],\r\n labelPos[5] // base\r\n ];\r\n\r\n if (connector) {\r\n connector.animate({ d: connectorPath });\r\n connector.attr(\"visibility\", visibility);\r\n }\r\n else {\r\n point.connector = connector = series.chart.renderer\r\n .path(connectorPath)\r\n .attr({\r\n \"stroke-width\": connectorWidth,\r\n stroke: options.connectorColor || point.color || \"#606060\",\r\n visibility: visibility,\r\n zIndex: 3\r\n })\r\n .translate(chart.plotLeft, chart.plotTop)\r\n .add();\r\n }\r\n }\r\n }\r\n }\r\n },\r\n\r\n alignDataLabel: noop,\r\n\r\n /**\r\n * Draw point specific tracker objects. Inherit directly from column series.\r\n */\r\n drawTracker: ColumnSeries.prototype.drawTracker,\r\n\r\n /**\r\n * Use a simple symbol from column prototype\r\n */\r\n drawLegendSymbol: AreaSeries.prototype.drawLegendSymbol,\r\n\r\n /**\r\n * Pies don't have point marker symbols\r\n */\r\n getSymbol: function() {}\r\n };\r\n PieSeries = extendClass(Series, PieSeries);\r\n seriesTypes.pie = PieSeries;\r\n\r\n // global variables\r\n extend(Highcharts, {\r\n // Constructors\r\n Axis: Axis,\r\n CanVGRenderer: CanVGRenderer,\r\n Chart: Chart,\r\n Color: Color,\r\n Legend: Legend,\r\n MouseTracker: MouseTracker,\r\n Point: Point,\r\n Tick: Tick,\r\n Tooltip: Tooltip,\r\n Renderer: Renderer,\r\n Series: Series,\r\n SVGRenderer: SVGRenderer,\r\n VMLRenderer: VMLRenderer,\r\n\r\n // Various\r\n arrayMin: arrayMin,\r\n arrayMax: arrayMax,\r\n charts: charts,\r\n dateFormat: dateFormat,\r\n pathAnim: pathAnim,\r\n getOptions: getOptions,\r\n hasBidiBug: hasBidiBug,\r\n isTouchDevice: isTouchDevice,\r\n numberFormat: numberFormat,\r\n seriesTypes: seriesTypes,\r\n setOptions: setOptions,\r\n addEvent: addEvent,\r\n removeEvent: removeEvent,\r\n createElement: createElement,\r\n discardElement: discardElement,\r\n css: css,\r\n each: each,\r\n extend: extend,\r\n map: map,\r\n merge: merge,\r\n pick: pick,\r\n splat: splat,\r\n extendClass: extendClass,\r\n pInt: pInt,\r\n wrap: wrap,\r\n svg: hasSVG,\r\n canvas: useCanVG,\r\n vml: !hasSVG && !useCanVG,\r\n product: \"Highcharts\",\r\n version: \"2.3.5\"\r\n });\r\n})();\r\n","/*\r\n proj4js.js -- Javascript reprojection library. \r\n \r\n Authors: Mike Adair madairATdmsolutions.ca\r\n Richard Greenwood richATgreenwoodmap.com\r\n Didier Richard didier.richardATign.fr\r\n Stephen Irons stephen.ironsATclear.net.nz\r\n Olivier Terral oterralATgmail.com\r\n \r\n License: \r\n Copyright (c) 2012, Mike Adair, Richard Greenwood, Didier Richard, \r\n Stephen Irons and Olivier Terral\r\n\r\n Permission is hereby granted, free of charge, to any person obtaining a\r\n copy of this software and associated documentation files (the \"Software\"),\r\n to deal in the Software without restriction, including without limitation\r\n the rights to use, copy, modify, merge, publish, distribute, sublicense,\r\n and/or sell copies of the Software, and to permit persons to whom the\r\n Software is furnished to do so, subject to the following conditions:\r\n\r\n The above copyright notice and this permission notice shall be included\r\n in all copies or substantial portions of the Software.\r\n\r\n THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS\r\n OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\r\n FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL\r\n THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\r\n LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING\r\n FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER\r\n DEALINGS IN THE SOFTWARE.\r\n \r\n Note: This program is an almost direct port of the C library PROJ.4.\r\n*/\r\n/* ======================================================================\r\n proj4js.js\r\n ====================================================================== */\r\n\r\n/*\r\nAuthor: Mike Adair madairATdmsolutions.ca\r\n Richard Greenwood rich@greenwoodmap.com\r\nLicense: LGPL as per: http://www.gnu.org/copyleft/lesser.html\r\n\r\n$Id: Proj.js 2956 2007-07-09 12:17:52Z steven $\r\n*/\r\n\r\n/**\r\n * Namespace: Proj4js\r\n *\r\n * Proj4js is a JavaScript library to transform point coordinates from one\r\n * coordinate system to another, including datum transformations.\r\n *\r\n * This library is a port of both the Proj.4 and GCTCP C libraries to JavaScript.\r\n * Enabling these transformations in the browser allows geographic data stored\r\n * in different projections to be combined in browser-based web mapping\r\n * applications.\r\n *\r\n * Proj4js must have access to coordinate system initialization strings (which\r\n * are the same as for PROJ.4 command line). Thes can be included in your\r\n * application using a \r\n\r\n def is a CS definition in PROJ.4 WKT format, for example:\r\n +proj=\"tmerc\" //longlat, etc.\r\n +a=majorRadius\r\n +b=minorRadius\r\n +lat0=somenumber\r\n +long=somenumber\r\n*/\r\nProj4js.defs = {\r\n // These are so widely used, we'll go ahead and throw them in\r\n // without requiring a separate .js file\r\n WGS84:\r\n \"+title=long/lat:WGS84 +proj=longlat +ellps=WGS84 +datum=WGS84 +units=degrees\",\r\n \"EPSG:4326\":\r\n \"+title=long/lat:WGS84 +proj=longlat +a=6378137.0 +b=6356752.31424518 +ellps=WGS84 +datum=WGS84 +units=degrees\",\r\n \"EPSG:4269\":\r\n \"+title=long/lat:NAD83 +proj=longlat +a=6378137.0 +b=6356752.31414036 +ellps=GRS80 +datum=NAD83 +units=degrees\",\r\n \"EPSG:3875\":\r\n \"+title= Google Mercator +proj=merc +a=6378137 +b=6378137 +lat_ts=0.0 +lon_0=0.0 +x_0=0.0 +y_0=0 +k=1.0 +units=m +nadgrids=@null +no_defs\"\r\n};\r\nProj4js.defs[\"EPSG:3785\"] = Proj4js.defs[\"EPSG:3875\"]; //maintain backward compat, official code is 3875\r\nProj4js.defs[\"GOOGLE\"] = Proj4js.defs[\"EPSG:3875\"];\r\nProj4js.defs[\"EPSG:900913\"] = Proj4js.defs[\"EPSG:3875\"];\r\nProj4js.defs[\"EPSG:102113\"] = Proj4js.defs[\"EPSG:3875\"];\r\n\r\nProj4js.common = {\r\n PI: 3.141592653589793238, //Math.PI,\r\n HALF_PI: 1.570796326794896619, //Math.PI*0.5,\r\n TWO_PI: 6.283185307179586477, //Math.PI*2,\r\n FORTPI: 0.78539816339744833,\r\n R2D: 57.29577951308232088,\r\n D2R: 0.01745329251994329577,\r\n SEC_TO_RAD: 4.84813681109535993589914102357e-6 /* SEC_TO_RAD = Pi/180/3600 */,\r\n EPSLN: 1.0e-10,\r\n MAX_ITER: 20,\r\n // following constants from geocent.c\r\n COS_67P5: 0.38268343236508977 /* cosine of 67.5 degrees */,\r\n AD_C: 1.0026 /* Toms region 1 constant */,\r\n\r\n /* datum_type values */\r\n PJD_UNKNOWN: 0,\r\n PJD_3PARAM: 1,\r\n PJD_7PARAM: 2,\r\n PJD_GRIDSHIFT: 3,\r\n PJD_WGS84: 4, // WGS84 or equivalent\r\n PJD_NODATUM: 5, // WGS84 or equivalent\r\n SRS_WGS84_SEMIMAJOR: 6378137.0, // only used in grid shift transforms\r\n\r\n // ellipoid pj_set_ell.c\r\n SIXTH: 0.1666666666666666667 /* 1/6 */,\r\n RA4: 0.04722222222222222222 /* 17/360 */,\r\n RA6: 0.02215608465608465608 /* 67/3024 */,\r\n RV4: 0.06944444444444444444 /* 5/72 */,\r\n RV6: 0.0424382716049382716 /* 55/1296 */,\r\n\r\n // Function to compute the constant small m which is the radius of\r\n // a parallel of latitude, phi, divided by the semimajor axis.\r\n // -----------------------------------------------------------------\r\n msfnz: function(eccent, sinphi, cosphi) {\r\n var con = eccent * sinphi;\r\n return cosphi / Math.sqrt(1.0 - con * con);\r\n },\r\n\r\n // Function to compute the constant small t for use in the forward\r\n // computations in the Lambert Conformal Conic and the Polar\r\n // Stereographic projections.\r\n // -----------------------------------------------------------------\r\n tsfnz: function(eccent, phi, sinphi) {\r\n var con = eccent * sinphi;\r\n var com = 0.5 * eccent;\r\n con = Math.pow((1.0 - con) / (1.0 + con), com);\r\n return Math.tan(0.5 * (this.HALF_PI - phi)) / con;\r\n },\r\n\r\n // Function to compute the latitude angle, phi2, for the inverse of the\r\n // Lambert Conformal Conic and Polar Stereographic projections.\r\n // ----------------------------------------------------------------\r\n phi2z: function(eccent, ts) {\r\n var eccnth = 0.5 * eccent;\r\n var con, dphi;\r\n var phi = this.HALF_PI - 2 * Math.atan(ts);\r\n for (var i = 0; i <= 15; i++) {\r\n con = eccent * Math.sin(phi);\r\n dphi =\r\n this.HALF_PI -\r\n 2 * Math.atan(ts * Math.pow((1.0 - con) / (1.0 + con), eccnth)) -\r\n phi;\r\n phi += dphi;\r\n if (Math.abs(dphi) <= 0.0000000001) return phi;\r\n }\r\n alert(\"phi2z has NoConvergence\");\r\n return -9999;\r\n },\r\n\r\n /* Function to compute constant small q which is the radius of a \r\n parallel of latitude, phi, divided by the semimajor axis. \r\n------------------------------------------------------------*/\r\n qsfnz: function(eccent, sinphi) {\r\n var con;\r\n if (eccent > 1.0e-7) {\r\n con = eccent * sinphi;\r\n return (\r\n (1.0 - eccent * eccent) *\r\n (sinphi / (1.0 - con * con) -\r\n (0.5 / eccent) * Math.log((1.0 - con) / (1.0 + con)))\r\n );\r\n }\n else {\r\n return 2.0 * sinphi;\r\n }\r\n },\r\n\r\n /* Function to eliminate roundoff errors in asin\r\n----------------------------------------------*/\r\n asinz: function(x) {\r\n if (Math.abs(x) > 1.0) {\r\n x = x > 1.0 ? 1.0 : -1.0;\r\n }\r\n return Math.asin(x);\r\n },\r\n\r\n // following functions from gctpc cproj.c for transverse mercator projections\r\n e0fn: function(x) {\r\n return 1.0 - 0.25 * x * (1.0 + (x / 16.0) * (3.0 + 1.25 * x));\r\n },\r\n e1fn: function(x) {\r\n return 0.375 * x * (1.0 + 0.25 * x * (1.0 + 0.46875 * x));\r\n },\r\n e2fn: function(x) {\r\n return 0.05859375 * x * x * (1.0 + 0.75 * x);\r\n },\r\n e3fn: function(x) {\r\n return x * x * x * (35.0 / 3072.0);\r\n },\r\n mlfn: function(e0, e1, e2, e3, phi) {\r\n return (\r\n e0 * phi -\r\n e1 * Math.sin(2.0 * phi) +\r\n e2 * Math.sin(4.0 * phi) -\r\n e3 * Math.sin(6.0 * phi)\r\n );\r\n },\r\n\r\n srat: function(esinp, exp) {\r\n return Math.pow((1.0 - esinp) / (1.0 + esinp), exp);\r\n },\r\n\r\n // Function to return the sign of an argument\r\n sign: function(x) {\r\n if (x < 0.0) return -1;\r\n else return 1;\r\n },\r\n\r\n // Function to adjust longitude to -180 to 180; input in radians\r\n adjust_lon: function(x) {\r\n x = Math.abs(x) < this.PI ? x : x - this.sign(x) * this.TWO_PI;\r\n return x;\r\n },\r\n\r\n // IGNF - DGR : algorithms used by IGN France\r\n\r\n // Function to adjust latitude to -90 to 90; input in radians\r\n adjust_lat: function(x) {\r\n x = Math.abs(x) < this.HALF_PI ? x : x - this.sign(x) * this.PI;\r\n return x;\r\n },\r\n\r\n // Latitude Isometrique - close to tsfnz ...\r\n latiso: function(eccent, phi, sinphi) {\r\n if (Math.abs(phi) > this.HALF_PI) return +Number.NaN;\r\n if (phi == this.HALF_PI) return Number.POSITIVE_INFINITY;\r\n if (phi == -1.0 * this.HALF_PI) return -1.0 * Number.POSITIVE_INFINITY;\r\n\r\n var con = eccent * sinphi;\r\n return (\r\n Math.log(Math.tan((this.HALF_PI + phi) / 2.0)) +\r\n (eccent * Math.log((1.0 - con) / (1.0 + con))) / 2.0\r\n );\r\n },\r\n\r\n fL: function(x, L) {\r\n return 2.0 * Math.atan(x * Math.exp(L)) - this.HALF_PI;\r\n },\r\n\r\n // Inverse Latitude Isometrique - close to ph2z\r\n invlatiso: function(eccent, ts) {\r\n var phi = this.fL(1.0, ts);\r\n var Iphi = 0.0;\r\n var con = 0.0;\r\n do {\r\n Iphi = phi;\r\n con = eccent * Math.sin(Iphi);\r\n phi = this.fL(\r\n Math.exp((eccent * Math.log((1.0 + con) / (1.0 - con))) / 2.0),\r\n ts\r\n );\r\n } while (Math.abs(phi - Iphi) > 1.0e-12);\r\n return phi;\r\n },\r\n\r\n // Needed for Gauss Schreiber\r\n // Original: Denis Makarov (info@binarythings.com)\r\n // Web Site: http://www.binarythings.com\r\n sinh: function(x) {\r\n var r = Math.exp(x);\r\n r = (r - 1.0 / r) / 2.0;\r\n return r;\r\n },\r\n\r\n cosh: function(x) {\r\n var r = Math.exp(x);\r\n r = (r + 1.0 / r) / 2.0;\r\n return r;\r\n },\r\n\r\n tanh: function(x) {\r\n var r = Math.exp(x);\r\n r = (r - 1.0 / r) / (r + 1.0 / r);\r\n return r;\r\n },\r\n\r\n asinh: function(x) {\r\n var s = x >= 0 ? 1.0 : -1.0;\r\n return s * Math.log(Math.abs(x) + Math.sqrt(x * x + 1.0));\r\n },\r\n\r\n acosh: function(x) {\r\n return (\r\n 2.0 * Math.log(Math.sqrt((x + 1.0) / 2.0) + Math.sqrt((x - 1.0) / 2.0))\r\n );\r\n },\r\n\r\n atanh: function(x) {\r\n return Math.log((x - 1.0) / (x + 1.0)) / 2.0;\r\n },\r\n\r\n // Grande Normale\r\n gN: function(a, e, sinphi) {\r\n var temp = e * sinphi;\r\n return a / Math.sqrt(1.0 - temp * temp);\r\n },\r\n\r\n //code from the PROJ.4 pj_mlfn.c file; this may be useful for other projections\r\n pj_enfn: function(es) {\r\n var en = new Array();\r\n en[0] =\r\n this.C00 -\r\n es * (this.C02 + es * (this.C04 + es * (this.C06 + es * this.C08)));\r\n en[1] = es * (this.C22 - es * (this.C04 + es * (this.C06 + es * this.C08)));\r\n var t = es * es;\r\n en[2] = t * (this.C44 - es * (this.C46 + es * this.C48));\r\n t *= es;\r\n en[3] = t * (this.C66 - es * this.C68);\r\n en[4] = t * es * this.C88;\r\n return en;\r\n },\r\n\r\n pj_mlfn: function(phi, sphi, cphi, en) {\r\n cphi *= sphi;\r\n sphi *= sphi;\r\n return (\r\n en[0] * phi -\r\n cphi * (en[1] + sphi * (en[2] + sphi * (en[3] + sphi * en[4])))\r\n );\r\n },\r\n\r\n pj_inv_mlfn: function(arg, es, en) {\r\n var k = 1 / (1 - es);\r\n var phi = arg;\r\n for (var i = Proj4js.common.MAX_ITER; i; --i) {\r\n /* rarely goes over 2 iterations */\r\n var s = Math.sin(phi);\r\n var t = 1 - es * s * s;\r\n //t = this.pj_mlfn(phi, s, Math.cos(phi), en) - arg;\r\n //phi -= t * (t * Math.sqrt(t)) * k;\r\n t =\r\n (this.pj_mlfn(phi, s, Math.cos(phi), en) - arg) *\r\n (t * Math.sqrt(t)) *\r\n k;\r\n phi -= t;\r\n if (Math.abs(t) < Proj4js.common.EPSLN) return phi;\r\n }\r\n Proj4js.reportError(\"cass:pj_inv_mlfn: Convergence error\");\r\n return phi;\r\n },\r\n\r\n /* meridinal distance for ellipsoid and inverse\r\n **\t8th degree - accurate to < 1e-5 meters when used in conjuction\r\n **\t\twith typical major axis values.\r\n **\tInverse determines phi to EPS (1e-11) radians, about 1e-6 seconds.\r\n */\r\n C00: 1.0,\r\n C02: 0.25,\r\n C04: 0.046875,\r\n C06: 0.01953125,\r\n C08: 0.01068115234375,\r\n C22: 0.75,\r\n C44: 0.46875,\r\n C46: 0.01302083333333333333,\r\n C48: 0.00712076822916666666,\r\n C66: 0.36458333333333333333,\r\n C68: 0.00569661458333333333,\r\n C88: 0.3076171875\r\n};\r\n\r\n/** datum object\r\n */\r\nProj4js.datum = Proj4js.Class({\r\n initialize: function(proj) {\r\n this.datum_type = Proj4js.common.PJD_WGS84; //default setting\r\n if (proj.datumCode && proj.datumCode == \"none\") {\r\n this.datum_type = Proj4js.common.PJD_NODATUM;\r\n }\r\n if (proj && proj.datum_params) {\r\n for (var i = 0; i < proj.datum_params.length; i++) {\r\n proj.datum_params[i] = parseFloat(proj.datum_params[i]);\r\n }\r\n if (\r\n proj.datum_params[0] != 0 ||\r\n proj.datum_params[1] != 0 ||\r\n proj.datum_params[2] != 0\r\n ) {\r\n this.datum_type = Proj4js.common.PJD_3PARAM;\r\n }\r\n if (proj.datum_params.length > 3) {\r\n if (\r\n proj.datum_params[3] != 0 ||\r\n proj.datum_params[4] != 0 ||\r\n proj.datum_params[5] != 0 ||\r\n proj.datum_params[6] != 0\r\n ) {\r\n this.datum_type = Proj4js.common.PJD_7PARAM;\r\n proj.datum_params[3] *= Proj4js.common.SEC_TO_RAD;\r\n proj.datum_params[4] *= Proj4js.common.SEC_TO_RAD;\r\n proj.datum_params[5] *= Proj4js.common.SEC_TO_RAD;\r\n proj.datum_params[6] = proj.datum_params[6] / 1000000.0 + 1.0;\r\n }\r\n }\r\n }\r\n if (proj) {\r\n this.a = proj.a; //datum object also uses these values\r\n this.b = proj.b;\r\n this.es = proj.es;\r\n this.ep2 = proj.ep2;\r\n this.datum_params = proj.datum_params;\r\n }\r\n },\r\n\r\n /****************************************************************/\r\n // cs_compare_datums()\r\n // Returns TRUE if the two datums match, otherwise FALSE.\r\n compare_datums: function(dest) {\r\n if (this.datum_type != dest.datum_type) {\r\n return false; // false, datums are not equal\r\n }\n else if (\r\n this.a != dest.a ||\r\n Math.abs(this.es - dest.es) > 0.00000000005\r\n ) {\r\n // the tolerence for es is to ensure that GRS80 and WGS84\r\n // are considered identical\r\n return false;\r\n }\n else if (this.datum_type == Proj4js.common.PJD_3PARAM) {\r\n return (\r\n this.datum_params[0] == dest.datum_params[0] &&\r\n this.datum_params[1] == dest.datum_params[1] &&\r\n this.datum_params[2] == dest.datum_params[2]\r\n );\r\n }\n else if (this.datum_type == Proj4js.common.PJD_7PARAM) {\r\n return (\r\n this.datum_params[0] == dest.datum_params[0] &&\r\n this.datum_params[1] == dest.datum_params[1] &&\r\n this.datum_params[2] == dest.datum_params[2] &&\r\n this.datum_params[3] == dest.datum_params[3] &&\r\n this.datum_params[4] == dest.datum_params[4] &&\r\n this.datum_params[5] == dest.datum_params[5] &&\r\n this.datum_params[6] == dest.datum_params[6]\r\n );\r\n }\n else if (\r\n this.datum_type == Proj4js.common.PJD_GRIDSHIFT ||\r\n dest.datum_type == Proj4js.common.PJD_GRIDSHIFT\r\n ) {\r\n alert(\"ERROR: Grid shift transformations are not implemented.\");\r\n return false;\r\n }\n else {\r\n return true; // datums are equal\r\n }\r\n }, // cs_compare_datums()\r\n\r\n /*\r\n * The function Convert_Geodetic_To_Geocentric converts geodetic coordinates\r\n * (latitude, longitude, and height) to geocentric coordinates (X, Y, Z),\r\n * according to the current ellipsoid parameters.\r\n *\r\n * Latitude : Geodetic latitude in radians (input)\r\n * Longitude : Geodetic longitude in radians (input)\r\n * Height : Geodetic height, in meters (input)\r\n * X : Calculated Geocentric X coordinate, in meters (output)\r\n * Y : Calculated Geocentric Y coordinate, in meters (output)\r\n * Z : Calculated Geocentric Z coordinate, in meters (output)\r\n *\r\n */\r\n geodetic_to_geocentric: function(p) {\r\n var Longitude = p.x;\r\n var Latitude = p.y;\r\n var Height = p.z ? p.z : 0; //Z value not always supplied\r\n var X; // output\r\n var Y;\r\n var Z;\r\n\r\n var Error_Code = 0; // GEOCENT_NO_ERROR;\r\n var Rn; /* Earth radius at location */\r\n var Sin_Lat; /* Math.sin(Latitude) */\r\n var Sin2_Lat; /* Square of Math.sin(Latitude) */\r\n var Cos_Lat; /* Math.cos(Latitude) */\r\n\r\n /*\r\n ** Don't blow up if Latitude is just a little out of the value\r\n ** range as it may just be a rounding issue. Also removed longitude\r\n ** test, it should be wrapped by Math.cos() and Math.sin(). NFW for PROJ.4, Sep/2001.\r\n */\r\n if (\r\n Latitude < -Proj4js.common.HALF_PI &&\r\n Latitude > -1.001 * Proj4js.common.HALF_PI\r\n ) {\r\n Latitude = -Proj4js.common.HALF_PI;\r\n }\n else if (\r\n Latitude > Proj4js.common.HALF_PI &&\r\n Latitude < 1.001 * Proj4js.common.HALF_PI\r\n ) {\r\n Latitude = Proj4js.common.HALF_PI;\r\n }\n else if (\r\n Latitude < -Proj4js.common.HALF_PI ||\r\n Latitude > Proj4js.common.HALF_PI\r\n ) {\r\n /* Latitude out of range */\r\n Proj4js.reportError(\"geocent:lat out of range:\" + Latitude);\r\n return null;\r\n }\r\n\r\n if (Longitude > Proj4js.common.PI) Longitude -= 2 * Proj4js.common.PI;\r\n Sin_Lat = Math.sin(Latitude);\r\n Cos_Lat = Math.cos(Latitude);\r\n Sin2_Lat = Sin_Lat * Sin_Lat;\r\n Rn = this.a / Math.sqrt(1.0 - this.es * Sin2_Lat);\r\n X = (Rn + Height) * Cos_Lat * Math.cos(Longitude);\r\n Y = (Rn + Height) * Cos_Lat * Math.sin(Longitude);\r\n Z = (Rn * (1 - this.es) + Height) * Sin_Lat;\r\n\r\n p.x = X;\r\n p.y = Y;\r\n p.z = Z;\r\n return Error_Code;\r\n }, // cs_geodetic_to_geocentric()\r\n\r\n geocentric_to_geodetic: function(p) {\r\n /* local defintions and variables */\r\n /* end-criterium of loop, accuracy of sin(Latitude) */\r\n var genau = 1e-12;\r\n var genau2 = genau * genau;\r\n var maxiter = 30;\r\n\r\n var P; /* distance between semi-minor axis and location */\r\n var RR; /* distance between center and location */\r\n var CT; /* sin of geocentric latitude */\r\n var ST; /* cos of geocentric latitude */\r\n var RX;\r\n var RK;\r\n var RN; /* Earth radius at location */\r\n var CPHI0; /* cos of start or old geodetic latitude in iterations */\r\n var SPHI0; /* sin of start or old geodetic latitude in iterations */\r\n var CPHI; /* cos of searched geodetic latitude */\r\n var SPHI; /* sin of searched geodetic latitude */\r\n var SDPHI; /* end-criterium: addition-theorem of sin(Latitude(iter)-Latitude(iter-1)) */\r\n var At_Pole; /* indicates location is in polar region */\r\n var iter; /* # of continous iteration, max. 30 is always enough (s.a.) */\r\n\r\n var X = p.x;\r\n var Y = p.y;\r\n var Z = p.z ? p.z : 0.0; //Z value not always supplied\r\n var Longitude;\r\n var Latitude;\r\n var Height;\r\n\r\n At_Pole = false;\r\n P = Math.sqrt(X * X + Y * Y);\r\n RR = Math.sqrt(X * X + Y * Y + Z * Z);\r\n\r\n /* special cases for latitude and longitude */\r\n if (P / this.a < genau) {\r\n /* special case, if P=0. (X=0., Y=0.) */\r\n At_Pole = true;\r\n Longitude = 0.0;\r\n\r\n /* if (X,Y,Z)=(0.,0.,0.) then Height becomes semi-minor axis\r\n * of ellipsoid (=center of mass), Latitude becomes PI/2 */\r\n if (RR / this.a < genau) {\r\n Latitude = Proj4js.common.HALF_PI;\r\n Height = -this.b;\r\n return;\r\n }\r\n }\n else {\r\n /* ellipsoidal (geodetic) longitude\r\n * interval: -PI < Longitude <= +PI */\r\n Longitude = Math.atan2(Y, X);\r\n }\r\n\r\n /* --------------------------------------------------------------\r\n * Following iterative algorithm was developped by\r\n * \"Institut f�r Erdmessung\", University of Hannover, July 1988.\r\n * Internet: www.ife.uni-hannover.de\r\n * Iterative computation of CPHI,SPHI and Height.\r\n * Iteration of CPHI and SPHI to 10**-12 radian resp.\r\n * 2*10**-7 arcsec.\r\n * --------------------------------------------------------------\r\n */\r\n CT = Z / RR;\r\n ST = P / RR;\r\n RX = 1.0 / Math.sqrt(1.0 - this.es * (2.0 - this.es) * ST * ST);\r\n CPHI0 = ST * (1.0 - this.es) * RX;\r\n SPHI0 = CT * RX;\r\n iter = 0;\r\n\r\n /* loop to find sin(Latitude) resp. Latitude\r\n * until |sin(Latitude(iter)-Latitude(iter-1))| < genau */\r\n do {\r\n iter++;\r\n RN = this.a / Math.sqrt(1.0 - this.es * SPHI0 * SPHI0);\r\n\r\n /* ellipsoidal (geodetic) height */\r\n Height = P * CPHI0 + Z * SPHI0 - RN * (1.0 - this.es * SPHI0 * SPHI0);\r\n\r\n RK = (this.es * RN) / (RN + Height);\r\n RX = 1.0 / Math.sqrt(1.0 - RK * (2.0 - RK) * ST * ST);\r\n CPHI = ST * (1.0 - RK) * RX;\r\n SPHI = CT * RX;\r\n SDPHI = SPHI * CPHI0 - CPHI * SPHI0;\r\n CPHI0 = CPHI;\r\n SPHI0 = SPHI;\r\n } while (SDPHI * SDPHI > genau2 && iter < maxiter);\r\n\r\n /* ellipsoidal (geodetic) latitude */\r\n Latitude = Math.atan(SPHI / Math.abs(CPHI));\r\n\r\n p.x = Longitude;\r\n p.y = Latitude;\r\n p.z = Height;\r\n return p;\r\n }, // cs_geocentric_to_geodetic()\r\n\r\n /** Convert_Geocentric_To_Geodetic\r\n * The method used here is derived from 'An Improved Algorithm for\r\n * Geocentric to Geodetic Coordinate Conversion', by Ralph Toms, Feb 1996\r\n */\r\n geocentric_to_geodetic_noniter: function(p) {\r\n var X = p.x;\r\n var Y = p.y;\r\n var Z = p.z ? p.z : 0; //Z value not always supplied\r\n var Longitude;\r\n var Latitude;\r\n var Height;\r\n\r\n var W; /* distance from Z axis */\r\n var W2; /* square of distance from Z axis */\r\n var T0; /* initial estimate of vertical component */\r\n var T1; /* corrected estimate of vertical component */\r\n var S0; /* initial estimate of horizontal component */\r\n var S1; /* corrected estimate of horizontal component */\r\n var Sin_B0; /* Math.sin(B0), B0 is estimate of Bowring aux variable */\r\n var Sin3_B0; /* cube of Math.sin(B0) */\r\n var Cos_B0; /* Math.cos(B0) */\r\n var Sin_p1; /* Math.sin(phi1), phi1 is estimated latitude */\r\n var Cos_p1; /* Math.cos(phi1) */\r\n var Rn; /* Earth radius at location */\r\n var Sum; /* numerator of Math.cos(phi1) */\r\n var At_Pole; /* indicates location is in polar region */\r\n\r\n X = parseFloat(X); // cast from string to float\r\n Y = parseFloat(Y);\r\n Z = parseFloat(Z);\r\n\r\n At_Pole = false;\r\n if (X != 0.0) {\r\n Longitude = Math.atan2(Y, X);\r\n }\n else {\r\n if (Y > 0) {\r\n Longitude = Proj4js.common.HALF_PI;\r\n }\n else if (Y < 0) {\r\n Longitude = -Proj4js.common.HALF_PI;\r\n }\n else {\r\n At_Pole = true;\r\n Longitude = 0.0;\r\n if (Z > 0.0) {\r\n /* north pole */\r\n Latitude = Proj4js.common.HALF_PI;\r\n }\n else if (Z < 0.0) {\r\n /* south pole */\r\n Latitude = -Proj4js.common.HALF_PI;\r\n }\n else {\r\n /* center of earth */\r\n Latitude = Proj4js.common.HALF_PI;\r\n Height = -this.b;\r\n return;\r\n }\r\n }\r\n }\r\n W2 = X * X + Y * Y;\r\n W = Math.sqrt(W2);\r\n T0 = Z * Proj4js.common.AD_C;\r\n S0 = Math.sqrt(T0 * T0 + W2);\r\n Sin_B0 = T0 / S0;\r\n Cos_B0 = W / S0;\r\n Sin3_B0 = Sin_B0 * Sin_B0 * Sin_B0;\r\n T1 = Z + this.b * this.ep2 * Sin3_B0;\r\n Sum = W - this.a * this.es * Cos_B0 * Cos_B0 * Cos_B0;\r\n S1 = Math.sqrt(T1 * T1 + Sum * Sum);\r\n Sin_p1 = T1 / S1;\r\n Cos_p1 = Sum / S1;\r\n Rn = this.a / Math.sqrt(1.0 - this.es * Sin_p1 * Sin_p1);\r\n if (Cos_p1 >= Proj4js.common.COS_67P5) {\r\n Height = W / Cos_p1 - Rn;\r\n }\n else if (Cos_p1 <= -Proj4js.common.COS_67P5) {\r\n Height = W / -Cos_p1 - Rn;\r\n }\n else {\r\n Height = Z / Sin_p1 + Rn * (this.es - 1.0);\r\n }\r\n if (At_Pole == false) {\r\n Latitude = Math.atan(Sin_p1 / Cos_p1);\r\n }\r\n\r\n p.x = Longitude;\r\n p.y = Latitude;\r\n p.z = Height;\r\n return p;\r\n }, // geocentric_to_geodetic_noniter()\r\n\r\n /****************************************************************/\r\n // pj_geocentic_to_wgs84( p )\r\n // p = point to transform in geocentric coordinates (x,y,z)\r\n geocentric_to_wgs84: function(p) {\r\n if (this.datum_type == Proj4js.common.PJD_3PARAM) {\r\n // if( x[io] == HUGE_VAL )\r\n // continue;\r\n p.x += this.datum_params[0];\r\n p.y += this.datum_params[1];\r\n p.z += this.datum_params[2];\r\n }\n else if (this.datum_type == Proj4js.common.PJD_7PARAM) {\r\n var Dx_BF = this.datum_params[0];\r\n var Dy_BF = this.datum_params[1];\r\n var Dz_BF = this.datum_params[2];\r\n var Rx_BF = this.datum_params[3];\r\n var Ry_BF = this.datum_params[4];\r\n var Rz_BF = this.datum_params[5];\r\n var M_BF = this.datum_params[6];\r\n // if( x[io] == HUGE_VAL )\r\n // continue;\r\n var x_out = M_BF * (p.x - Rz_BF * p.y + Ry_BF * p.z) + Dx_BF;\r\n var y_out = M_BF * (Rz_BF * p.x + p.y - Rx_BF * p.z) + Dy_BF;\r\n var z_out = M_BF * (-Ry_BF * p.x + Rx_BF * p.y + p.z) + Dz_BF;\r\n p.x = x_out;\r\n p.y = y_out;\r\n p.z = z_out;\r\n }\r\n }, // cs_geocentric_to_wgs84\r\n\r\n /****************************************************************/\r\n // pj_geocentic_from_wgs84()\r\n // coordinate system definition,\r\n // point to transform in geocentric coordinates (x,y,z)\r\n geocentric_from_wgs84: function(p) {\r\n if (this.datum_type == Proj4js.common.PJD_3PARAM) {\r\n //if( x[io] == HUGE_VAL )\r\n // continue;\r\n p.x -= this.datum_params[0];\r\n p.y -= this.datum_params[1];\r\n p.z -= this.datum_params[2];\r\n }\n else if (this.datum_type == Proj4js.common.PJD_7PARAM) {\r\n var Dx_BF = this.datum_params[0];\r\n var Dy_BF = this.datum_params[1];\r\n var Dz_BF = this.datum_params[2];\r\n var Rx_BF = this.datum_params[3];\r\n var Ry_BF = this.datum_params[4];\r\n var Rz_BF = this.datum_params[5];\r\n var M_BF = this.datum_params[6];\r\n var x_tmp = (p.x - Dx_BF) / M_BF;\r\n var y_tmp = (p.y - Dy_BF) / M_BF;\r\n var z_tmp = (p.z - Dz_BF) / M_BF;\r\n //if( x[io] == HUGE_VAL )\r\n // continue;\r\n\r\n p.x = x_tmp + Rz_BF * y_tmp - Ry_BF * z_tmp;\r\n p.y = -Rz_BF * x_tmp + y_tmp + Rx_BF * z_tmp;\r\n p.z = Ry_BF * x_tmp - Rx_BF * y_tmp + z_tmp;\r\n } //cs_geocentric_from_wgs84()\r\n }\r\n});\r\n\r\n/** point object, nothing fancy, just allows values to be\r\n passed back and forth by reference rather than by value.\r\n Other point classes may be used as long as they have\r\n x and y properties, which will get modified in the transform method.\r\n*/\r\nProj4js.Point = Proj4js.Class({\r\n /**\r\n * Constructor: Proj4js.Point\r\n *\r\n * Parameters:\r\n * - x {float} or {Array} either the first coordinates component or\r\n * the full coordinates\r\n * - y {float} the second component\r\n * - z {float} the third component, optional.\r\n */\r\n initialize: function(x, y, z) {\r\n if (typeof x == \"object\") {\r\n this.x = x[0];\r\n this.y = x[1];\r\n this.z = x[2] || 0.0;\r\n }\n else if (typeof x == \"string\" && typeof y == \"undefined\") {\r\n var coords = x.split(\",\");\r\n this.x = parseFloat(coords[0]);\r\n this.y = parseFloat(coords[1]);\r\n this.z = parseFloat(coords[2]) || 0.0;\r\n }\n else {\r\n this.x = x;\r\n this.y = y;\r\n this.z = z || 0.0;\r\n }\r\n },\r\n\r\n /**\r\n * APIMethod: clone\r\n * Build a copy of a Proj4js.Point object.\r\n *\r\n * Return:\r\n * {Proj4js}.Point the cloned point.\r\n */\r\n clone: function() {\r\n return new Proj4js.Point(this.x, this.y, this.z);\r\n },\r\n\r\n /**\r\n * APIMethod: toString\r\n * Return a readable string version of the point\r\n *\r\n * Return:\r\n * {String} String representation of Proj4js.Point object.\r\n * (ex. \"x=5,y=42\")\r\n */\r\n toString: function() {\r\n return \"x=\" + this.x + \",y=\" + this.y;\r\n },\r\n\r\n /**\r\n * APIMethod: toShortString\r\n * Return a short string version of the point.\r\n *\r\n * Return:\r\n * {String} Shortened String representation of Proj4js.Point object.\r\n * (ex. \"5, 42\")\r\n */\r\n toShortString: function() {\r\n return this.x + \", \" + this.y;\r\n }\r\n});\r\n\r\nProj4js.PrimeMeridian = {\r\n greenwich: 0.0, //\"0dE\",\r\n lisbon: -9.131906111111, //\"9d07'54.862\\\"W\",\r\n paris: 2.337229166667, //\"2d20'14.025\\\"E\",\r\n bogota: -74.080916666667, //\"74d04'51.3\\\"W\",\r\n madrid: -3.687938888889, //\"3d41'16.58\\\"W\",\r\n rome: 12.452333333333, //\"12d27'8.4\\\"E\",\r\n bern: 7.439583333333, //\"7d26'22.5\\\"E\",\r\n jakarta: 106.807719444444, //\"106d48'27.79\\\"E\",\r\n ferro: -17.666666666667, //\"17d40'W\",\r\n brussels: 4.367975, //\"4d22'4.71\\\"E\",\r\n stockholm: 18.058277777778, //\"18d3'29.8\\\"E\",\r\n athens: 23.7163375, //\"23d42'58.815\\\"E\",\r\n oslo: 10.722916666667 //\"10d43'22.5\\\"E\"\r\n};\r\n\r\nProj4js.Ellipsoid = {\r\n MERIT: { a: 6378137.0, rf: 298.257, ellipseName: \"MERIT 1983\" },\r\n SGS85: {\r\n a: 6378136.0,\r\n rf: 298.257,\r\n ellipseName: \"Soviet Geodetic System 85\"\r\n },\r\n GRS80: {\r\n a: 6378137.0,\r\n rf: 298.257222101,\r\n ellipseName: \"GRS 1980(IUGG, 1980)\"\r\n },\r\n IAU76: { a: 6378140.0, rf: 298.257, ellipseName: \"IAU 1976\" },\r\n airy: { a: 6377563.396, b: 6356256.91, ellipseName: \"Airy 1830\" },\r\n \"APL4.\": { a: 6378137, rf: 298.25, ellipseName: \"Appl. Physics. 1965\" },\r\n NWL9D: { a: 6378145.0, rf: 298.25, ellipseName: \"Naval Weapons Lab., 1965\" },\r\n mod_airy: { a: 6377340.189, b: 6356034.446, ellipseName: \"Modified Airy\" },\r\n andrae: {\r\n a: 6377104.43,\r\n rf: 300.0,\r\n ellipseName: \"Andrae 1876 (Den., Iclnd.)\"\r\n },\r\n aust_SA: {\r\n a: 6378160.0,\r\n rf: 298.25,\r\n ellipseName: \"Australian Natl & S. Amer. 1969\"\r\n },\r\n GRS67: { a: 6378160.0, rf: 298.247167427, ellipseName: \"GRS 67(IUGG 1967)\" },\r\n bessel: { a: 6377397.155, rf: 299.1528128, ellipseName: \"Bessel 1841\" },\r\n bess_nam: {\r\n a: 6377483.865,\r\n rf: 299.1528128,\r\n ellipseName: \"Bessel 1841 (Namibia)\"\r\n },\r\n clrk66: { a: 6378206.4, b: 6356583.8, ellipseName: \"Clarke 1866\" },\r\n clrk80: { a: 6378249.145, rf: 293.4663, ellipseName: \"Clarke 1880 mod.\" },\r\n CPM: {\r\n a: 6375738.7,\r\n rf: 334.29,\r\n ellipseName: \"Comm. des Poids et Mesures 1799\"\r\n },\r\n delmbr: { a: 6376428.0, rf: 311.5, ellipseName: \"Delambre 1810 (Belgium)\" },\r\n engelis: { a: 6378136.05, rf: 298.2566, ellipseName: \"Engelis 1985\" },\r\n evrst30: { a: 6377276.345, rf: 300.8017, ellipseName: \"Everest 1830\" },\r\n evrst48: { a: 6377304.063, rf: 300.8017, ellipseName: \"Everest 1948\" },\r\n evrst56: { a: 6377301.243, rf: 300.8017, ellipseName: \"Everest 1956\" },\r\n evrst69: { a: 6377295.664, rf: 300.8017, ellipseName: \"Everest 1969\" },\r\n evrstSS: {\r\n a: 6377298.556,\r\n rf: 300.8017,\r\n ellipseName: \"Everest (Sabah & Sarawak)\"\r\n },\r\n fschr60: {\r\n a: 6378166.0,\r\n rf: 298.3,\r\n ellipseName: \"Fischer (Mercury Datum) 1960\"\r\n },\r\n fschr60m: { a: 6378155.0, rf: 298.3, ellipseName: \"Fischer 1960\" },\r\n fschr68: { a: 6378150.0, rf: 298.3, ellipseName: \"Fischer 1968\" },\r\n helmert: { a: 6378200.0, rf: 298.3, ellipseName: \"Helmert 1906\" },\r\n hough: { a: 6378270.0, rf: 297.0, ellipseName: \"Hough\" },\r\n intl: {\r\n a: 6378388.0,\r\n rf: 297.0,\r\n ellipseName: \"International 1909 (Hayford)\"\r\n },\r\n kaula: { a: 6378163.0, rf: 298.24, ellipseName: \"Kaula 1961\" },\r\n lerch: { a: 6378139.0, rf: 298.257, ellipseName: \"Lerch 1979\" },\r\n mprts: { a: 6397300.0, rf: 191.0, ellipseName: \"Maupertius 1738\" },\r\n new_intl: {\r\n a: 6378157.5,\r\n b: 6356772.2,\r\n ellipseName: \"New International 1967\"\r\n },\r\n plessis: {\r\n a: 6376523.0,\r\n rf: 6355863.0,\r\n ellipseName: \"Plessis 1817 (France)\"\r\n },\r\n krass: { a: 6378245.0, rf: 298.3, ellipseName: \"Krassovsky, 1942\" },\r\n SEasia: { a: 6378155.0, b: 6356773.3205, ellipseName: \"Southeast Asia\" },\r\n walbeck: { a: 6376896.0, b: 6355834.8467, ellipseName: \"Walbeck\" },\r\n WGS60: { a: 6378165.0, rf: 298.3, ellipseName: \"WGS 60\" },\r\n WGS66: { a: 6378145.0, rf: 298.25, ellipseName: \"WGS 66\" },\r\n WGS72: { a: 6378135.0, rf: 298.26, ellipseName: \"WGS 72\" },\r\n WGS84: { a: 6378137.0, rf: 298.257223563, ellipseName: \"WGS 84\" },\r\n sphere: {\r\n a: 6370997.0,\r\n b: 6370997.0,\r\n ellipseName: \"Normal Sphere (r=6370997)\"\r\n }\r\n};\r\n\r\nProj4js.Datum = {\r\n WGS84: { towgs84: \"0,0,0\", ellipse: \"WGS84\", datumName: \"WGS84\" },\r\n GGRS87: {\r\n towgs84: \"-199.87,74.79,246.62\",\r\n ellipse: \"GRS80\",\r\n datumName: \"Greek_Geodetic_Reference_System_1987\"\r\n },\r\n NAD83: {\r\n towgs84: \"0,0,0\",\r\n ellipse: \"GRS80\",\r\n datumName: \"North_American_Datum_1983\"\r\n },\r\n NAD27: {\r\n nadgrids: \"@conus,@alaska,@ntv2_0.gsb,@ntv1_can.dat\",\r\n ellipse: \"clrk66\",\r\n datumName: \"North_American_Datum_1927\"\r\n },\r\n potsdam: {\r\n towgs84: \"606.0,23.0,413.0\",\r\n ellipse: \"bessel\",\r\n datumName: \"Potsdam Rauenberg 1950 DHDN\"\r\n },\r\n carthage: {\r\n towgs84: \"-263.0,6.0,431.0\",\r\n ellipse: \"clark80\",\r\n datumName: \"Carthage 1934 Tunisia\"\r\n },\r\n hermannskogel: {\r\n towgs84: \"653.0,-212.0,449.0\",\r\n ellipse: \"bessel\",\r\n datumName: \"Hermannskogel\"\r\n },\r\n ire65: {\r\n towgs84: \"482.530,-130.596,564.557,-1.042,-0.214,-0.631,8.15\",\r\n ellipse: \"mod_airy\",\r\n datumName: \"Ireland 1965\"\r\n },\r\n nzgd49: {\r\n towgs84: \"59.47,-5.04,187.44,0.47,-0.1,1.024,-4.5993\",\r\n ellipse: \"intl\",\r\n datumName: \"New Zealand Geodetic Datum 1949\"\r\n },\r\n OSGB36: {\r\n towgs84: \"446.448,-125.157,542.060,0.1502,0.2470,0.8421,-20.4894\",\r\n ellipse: \"airy\",\r\n datumName: \"Airy 1830\"\r\n }\r\n};\r\n\r\nProj4js.WGS84 = new Proj4js.Proj(\"WGS84\");\r\nProj4js.Datum[\"OSB36\"] = Proj4js.Datum[\"OSGB36\"]; //as returned from spatialreference.org\r\n\r\n//lookup table to go from the projection name in WKT to the Proj4js projection name\r\n//build this out as required\r\nProj4js.wktProjections = {\r\n \"Lambert Tangential Conformal Conic Projection\": \"lcc\",\r\n Mercator: \"merc\",\r\n \"Popular Visualisation Pseudo Mercator\": \"merc\",\r\n Mercator_1SP: \"merc\",\r\n Transverse_Mercator: \"tmerc\",\r\n \"Transverse Mercator\": \"tmerc\",\r\n \"Lambert Azimuthal Equal Area\": \"laea\",\r\n \"Universal Transverse Mercator System\": \"utm\"\r\n};\r\n\r\n/* ======================================================================\r\n projCode/aea.js\r\n ====================================================================== */\r\n\r\n/*******************************************************************************\r\nNAME ALBERS CONICAL EQUAL AREA \r\n\r\nPURPOSE:\tTransforms input longitude and latitude to Easting and Northing\r\n\t\tfor the Albers Conical Equal Area projection. The longitude\r\n\t\tand latitude must be in radians. The Easting and Northing\r\n\t\tvalues will be returned in meters.\r\n\r\nPROGRAMMER DATE\r\n---------- ----\r\nT. Mittan, \tFeb, 1992\r\n\r\nALGORITHM REFERENCES\r\n\r\n1. Snyder, John P., \"Map Projections--A Working Manual\", U.S. Geological\r\n Survey Professional Paper 1395 (Supersedes USGS Bulletin 1532), United\r\n State Government Printing Office, Washington D.C., 1987.\r\n\r\n2. Snyder, John P. and Voxland, Philip M., \"An Album of Map Projections\",\r\n U.S. Geological Survey Professional Paper 1453 , United State Government\r\n Printing Office, Washington D.C., 1989.\r\n*******************************************************************************/\r\n\r\nProj4js.Proj.aea = {\r\n init: function() {\r\n if (Math.abs(this.lat1 + this.lat2) < Proj4js.common.EPSLN) {\r\n Proj4js.reportError(\"aeaInitEqualLatitudes\");\r\n return;\r\n }\r\n this.temp = this.b / this.a;\r\n this.es = 1.0 - Math.pow(this.temp, 2);\r\n this.e3 = Math.sqrt(this.es);\r\n\r\n this.sin_po = Math.sin(this.lat1);\r\n this.cos_po = Math.cos(this.lat1);\r\n this.t1 = this.sin_po;\r\n this.con = this.sin_po;\r\n this.ms1 = Proj4js.common.msfnz(this.e3, this.sin_po, this.cos_po);\r\n this.qs1 = Proj4js.common.qsfnz(this.e3, this.sin_po, this.cos_po);\r\n\r\n this.sin_po = Math.sin(this.lat2);\r\n this.cos_po = Math.cos(this.lat2);\r\n this.t2 = this.sin_po;\r\n this.ms2 = Proj4js.common.msfnz(this.e3, this.sin_po, this.cos_po);\r\n this.qs2 = Proj4js.common.qsfnz(this.e3, this.sin_po, this.cos_po);\r\n\r\n this.sin_po = Math.sin(this.lat0);\r\n this.cos_po = Math.cos(this.lat0);\r\n this.t3 = this.sin_po;\r\n this.qs0 = Proj4js.common.qsfnz(this.e3, this.sin_po, this.cos_po);\r\n\r\n if (Math.abs(this.lat1 - this.lat2) > Proj4js.common.EPSLN) {\r\n this.ns0 =\r\n (this.ms1 * this.ms1 - this.ms2 * this.ms2) / (this.qs2 - this.qs1);\r\n }\n else {\r\n this.ns0 = this.con;\r\n }\r\n this.c = this.ms1 * this.ms1 + this.ns0 * this.qs1;\r\n this.rh = (this.a * Math.sqrt(this.c - this.ns0 * this.qs0)) / this.ns0;\r\n },\r\n\r\n /* Albers Conical Equal Area forward equations--mapping lat,long to x,y\r\n -------------------------------------------------------------------*/\r\n forward: function(p) {\r\n var lon = p.x;\r\n var lat = p.y;\r\n\r\n this.sin_phi = Math.sin(lat);\r\n this.cos_phi = Math.cos(lat);\r\n\r\n var qs = Proj4js.common.qsfnz(this.e3, this.sin_phi, this.cos_phi);\r\n var rh1 = (this.a * Math.sqrt(this.c - this.ns0 * qs)) / this.ns0;\r\n var theta = this.ns0 * Proj4js.common.adjust_lon(lon - this.long0);\r\n var x = rh1 * Math.sin(theta) + this.x0;\r\n var y = this.rh - rh1 * Math.cos(theta) + this.y0;\r\n\r\n p.x = x;\r\n p.y = y;\r\n return p;\r\n },\r\n\r\n inverse: function(p) {\r\n var rh1, qs, con, theta, lon, lat;\r\n\r\n p.x -= this.x0;\r\n p.y = this.rh - p.y + this.y0;\r\n if (this.ns0 >= 0) {\r\n rh1 = Math.sqrt(p.x * p.x + p.y * p.y);\r\n con = 1.0;\r\n }\n else {\r\n rh1 = -Math.sqrt(p.x * p.x + p.y * p.y);\r\n con = -1.0;\r\n }\r\n theta = 0.0;\r\n if (rh1 != 0.0) {\r\n theta = Math.atan2(con * p.x, con * p.y);\r\n }\r\n con = (rh1 * this.ns0) / this.a;\r\n qs = (this.c - con * con) / this.ns0;\r\n if (this.e3 >= 1e-10) {\r\n con =\r\n 1 -\r\n (0.5 * (1.0 - this.es) * Math.log((1.0 - this.e3) / (1.0 + this.e3))) /\r\n this.e3;\r\n if (Math.abs(Math.abs(con) - Math.abs(qs)) > 0.0000000001) {\r\n lat = this.phi1z(this.e3, qs);\r\n }\n else {\r\n if (qs >= 0) {\r\n lat = 0.5 * Proj4js.common.PI;\r\n }\n else {\r\n lat = -0.5 * Proj4js.common.PI;\r\n }\r\n }\r\n }\n else {\r\n lat = this.phi1z(this.e3, qs);\r\n }\r\n\r\n lon = Proj4js.common.adjust_lon(theta / this.ns0 + this.long0);\r\n p.x = lon;\r\n p.y = lat;\r\n return p;\r\n },\r\n\r\n /* Function to compute phi1, the latitude for the inverse of the\r\n Albers Conical Equal-Area projection.\r\n-------------------------------------------*/\r\n phi1z: function(eccent, qs) {\r\n var sinphi, cosphi, con, com, dphi;\r\n var phi = Proj4js.common.asinz(0.5 * qs);\r\n if (eccent < Proj4js.common.EPSLN) return phi;\r\n\r\n var eccnts = eccent * eccent;\r\n for (var i = 1; i <= 25; i++) {\r\n sinphi = Math.sin(phi);\r\n cosphi = Math.cos(phi);\r\n con = eccent * sinphi;\r\n com = 1.0 - con * con;\r\n dphi =\r\n ((0.5 * com * com) / cosphi) *\r\n (qs / (1.0 - eccnts) -\r\n sinphi / com +\r\n (0.5 / eccent) * Math.log((1.0 - con) / (1.0 + con)));\r\n phi = phi + dphi;\r\n if (Math.abs(dphi) <= 1e-7) return phi;\r\n }\r\n Proj4js.reportError(\"aea:phi1z:Convergence error\");\r\n return null;\r\n }\r\n};\r\n\r\n/* ======================================================================\r\n projCode/sterea.js\r\n ====================================================================== */\r\n\r\nProj4js.Proj.sterea = {\r\n dependsOn: \"gauss\",\r\n\r\n init: function() {\r\n Proj4js.Proj[\"gauss\"].init.apply(this);\r\n if (!this.rc) {\r\n Proj4js.reportError(\"sterea:init:E_ERROR_0\");\r\n return;\r\n }\r\n this.sinc0 = Math.sin(this.phic0);\r\n this.cosc0 = Math.cos(this.phic0);\r\n this.R2 = 2.0 * this.rc;\r\n if (!this.title) this.title = \"Oblique Stereographic Alternative\";\r\n },\r\n\r\n forward: function(p) {\r\n var sinc, cosc, cosl, k;\r\n p.x = Proj4js.common.adjust_lon(\r\n p.x - this.long0\r\n ); /* adjust del longitude */\r\n Proj4js.Proj[\"gauss\"].forward.apply(this, [p]);\r\n sinc = Math.sin(p.y);\r\n cosc = Math.cos(p.y);\r\n cosl = Math.cos(p.x);\r\n k =\r\n (this.k0 * this.R2) /\r\n (1.0 + this.sinc0 * sinc + this.cosc0 * cosc * cosl);\r\n p.x = k * cosc * Math.sin(p.x);\r\n p.y = k * (this.cosc0 * sinc - this.sinc0 * cosc * cosl);\r\n p.x = this.a * p.x + this.x0;\r\n p.y = this.a * p.y + this.y0;\r\n return p;\r\n },\r\n\r\n inverse: function(p) {\r\n var sinc, cosc, lon, lat, rho;\r\n p.x = (p.x - this.x0) / this.a; /* descale and de-offset */\r\n p.y = (p.y - this.y0) / this.a;\r\n\r\n p.x /= this.k0;\r\n p.y /= this.k0;\r\n if ((rho = Math.sqrt(p.x * p.x + p.y * p.y))) {\r\n var c = 2.0 * Math.atan2(rho, this.R2);\r\n sinc = Math.sin(c);\r\n cosc = Math.cos(c);\r\n lat = Math.asin(cosc * this.sinc0 + (p.y * sinc * this.cosc0) / rho);\r\n lon = Math.atan2(\r\n p.x * sinc,\r\n rho * this.cosc0 * cosc - p.y * this.sinc0 * sinc\r\n );\r\n }\n else {\r\n lat = this.phic0;\r\n lon = 0;\r\n }\r\n\r\n p.x = lon;\r\n p.y = lat;\r\n Proj4js.Proj[\"gauss\"].inverse.apply(this, [p]);\r\n p.x = Proj4js.common.adjust_lon(\r\n p.x + this.long0\r\n ); /* adjust longitude to CM */\r\n return p;\r\n }\r\n};\r\n\r\n/* ======================================================================\r\n projCode/poly.js\r\n ====================================================================== */\r\n\r\n/* Function to compute, phi4, the latitude for the inverse of the\r\n Polyconic projection.\r\n------------------------------------------------------------*/\r\nfunction phi4z(eccent, e0, e1, e2, e3, a, b, c, phi) {\r\n var sinphi, sin2ph, tanphi, ml, mlp, con1, con2, con3, dphi, i;\r\n\r\n phi = a;\r\n for (i = 1; i <= 15; i++) {\r\n sinphi = Math.sin(phi);\r\n tanphi = Math.tan(phi);\r\n c = tanphi * Math.sqrt(1.0 - eccent * sinphi * sinphi);\r\n sin2ph = Math.sin(2.0 * phi);\r\n /*\r\n\t\tml = e0 * *phi - e1 * sin2ph + e2 * sin (4.0 * *phi);\r\n\t\tmlp = e0 - 2.0 * e1 * cos (2.0 * *phi) + 4.0 * e2 * cos (4.0 * *phi);\r\n\t\t*/\r\n ml =\r\n e0 * phi -\r\n e1 * sin2ph +\r\n e2 * Math.sin(4.0 * phi) -\r\n e3 * Math.sin(6.0 * phi);\r\n mlp =\r\n e0 -\r\n 2.0 * e1 * Math.cos(2.0 * phi) +\r\n 4.0 * e2 * Math.cos(4.0 * phi) -\r\n 6.0 * e3 * Math.cos(6.0 * phi);\r\n con1 = 2.0 * ml + c * (ml * ml + b) - 2.0 * a * (c * ml + 1.0);\r\n con2 = (eccent * sin2ph * (ml * ml + b - 2.0 * a * ml)) / (2.0 * c);\r\n con3 = 2.0 * (a - ml) * (c * mlp - 2.0 / sin2ph) - 2.0 * mlp;\r\n dphi = con1 / (con2 + con3);\r\n phi += dphi;\r\n if (Math.abs(dphi) <= 0.0000000001) return phi;\r\n }\r\n Proj4js.reportError(\"phi4z: No convergence\");\r\n return null;\r\n}\r\n\r\n/* Function to compute the constant e4 from the input of the eccentricity\r\n of the spheroid, x. This constant is used in the Polar Stereographic\r\n projection.\r\n--------------------------------------------------------------------*/\r\nfunction e4fn(x) {\r\n var con, com;\r\n con = 1.0 + x;\r\n com = 1.0 - x;\r\n return Math.sqrt(Math.pow(con, con) * Math.pow(com, com));\r\n}\r\n\r\n/*******************************************************************************\r\nNAME POLYCONIC \r\n\r\nPURPOSE:\tTransforms input longitude and latitude to Easting and\r\n\t\tNorthing for the Polyconic projection. The\r\n\t\tlongitude and latitude must be in radians. The Easting\r\n\t\tand Northing values will be returned in meters.\r\n\r\nPROGRAMMER DATE\r\n---------- ----\r\nT. Mittan\t\tMar, 1993\r\n\r\nALGORITHM REFERENCES\r\n\r\n1. Snyder, John P., \"Map Projections--A Working Manual\", U.S. Geological\r\n Survey Professional Paper 1395 (Supersedes USGS Bulletin 1532), United\r\n State Government Printing Office, Washington D.C., 1987.\r\n\r\n2. Snyder, John P. and Voxland, Philip M., \"An Album of Map Projections\",\r\n U.S. Geological Survey Professional Paper 1453 , United State Government\r\n Printing Office, Washington D.C., 1989.\r\n*******************************************************************************/\r\n\r\nProj4js.Proj.poly = {\r\n /* Initialize the POLYCONIC projection\r\n\t ----------------------------------*/\r\n init: function() {\r\n var temp; /* temporary variable\t\t*/\r\n if (this.lat0 == 0) this.lat0 = 90; //this.lat0 ca\r\n\r\n /* Place parameters in static storage for common use\r\n\t\t -------------------------------------------------*/\r\n this.temp = this.b / this.a;\r\n this.es = 1.0 - Math.pow(this.temp, 2); // devait etre dans tmerc.js mais n y est pas donc je commente sinon retour de valeurs nulles\r\n this.e = Math.sqrt(this.es);\r\n this.e0 = Proj4js.common.e0fn(this.es);\r\n this.e1 = Proj4js.common.e1fn(this.es);\r\n this.e2 = Proj4js.common.e2fn(this.es);\r\n this.e3 = Proj4js.common.e3fn(this.es);\r\n this.ml0 = Proj4js.common.mlfn(\r\n this.e0,\r\n this.e1,\r\n this.e2,\r\n this.e3,\r\n this.lat0\r\n ); //si que des zeros le calcul ne se fait pas\r\n //if (!this.ml0) {this.ml0=0;}\r\n },\r\n\r\n /* Polyconic forward equations--mapping lat,long to x,y\r\n\t ---------------------------------------------------*/\r\n forward: function(p) {\r\n var sinphi, cosphi; /* sin and cos value\t\t\t\t*/\r\n var al; /* temporary values\t\t\t\t*/\r\n var c; /* temporary values\t\t\t\t*/\r\n var con, ml; /* cone constant, small m\t\t\t*/\r\n var ms; /* small m\t\t\t\t\t*/\r\n var x, y;\r\n\r\n var lon = p.x;\r\n var lat = p.y;\r\n\r\n con = Proj4js.common.adjust_lon(lon - this.long0);\r\n if (Math.abs(lat) <= 0.0000001) {\r\n x = this.x0 + this.a * con;\r\n y = this.y0 - this.a * this.ml0;\r\n }\n else {\r\n sinphi = Math.sin(lat);\r\n cosphi = Math.cos(lat);\r\n\r\n ml = Proj4js.common.mlfn(this.e0, this.e1, this.e2, this.e3, lat);\r\n ms = Proj4js.common.msfnz(this.e, sinphi, cosphi);\r\n con = sinphi;\r\n x = this.x0 + (this.a * ms * Math.sin(con)) / sinphi;\r\n y =\r\n this.y0 +\r\n this.a * (ml - this.ml0 + (ms * (1.0 - Math.cos(con))) / sinphi);\r\n }\r\n\r\n p.x = x;\r\n p.y = y;\r\n return p;\r\n },\r\n\r\n /* Inverse equations\r\n\t-----------------*/\r\n inverse: function(p) {\r\n var sin_phi, cos_phi; /* sin and cos value\t\t\t\t*/\r\n var al; /* temporary values\t\t\t\t*/\r\n var b; /* temporary values\t\t\t\t*/\r\n var c; /* temporary values\t\t\t\t*/\r\n var con, ml; /* cone constant, small m\t\t\t*/\r\n var iflg; /* error flag\t\t\t\t\t*/\r\n var lon, lat;\r\n p.x -= this.x0;\r\n p.y -= this.y0;\r\n al = this.ml0 + p.y / this.a;\r\n iflg = 0;\r\n\r\n if (Math.abs(al) <= 0.0000001) {\r\n lon = p.x / this.a + this.long0;\r\n lat = 0.0;\r\n }\n else {\r\n b = al * al + (p.x / this.a) * (p.x / this.a);\r\n iflg = phi4z(\r\n this.es,\r\n this.e0,\r\n this.e1,\r\n this.e2,\r\n this.e3,\r\n this.al,\r\n b,\r\n c,\r\n lat\r\n );\r\n if (iflg != 1) return iflg;\r\n lon = Proj4js.common.adjust_lon(\r\n Proj4js.common.asinz((p.x * c) / this.a) / Math.sin(lat) + this.long0\r\n );\r\n }\r\n\r\n p.x = lon;\r\n p.y = lat;\r\n return p;\r\n }\r\n};\r\n\r\n/* ======================================================================\r\n projCode/equi.js\r\n ====================================================================== */\r\n\r\n/*******************************************************************************\r\nNAME EQUIRECTANGULAR \r\n\r\nPURPOSE:\tTransforms input longitude and latitude to Easting and\r\n\t\tNorthing for the Equirectangular projection. The\r\n\t\tlongitude and latitude must be in radians. The Easting\r\n\t\tand Northing values will be returned in meters.\r\n\r\nPROGRAMMER DATE\r\n---------- ----\r\nT. Mittan\t\tMar, 1993\r\n\r\nALGORITHM REFERENCES\r\n\r\n1. Snyder, John P., \"Map Projections--A Working Manual\", U.S. Geological\r\n Survey Professional Paper 1395 (Supersedes USGS Bulletin 1532), United\r\n State Government Printing Office, Washington D.C., 1987.\r\n\r\n2. Snyder, John P. and Voxland, Philip M., \"An Album of Map Projections\",\r\n U.S. Geological Survey Professional Paper 1453 , United State Government\r\n Printing Office, Washington D.C., 1989.\r\n*******************************************************************************/\r\nProj4js.Proj.equi = {\r\n init: function() {\r\n if (!this.x0) this.x0 = 0;\r\n if (!this.y0) this.y0 = 0;\r\n if (!this.lat0) this.lat0 = 0;\r\n if (!this.long0) this.long0 = 0;\r\n ///this.t2;\r\n },\r\n\r\n /* Equirectangular forward equations--mapping lat,long to x,y\r\n ---------------------------------------------------------*/\r\n forward: function(p) {\r\n var lon = p.x;\r\n var lat = p.y;\r\n\r\n var dlon = Proj4js.common.adjust_lon(lon - this.long0);\r\n var x = this.x0 + this.a * dlon * Math.cos(this.lat0);\r\n var y = this.y0 + this.a * lat;\r\n\r\n this.t1 = x;\r\n this.t2 = Math.cos(this.lat0);\r\n p.x = x;\r\n p.y = y;\r\n return p;\r\n }, //equiFwd()\r\n\r\n /* Equirectangular inverse equations--mapping x,y to lat/long\r\n ---------------------------------------------------------*/\r\n inverse: function(p) {\r\n p.x -= this.x0;\r\n p.y -= this.y0;\r\n var lat = p.y / this.a;\r\n\r\n if (Math.abs(lat) > Proj4js.common.HALF_PI) {\r\n Proj4js.reportError(\"equi:Inv:DataError\");\r\n }\r\n var lon = Proj4js.common.adjust_lon(\r\n this.long0 + p.x / (this.a * Math.cos(this.lat0))\r\n );\r\n p.x = lon;\r\n p.y = lat;\r\n } //equiInv()\r\n};\r\n\r\n/* ======================================================================\r\n projCode/merc.js\r\n ====================================================================== */\r\n\r\n/*******************************************************************************\r\nNAME MERCATOR\r\n\r\nPURPOSE:\tTransforms input longitude and latitude to Easting and\r\n\t\tNorthing for the Mercator projection. The\r\n\t\tlongitude and latitude must be in radians. The Easting\r\n\t\tand Northing values will be returned in meters.\r\n\r\nPROGRAMMER DATE\r\n---------- ----\r\nD. Steinwand, EROS Nov, 1991\r\nT. Mittan\t\tMar, 1993\r\n\r\nALGORITHM REFERENCES\r\n\r\n1. Snyder, John P., \"Map Projections--A Working Manual\", U.S. Geological\r\n Survey Professional Paper 1395 (Supersedes USGS Bulletin 1532), United\r\n State Government Printing Office, Washington D.C., 1987.\r\n\r\n2. Snyder, John P. and Voxland, Philip M., \"An Album of Map Projections\",\r\n U.S. Geological Survey Professional Paper 1453 , United State Government\r\n Printing Office, Washington D.C., 1989.\r\n*******************************************************************************/\r\n\r\n//static double r_major = a;\t\t /* major axis \t\t\t\t*/\r\n//static double r_minor = b;\t\t /* minor axis \t\t\t\t*/\r\n//static double lon_center = long0;\t /* Center longitude (projection center) */\r\n//static double lat_origin = lat0;\t /* center latitude\t\t\t*/\r\n//static double e,es;\t\t /* eccentricity constants\t\t*/\r\n//static double m1;\t\t /* small value m\t\t\t*/\r\n//static double false_northing = y0; /* y offset in meters\t\t\t*/\r\n//static double false_easting = x0;\t /* x offset in meters\t\t\t*/\r\n//scale_fact = k0\r\n\r\nProj4js.Proj.merc = {\r\n init: function() {\r\n //?this.temp = this.r_minor / this.r_major;\r\n //this.temp = this.b / this.a;\r\n //this.es = 1.0 - Math.sqrt(this.temp);\r\n //this.e = Math.sqrt( this.es );\r\n //?this.m1 = Math.cos(this.lat_origin) / (Math.sqrt( 1.0 - this.es * Math.sin(this.lat_origin) * Math.sin(this.lat_origin)));\r\n //this.m1 = Math.cos(0.0) / (Math.sqrt( 1.0 - this.es * Math.sin(0.0) * Math.sin(0.0)));\r\n if (this.lat_ts) {\r\n if (this.sphere) {\r\n this.k0 = Math.cos(this.lat_ts);\r\n }\n else {\r\n this.k0 = Proj4js.common.msfnz(\r\n this.es,\r\n Math.sin(this.lat_ts),\r\n Math.cos(this.lat_ts)\r\n );\r\n }\r\n }\r\n },\r\n\r\n /* Mercator forward equations--mapping lat,long to x,y\r\n --------------------------------------------------*/\r\n\r\n forward: function(p) {\r\n //alert(\"ll2m coords : \"+coords);\r\n var lon = p.x;\r\n var lat = p.y;\r\n // convert to radians\r\n if (\r\n lat * Proj4js.common.R2D > 90.0 &&\r\n lat * Proj4js.common.R2D < -90.0 &&\r\n lon * Proj4js.common.R2D > 180.0 &&\r\n lon * Proj4js.common.R2D < -180.0\r\n ) {\r\n Proj4js.reportError(\r\n \"merc:forward: llInputOutOfRange: \" + lon + \" : \" + lat\r\n );\r\n return null;\r\n }\r\n\r\n var x, y;\r\n if (\r\n Math.abs(Math.abs(lat) - Proj4js.common.HALF_PI) <= Proj4js.common.EPSLN\r\n ) {\r\n Proj4js.reportError(\"merc:forward: ll2mAtPoles\");\r\n return null;\r\n }\n else {\r\n if (this.sphere) {\r\n x =\r\n this.x0 +\r\n this.a * this.k0 * Proj4js.common.adjust_lon(lon - this.long0);\r\n y =\r\n this.y0 +\r\n this.a *\r\n this.k0 *\r\n Math.log(Math.tan(Proj4js.common.FORTPI + 0.5 * lat));\r\n }\n else {\r\n var sinphi = Math.sin(lat);\r\n var ts = Proj4js.common.tsfnz(this.e, lat, sinphi);\r\n x =\r\n this.x0 +\r\n this.a * this.k0 * Proj4js.common.adjust_lon(lon - this.long0);\r\n y = this.y0 - this.a * this.k0 * Math.log(ts);\r\n }\r\n p.x = x;\r\n p.y = y;\r\n return p;\r\n }\r\n },\r\n\r\n /* Mercator inverse equations--mapping x,y to lat/long\r\n --------------------------------------------------*/\r\n inverse: function(p) {\r\n var x = p.x - this.x0;\r\n var y = p.y - this.y0;\r\n var lon, lat;\r\n\r\n if (this.sphere) {\r\n lat =\r\n Proj4js.common.HALF_PI -\r\n 2.0 * Math.atan(Math.exp((-y / this.a) * this.k0));\r\n }\n else {\r\n var ts = Math.exp(-y / (this.a * this.k0));\r\n lat = Proj4js.common.phi2z(this.e, ts);\r\n if (lat == -9999) {\r\n Proj4js.reportError(\"merc:inverse: lat = -9999\");\r\n return null;\r\n }\r\n }\r\n lon = Proj4js.common.adjust_lon(this.long0 + x / (this.a * this.k0));\r\n\r\n p.x = lon;\r\n p.y = lat;\r\n return p;\r\n }\r\n};\r\n\r\n/* ======================================================================\r\n projCode/utm.js\r\n ====================================================================== */\r\n\r\n/*******************************************************************************\r\nNAME TRANSVERSE MERCATOR\r\n\r\nPURPOSE:\tTransforms input longitude and latitude to Easting and\r\n\t\tNorthing for the Transverse Mercator projection. The\r\n\t\tlongitude and latitude must be in radians. The Easting\r\n\t\tand Northing values will be returned in meters.\r\n\r\nALGORITHM REFERENCES\r\n\r\n1. Snyder, John P., \"Map Projections--A Working Manual\", U.S. Geological\r\n Survey Professional Paper 1395 (Supersedes USGS Bulletin 1532), United\r\n State Government Printing Office, Washington D.C., 1987.\r\n\r\n2. Snyder, John P. and Voxland, Philip M., \"An Album of Map Projections\",\r\n U.S. Geological Survey Professional Paper 1453 , United State Government\r\n Printing Office, Washington D.C., 1989.\r\n*******************************************************************************/\r\n\r\n/**\r\n Initialize Transverse Mercator projection\r\n*/\r\n\r\nProj4js.Proj.utm = {\r\n dependsOn: \"tmerc\",\r\n\r\n init: function() {\r\n if (!this.zone) {\r\n Proj4js.reportError(\"utm:init: zone must be specified for UTM\");\r\n return;\r\n }\r\n this.lat0 = 0.0;\r\n this.long0 = (6 * Math.abs(this.zone) - 183) * Proj4js.common.D2R;\r\n this.x0 = 500000.0;\r\n this.y0 = this.utmSouth ? 10000000.0 : 0.0;\r\n this.k0 = 0.9996;\r\n\r\n Proj4js.Proj[\"tmerc\"].init.apply(this);\r\n this.forward = Proj4js.Proj[\"tmerc\"].forward;\r\n this.inverse = Proj4js.Proj[\"tmerc\"].inverse;\r\n }\r\n};\r\n/* ======================================================================\r\n projCode/eqdc.js\r\n ====================================================================== */\r\n\r\n/*******************************************************************************\r\nNAME EQUIDISTANT CONIC \r\n\r\nPURPOSE:\tTransforms input longitude and latitude to Easting and Northing\r\n\t\tfor the Equidistant Conic projection. The longitude and\r\n\t\tlatitude must be in radians. The Easting and Northing values\r\n\t\twill be returned in meters.\r\n\r\nPROGRAMMER DATE\r\n---------- ----\r\nT. Mittan\t\tMar, 1993\r\n\r\nALGORITHM REFERENCES\r\n\r\n1. Snyder, John P., \"Map Projections--A Working Manual\", U.S. Geological\r\n Survey Professional Paper 1395 (Supersedes USGS Bulletin 1532), United\r\n State Government Printing Office, Washington D.C., 1987.\r\n\r\n2. Snyder, John P. and Voxland, Philip M., \"An Album of Map Projections\",\r\n U.S. Geological Survey Professional Paper 1453 , United State Government\r\n Printing Office, Washington D.C., 1989.\r\n*******************************************************************************/\r\n\r\n/* Variables common to all subroutines in this code file\r\n -----------------------------------------------------*/\r\n\r\nProj4js.Proj.eqdc = {\r\n /* Initialize the Equidistant Conic projection\r\n ------------------------------------------*/\r\n init: function() {\r\n /* Place parameters in static storage for common use\r\n -------------------------------------------------*/\r\n\r\n if (!this.mode) this.mode = 0; //chosen default mode\r\n this.temp = this.b / this.a;\r\n this.es = 1.0 - Math.pow(this.temp, 2);\r\n this.e = Math.sqrt(this.es);\r\n this.e0 = Proj4js.common.e0fn(this.es);\r\n this.e1 = Proj4js.common.e1fn(this.es);\r\n this.e2 = Proj4js.common.e2fn(this.es);\r\n this.e3 = Proj4js.common.e3fn(this.es);\r\n\r\n this.sinphi = Math.sin(this.lat1);\r\n this.cosphi = Math.cos(this.lat1);\r\n\r\n this.ms1 = Proj4js.common.msfnz(this.e, this.sinphi, this.cosphi);\r\n this.ml1 = Proj4js.common.mlfn(\r\n this.e0,\r\n this.e1,\r\n this.e2,\r\n this.e3,\r\n this.lat1\r\n );\r\n\r\n /* format B\r\n ---------*/\r\n if (this.mode != 0) {\r\n if (Math.abs(this.lat1 + this.lat2) < Proj4js.common.EPSLN) {\r\n Proj4js.reportError(\"eqdc:Init:EqualLatitudes\");\r\n //return(81);\r\n }\r\n this.sinphi = Math.sin(this.lat2);\r\n this.cosphi = Math.cos(this.lat2);\r\n\r\n this.ms2 = Proj4js.common.msfnz(this.e, this.sinphi, this.cosphi);\r\n this.ml2 = Proj4js.common.mlfn(\r\n this.e0,\r\n this.e1,\r\n this.e2,\r\n this.e3,\r\n this.lat2\r\n );\r\n if (Math.abs(this.lat1 - this.lat2) >= Proj4js.common.EPSLN) {\r\n this.ns = (this.ms1 - this.ms2) / (this.ml2 - this.ml1);\r\n }\n else {\r\n this.ns = this.sinphi;\r\n }\r\n }\n else {\r\n this.ns = this.sinphi;\r\n }\r\n this.g = this.ml1 + this.ms1 / this.ns;\r\n this.ml0 = Proj4js.common.mlfn(\r\n this.e0,\r\n this.e1,\r\n this.e2,\r\n this.e3,\r\n this.lat0\r\n );\r\n this.rh = this.a * (this.g - this.ml0);\r\n },\r\n\r\n /* Equidistant Conic forward equations--mapping lat,long to x,y\r\n -----------------------------------------------------------*/\r\n forward: function(p) {\r\n var lon = p.x;\r\n var lat = p.y;\r\n\r\n /* Forward equations\r\n -----------------*/\r\n var ml = Proj4js.common.mlfn(this.e0, this.e1, this.e2, this.e3, lat);\r\n var rh1 = this.a * (this.g - ml);\r\n var theta = this.ns * Proj4js.common.adjust_lon(lon - this.long0);\r\n\r\n var x = this.x0 + rh1 * Math.sin(theta);\r\n var y = this.y0 + this.rh - rh1 * Math.cos(theta);\r\n p.x = x;\r\n p.y = y;\r\n return p;\r\n },\r\n\r\n /* Inverse equations\r\n -----------------*/\r\n inverse: function(p) {\r\n p.x -= this.x0;\r\n p.y = this.rh - p.y + this.y0;\r\n var con, rh1;\r\n if (this.ns >= 0) {\r\n rh1 = Math.sqrt(p.x * p.x + p.y * p.y);\r\n con = 1.0;\r\n }\n else {\r\n rh1 = -Math.sqrt(p.x * p.x + p.y * p.y);\r\n con = -1.0;\r\n }\r\n var theta = 0.0;\r\n if (rh1 != 0.0) theta = Math.atan2(con * p.x, con * p.y);\r\n var ml = this.g - rh1 / this.a;\r\n var lat = this.phi3z(ml, this.e0, this.e1, this.e2, this.e3);\r\n var lon = Proj4js.common.adjust_lon(this.long0 + theta / this.ns);\r\n\r\n p.x = lon;\r\n p.y = lat;\r\n return p;\r\n },\r\n\r\n /* Function to compute latitude, phi3, for the inverse of the Equidistant\r\n Conic projection.\r\n-----------------------------------------------------------------*/\r\n phi3z: function(ml, e0, e1, e2, e3) {\r\n var phi;\r\n var dphi;\r\n\r\n phi = ml;\r\n for (var i = 0; i < 15; i++) {\r\n dphi =\r\n (ml +\r\n e1 * Math.sin(2.0 * phi) -\r\n e2 * Math.sin(4.0 * phi) +\r\n e3 * Math.sin(6.0 * phi)) /\r\n e0 -\r\n phi;\r\n phi += dphi;\r\n if (Math.abs(dphi) <= 0.0000000001) {\r\n return phi;\r\n }\r\n }\r\n Proj4js.reportError(\r\n \"PHI3Z-CONV:Latitude failed to converge after 15 iterations\"\r\n );\r\n return null;\r\n }\r\n};\r\n/* ======================================================================\r\n projCode/tmerc.js\r\n ====================================================================== */\r\n\r\n/*******************************************************************************\r\nNAME TRANSVERSE MERCATOR\r\n\r\nPURPOSE:\tTransforms input longitude and latitude to Easting and\r\n\t\tNorthing for the Transverse Mercator projection. The\r\n\t\tlongitude and latitude must be in radians. The Easting\r\n\t\tand Northing values will be returned in meters.\r\n\r\nALGORITHM REFERENCES\r\n\r\n1. Snyder, John P., \"Map Projections--A Working Manual\", U.S. Geological\r\n Survey Professional Paper 1395 (Supersedes USGS Bulletin 1532), United\r\n State Government Printing Office, Washington D.C., 1987.\r\n\r\n2. Snyder, John P. and Voxland, Philip M., \"An Album of Map Projections\",\r\n U.S. Geological Survey Professional Paper 1453 , United State Government\r\n Printing Office, Washington D.C., 1989.\r\n*******************************************************************************/\r\n\r\n/**\r\n Initialize Transverse Mercator projection\r\n*/\r\n\r\nProj4js.Proj.tmerc = {\r\n init: function() {\r\n this.e0 = Proj4js.common.e0fn(this.es);\r\n this.e1 = Proj4js.common.e1fn(this.es);\r\n this.e2 = Proj4js.common.e2fn(this.es);\r\n this.e3 = Proj4js.common.e3fn(this.es);\r\n this.ml0 =\r\n this.a *\r\n Proj4js.common.mlfn(this.e0, this.e1, this.e2, this.e3, this.lat0);\r\n },\r\n\r\n /**\r\n Transverse Mercator Forward - long/lat to x/y\r\n long/lat in radians\r\n */\r\n forward: function(p) {\r\n var lon = p.x;\r\n var lat = p.y;\r\n\r\n var delta_lon = Proj4js.common.adjust_lon(lon - this.long0); // Delta longitude\r\n var con; // cone constant\r\n var x, y;\r\n var sin_phi = Math.sin(lat);\r\n var cos_phi = Math.cos(lat);\r\n\r\n if (this.sphere) {\r\n /* spherical form */\r\n var b = cos_phi * Math.sin(delta_lon);\r\n if (Math.abs(Math.abs(b) - 1.0) < 0.0000000001) {\r\n Proj4js.reportError(\"tmerc:forward: Point projects into infinity\");\r\n return 93;\r\n }\n else {\r\n x = 0.5 * this.a * this.k0 * Math.log((1.0 + b) / (1.0 - b));\r\n con = Math.acos(\r\n (cos_phi * Math.cos(delta_lon)) / Math.sqrt(1.0 - b * b)\r\n );\r\n if (lat < 0) con = -con;\r\n y = this.a * this.k0 * (con - this.lat0);\r\n }\r\n }\n else {\r\n var al = cos_phi * delta_lon;\r\n var als = Math.pow(al, 2);\r\n var c = this.ep2 * Math.pow(cos_phi, 2);\r\n var tq = Math.tan(lat);\r\n var t = Math.pow(tq, 2);\r\n con = 1.0 - this.es * Math.pow(sin_phi, 2);\r\n var n = this.a / Math.sqrt(con);\r\n var ml =\r\n this.a * Proj4js.common.mlfn(this.e0, this.e1, this.e2, this.e3, lat);\r\n\r\n x =\r\n this.k0 *\r\n n *\r\n al *\r\n (1.0 +\r\n (als / 6.0) *\r\n (1.0 -\r\n t +\r\n c +\r\n (als / 20.0) *\r\n (5.0 -\r\n 18.0 * t +\r\n Math.pow(t, 2) +\r\n 72.0 * c -\r\n 58.0 * this.ep2))) +\r\n this.x0;\r\n y =\r\n this.k0 *\r\n (ml -\r\n this.ml0 +\r\n n *\r\n tq *\r\n (als *\r\n (0.5 +\r\n (als / 24.0) *\r\n (5.0 -\r\n t +\r\n 9.0 * c +\r\n 4.0 * Math.pow(c, 2) +\r\n (als / 30.0) *\r\n (61.0 -\r\n 58.0 * t +\r\n Math.pow(t, 2) +\r\n 600.0 * c -\r\n 330.0 * this.ep2))))) +\r\n this.y0;\r\n }\r\n p.x = x;\r\n p.y = y;\r\n return p;\r\n }, // tmercFwd()\r\n\r\n /**\r\n Transverse Mercator Inverse - x/y to long/lat\r\n */\r\n inverse: function(p) {\r\n var con, phi; /* temporary angles */\r\n var delta_phi; /* difference between longitudes */\r\n var i;\r\n var max_iter = 6; /* maximun number of iterations */\r\n var lat, lon;\r\n\r\n if (this.sphere) {\r\n /* spherical form */\r\n var f = Math.exp(p.x / (this.a * this.k0));\r\n var g = 0.5 * (f - 1 / f);\r\n var temp = this.lat0 + p.y / (this.a * this.k0);\r\n var h = Math.cos(temp);\r\n con = Math.sqrt((1.0 - h * h) / (1.0 + g * g));\r\n lat = Proj4js.common.asinz(con);\r\n if (temp < 0) lat = -lat;\r\n if (g == 0 && h == 0) {\r\n lon = this.long0;\r\n }\n else {\r\n lon = Proj4js.common.adjust_lon(Math.atan2(g, h) + this.long0);\r\n }\r\n }\n else {\r\n // ellipsoidal form\r\n var x = p.x - this.x0;\r\n var y = p.y - this.y0;\r\n\r\n con = (this.ml0 + y / this.k0) / this.a;\r\n phi = con;\r\n for (i = 0; true; i++) {\r\n delta_phi =\r\n (con +\r\n this.e1 * Math.sin(2.0 * phi) -\r\n this.e2 * Math.sin(4.0 * phi) +\r\n this.e3 * Math.sin(6.0 * phi)) /\r\n this.e0 -\r\n phi;\r\n phi += delta_phi;\r\n if (Math.abs(delta_phi) <= Proj4js.common.EPSLN) break;\r\n if (i >= max_iter) {\r\n Proj4js.reportError(\"tmerc:inverse: Latitude failed to converge\");\r\n return 95;\r\n }\r\n } // for()\r\n if (Math.abs(phi) < Proj4js.common.HALF_PI) {\r\n // sincos(phi, &sin_phi, &cos_phi);\r\n var sin_phi = Math.sin(phi);\r\n var cos_phi = Math.cos(phi);\r\n var tan_phi = Math.tan(phi);\r\n var c = this.ep2 * Math.pow(cos_phi, 2);\r\n var cs = Math.pow(c, 2);\r\n var t = Math.pow(tan_phi, 2);\r\n var ts = Math.pow(t, 2);\r\n con = 1.0 - this.es * Math.pow(sin_phi, 2);\r\n var n = this.a / Math.sqrt(con);\r\n var r = (n * (1.0 - this.es)) / con;\r\n var d = x / (n * this.k0);\r\n var ds = Math.pow(d, 2);\r\n lat =\r\n phi -\r\n ((n * tan_phi * ds) / r) *\r\n (0.5 -\r\n (ds / 24.0) *\r\n (5.0 +\r\n 3.0 * t +\r\n 10.0 * c -\r\n 4.0 * cs -\r\n 9.0 * this.ep2 -\r\n (ds / 30.0) *\r\n (61.0 +\r\n 90.0 * t +\r\n 298.0 * c +\r\n 45.0 * ts -\r\n 252.0 * this.ep2 -\r\n 3.0 * cs)));\r\n lon = Proj4js.common.adjust_lon(\r\n this.long0 +\r\n (d *\r\n (1.0 -\r\n (ds / 6.0) *\r\n (1.0 +\r\n 2.0 * t +\r\n c -\r\n (ds / 20.0) *\r\n (5.0 -\r\n 2.0 * c +\r\n 28.0 * t -\r\n 3.0 * cs +\r\n 8.0 * this.ep2 +\r\n 24.0 * ts)))) /\r\n cos_phi\r\n );\r\n }\n else {\r\n lat = Proj4js.common.HALF_PI * Proj4js.common.sign(y);\r\n lon = this.long0;\r\n }\r\n }\r\n p.x = lon;\r\n p.y = lat;\r\n return p;\r\n } // tmercInv()\r\n};\r\n/* ======================================================================\r\n defs/GOOGLE.js\r\n ====================================================================== */\r\n\r\nProj4js.defs[\"GOOGLE\"] =\r\n \"+proj=merc +a=6378137 +b=6378137 +lat_ts=0.0 +lon_0=0.0 +x_0=0.0 +y_0=0 +k=1.0 +units=m +nadgrids=@null +no_defs\";\r\nProj4js.defs[\"EPSG:900913\"] = Proj4js.defs[\"GOOGLE\"];\r\n/* ======================================================================\r\n projCode/gstmerc.js\r\n ====================================================================== */\r\n\r\nProj4js.Proj.gstmerc = {\r\n init: function() {\r\n // array of: a, b, lon0, lat0, k0, x0, y0\r\n var temp = this.b / this.a;\r\n this.e = Math.sqrt(1.0 - temp * temp);\r\n this.lc = this.long0;\r\n this.rs = Math.sqrt(\r\n 1.0 +\r\n (this.e * this.e * Math.pow(Math.cos(this.lat0), 4.0)) /\r\n (1.0 - this.e * this.e)\r\n );\r\n var sinz = Math.sin(this.lat0);\r\n var pc = Math.asin(sinz / this.rs);\r\n var sinzpc = Math.sin(pc);\r\n this.cp =\r\n Proj4js.common.latiso(0.0, pc, sinzpc) -\r\n this.rs * Proj4js.common.latiso(this.e, this.lat0, sinz);\r\n this.n2 =\r\n (this.k0 * this.a * Math.sqrt(1.0 - this.e * this.e)) /\r\n (1.0 - this.e * this.e * sinz * sinz);\r\n this.xs = this.x0;\r\n this.ys = this.y0 - this.n2 * pc;\r\n\r\n if (!this.title) this.title = \"Gauss Schreiber transverse mercator\";\r\n },\r\n\r\n // forward equations--mapping lat,long to x,y\r\n // -----------------------------------------------------------------\r\n forward: function(p) {\r\n var lon = p.x;\r\n var lat = p.y;\r\n\r\n var L = this.rs * (lon - this.lc);\r\n var Ls =\r\n this.cp + this.rs * Proj4js.common.latiso(this.e, lat, Math.sin(lat));\r\n var lat1 = Math.asin(Math.sin(L) / Proj4js.common.cosh(Ls));\r\n var Ls1 = Proj4js.common.latiso(0.0, lat1, Math.sin(lat1));\r\n p.x = this.xs + this.n2 * Ls1;\r\n p.y = this.ys + this.n2 * Math.atan(Proj4js.common.sinh(Ls) / Math.cos(L));\r\n return p;\r\n },\r\n\r\n // inverse equations--mapping x,y to lat/long\r\n // -----------------------------------------------------------------\r\n inverse: function(p) {\r\n var x = p.x;\r\n var y = p.y;\r\n\r\n var L = Math.atan(\r\n Proj4js.common.sinh((x - this.xs) / this.n2) /\r\n Math.cos((y - this.ys) / this.n2)\r\n );\r\n var lat1 = Math.asin(\r\n Math.sin((y - this.ys) / this.n2) /\r\n Proj4js.common.cosh((x - this.xs) / this.n2)\r\n );\r\n var LC = Proj4js.common.latiso(0.0, lat1, Math.sin(lat1));\r\n p.x = this.lc + L / this.rs;\r\n p.y = Proj4js.common.invlatiso(this.e, (LC - this.cp) / this.rs);\r\n return p;\r\n }\r\n};\r\n/* ======================================================================\r\n projCode/ortho.js\r\n ====================================================================== */\r\n\r\n/*******************************************************************************\r\nNAME ORTHOGRAPHIC \r\n\r\nPURPOSE:\tTransforms input longitude and latitude to Easting and\r\n\t\tNorthing for the Orthographic projection. The\r\n\t\tlongitude and latitude must be in radians. The Easting\r\n\t\tand Northing values will be returned in meters.\r\n\r\nPROGRAMMER DATE\r\n---------- ----\r\nT. Mittan\t\tMar, 1993\r\n\r\nALGORITHM REFERENCES\r\n\r\n1. Snyder, John P., \"Map Projections--A Working Manual\", U.S. Geological\r\n Survey Professional Paper 1395 (Supersedes USGS Bulletin 1532), United\r\n State Government Printing Office, Washington D.C., 1987.\r\n\r\n2. Snyder, John P. and Voxland, Philip M., \"An Album of Map Projections\",\r\n U.S. Geological Survey Professional Paper 1453 , United State Government\r\n Printing Office, Washington D.C., 1989.\r\n*******************************************************************************/\r\n\r\nProj4js.Proj.ortho = {\r\n /* Initialize the Orthographic projection\r\n -------------------------------------*/\r\n init: function(def) {\r\n //double temp;\t\t\t/* temporary variable\t\t*/\r\n\r\n /* Place parameters in static storage for common use\r\n -------------------------------------------------*/ this.sin_p14 = Math.sin(\r\n this.lat0\r\n );\r\n this.cos_p14 = Math.cos(this.lat0);\r\n },\r\n\r\n /* Orthographic forward equations--mapping lat,long to x,y\r\n ---------------------------------------------------*/\r\n forward: function(p) {\r\n var sinphi, cosphi; /* sin and cos value\t\t\t\t*/\r\n var dlon; /* delta longitude value\t\t\t*/\r\n var coslon; /* cos of longitude\t\t\t\t*/\r\n var ksp; /* scale factor\t\t\t\t\t*/\r\n var g;\r\n var lon = p.x;\r\n var lat = p.y;\r\n /* Forward equations\r\n -----------------*/\r\n dlon = Proj4js.common.adjust_lon(lon - this.long0);\r\n\r\n sinphi = Math.sin(lat);\r\n cosphi = Math.cos(lat);\r\n\r\n coslon = Math.cos(dlon);\r\n g = this.sin_p14 * sinphi + this.cos_p14 * cosphi * coslon;\r\n ksp = 1.0;\r\n if (g > 0 || Math.abs(g) <= Proj4js.common.EPSLN) {\r\n var x = this.a * ksp * cosphi * Math.sin(dlon);\r\n var y =\r\n this.y0 +\r\n this.a * ksp * (this.cos_p14 * sinphi - this.sin_p14 * cosphi * coslon);\r\n }\n else {\r\n Proj4js.reportError(\"orthoFwdPointError\");\r\n }\r\n p.x = x;\r\n p.y = y;\r\n return p;\r\n },\r\n\r\n inverse: function(p) {\r\n var rh; /* height above ellipsoid\t\t\t*/\r\n var z; /* angle\t\t\t\t\t*/\r\n var sinz, cosz; /* sin of z and cos of z\t\t\t*/\r\n var temp;\r\n var con;\r\n var lon, lat;\r\n /* Inverse equations\r\n -----------------*/\r\n p.x -= this.x0;\r\n p.y -= this.y0;\r\n rh = Math.sqrt(p.x * p.x + p.y * p.y);\r\n if (rh > this.a + 0.0000001) {\r\n Proj4js.reportError(\"orthoInvDataError\");\r\n }\r\n z = Proj4js.common.asinz(rh / this.a);\r\n\r\n sinz = Math.sin(z);\r\n cosz = Math.cos(z);\r\n\r\n lon = this.long0;\r\n if (Math.abs(rh) <= Proj4js.common.EPSLN) {\r\n lat = this.lat0;\r\n }\r\n lat = Proj4js.common.asinz(\r\n cosz * this.sin_p14 + (p.y * sinz * this.cos_p14) / rh\r\n );\r\n con = Math.abs(this.lat0) - Proj4js.common.HALF_PI;\r\n if (Math.abs(con) <= Proj4js.common.EPSLN) {\r\n if (this.lat0 >= 0) {\r\n lon = Proj4js.common.adjust_lon(this.long0 + Math.atan2(p.x, -p.y));\r\n }\n else {\r\n lon = Proj4js.common.adjust_lon(this.long0 - Math.atan2(-p.x, p.y));\r\n }\r\n }\r\n con = cosz - this.sin_p14 * Math.sin(lat);\r\n p.x = lon;\r\n p.y = lat;\r\n return p;\r\n }\r\n};\r\n\r\n/* ======================================================================\r\n projCode/krovak.js\r\n ====================================================================== */\r\n\r\n/**\r\n NOTES: According to EPSG the full Krovak projection method should have\r\n the following parameters. Within PROJ.4 the azimuth, and pseudo\r\n standard parallel are hardcoded in the algorithm and can't be \r\n altered from outside. The others all have defaults to match the\r\n common usage with Krovak projection.\r\n\r\n lat_0 = latitude of centre of the projection\r\n \r\n lon_0 = longitude of centre of the projection\r\n \r\n ** = azimuth (true) of the centre line passing through the centre of the projection\r\n\r\n ** = latitude of pseudo standard parallel\r\n \r\n k = scale factor on the pseudo standard parallel\r\n \r\n x_0 = False Easting of the centre of the projection at the apex of the cone\r\n \r\n y_0 = False Northing of the centre of the projection at the apex of the cone\r\n\r\n **/\r\n\r\nProj4js.Proj.krovak = {\r\n init: function() {\r\n /* we want Bessel as fixed ellipsoid */\r\n this.a = 6377397.155;\r\n this.es = 0.006674372230614;\r\n this.e = Math.sqrt(this.es);\r\n /* if latitude of projection center is not set, use 49d30'N */\r\n if (!this.lat0) {\r\n this.lat0 = 0.863937979737193;\r\n }\r\n if (!this.long0) {\r\n this.long0 = 0.7417649320975901 - 0.308341501185665;\r\n }\r\n /* if scale not set default to 0.9999 */\r\n if (!this.k0) {\r\n this.k0 = 0.9999;\r\n }\r\n this.s45 = 0.785398163397448; /* 45� */\r\n this.s90 = 2 * this.s45;\r\n this.fi0 = this.lat0; /* Latitude of projection centre 49� 30' */\r\n /* Ellipsoid Bessel 1841 a = 6377397.155m 1/f = 299.1528128,\r\n \t\t\t\t\t e2=0.006674372230614;\r\n\t\t */\r\n this.e2 = this.es; /* 0.006674372230614; */\r\n this.e = Math.sqrt(this.e2);\r\n this.alfa = Math.sqrt(\r\n 1 + (this.e2 * Math.pow(Math.cos(this.fi0), 4)) / (1 - this.e2)\r\n );\r\n this.uq = 1.04216856380474; /* DU(2, 59, 42, 42.69689) */\r\n this.u0 = Math.asin(Math.sin(this.fi0) / this.alfa);\r\n this.g = Math.pow(\r\n (1 + this.e * Math.sin(this.fi0)) / (1 - this.e * Math.sin(this.fi0)),\r\n (this.alfa * this.e) / 2\r\n );\r\n this.k =\r\n (Math.tan(this.u0 / 2 + this.s45) /\r\n Math.pow(Math.tan(this.fi0 / 2 + this.s45), this.alfa)) *\r\n this.g;\r\n this.k1 = this.k0;\r\n this.n0 =\r\n (this.a * Math.sqrt(1 - this.e2)) /\r\n (1 - this.e2 * Math.pow(Math.sin(this.fi0), 2));\r\n this.s0 = 1.37008346281555; /* Latitude of pseudo standard parallel 78� 30'00\" N */\r\n this.n = Math.sin(this.s0);\r\n this.ro0 = (this.k1 * this.n0) / Math.tan(this.s0);\r\n this.ad = this.s90 - this.uq;\r\n },\r\n\r\n /* ellipsoid */\r\n /* calculate xy from lat/lon */\r\n /* Constants, identical to inverse transform function */\r\n forward: function(p) {\r\n var gfi, u, deltav, s, d, eps, ro;\r\n var lon = p.x;\r\n var lat = p.y;\r\n var delta_lon = Proj4js.common.adjust_lon(lon - this.long0); // Delta longitude\r\n /* Transformation */\r\n gfi = Math.pow(\r\n (1 + this.e * Math.sin(lat)) / (1 - this.e * Math.sin(lat)),\r\n (this.alfa * this.e) / 2\r\n );\r\n u =\r\n 2 *\r\n (Math.atan(\r\n (this.k * Math.pow(Math.tan(lat / 2 + this.s45), this.alfa)) / gfi\r\n ) -\r\n this.s45);\r\n deltav = -delta_lon * this.alfa;\r\n s = Math.asin(\r\n Math.cos(this.ad) * Math.sin(u) +\r\n Math.sin(this.ad) * Math.cos(u) * Math.cos(deltav)\r\n );\r\n d = Math.asin((Math.cos(u) * Math.sin(deltav)) / Math.cos(s));\r\n eps = this.n * d;\r\n ro =\r\n (this.ro0 * Math.pow(Math.tan(this.s0 / 2 + this.s45), this.n)) /\r\n Math.pow(Math.tan(s / 2 + this.s45), this.n);\r\n /* x and y are reverted! */\r\n //p.y = ro * Math.cos(eps) / a;\r\n //p.x = ro * Math.sin(eps) / a;\r\n p.y = (ro * Math.cos(eps)) / 1.0;\r\n p.x = (ro * Math.sin(eps)) / 1.0;\r\n\r\n if (this.czech) {\r\n p.y *= -1.0;\r\n p.x *= -1.0;\r\n }\r\n return p;\r\n },\r\n\r\n /* calculate lat/lon from xy */\r\n inverse: function(p) {\r\n /* Constants, identisch wie in der Umkehrfunktion */\r\n var u, deltav, s, d, eps, ro, fi1;\r\n var ok;\r\n\r\n /* Transformation */\r\n /* revert y, x*/\r\n var tmp = p.x;\r\n p.x = p.y;\r\n p.y = tmp;\r\n if (this.czech) {\r\n p.y *= -1.0;\r\n p.x *= -1.0;\r\n }\r\n ro = Math.sqrt(p.x * p.x + p.y * p.y);\r\n eps = Math.atan2(p.y, p.x);\r\n d = eps / Math.sin(this.s0);\r\n s =\r\n 2 *\r\n (Math.atan(\r\n Math.pow(this.ro0 / ro, 1 / this.n) * Math.tan(this.s0 / 2 + this.s45)\r\n ) -\r\n this.s45);\r\n u = Math.asin(\r\n Math.cos(this.ad) * Math.sin(s) -\r\n Math.sin(this.ad) * Math.cos(s) * Math.cos(d)\r\n );\r\n deltav = Math.asin((Math.cos(s) * Math.sin(d)) / Math.cos(u));\r\n p.x = this.long0 - deltav / this.alfa;\r\n /* ITERATION FOR lat */\r\n fi1 = u;\r\n ok = 0;\r\n var iter = 0;\r\n do {\r\n p.y =\r\n 2 *\r\n (Math.atan(\r\n Math.pow(this.k, -1 / this.alfa) *\r\n Math.pow(Math.tan(u / 2 + this.s45), 1 / this.alfa) *\r\n Math.pow(\r\n (1 + this.e * Math.sin(fi1)) / (1 - this.e * Math.sin(fi1)),\r\n this.e / 2\r\n )\r\n ) -\r\n this.s45);\r\n if (Math.abs(fi1 - p.y) < 0.0000000001) ok = 1;\r\n fi1 = p.y;\r\n iter += 1;\r\n } while (ok == 0 && iter < 15);\r\n if (iter >= 15) {\r\n Proj4js.reportError(\r\n \"PHI3Z-CONV:Latitude failed to converge after 15 iterations\"\r\n );\r\n //console.log('iter:', iter);\r\n return null;\r\n }\r\n\r\n return p;\r\n }\r\n};\r\n/* ======================================================================\r\n projCode/somerc.js\r\n ====================================================================== */\r\n\r\n/*******************************************************************************\r\nNAME SWISS OBLIQUE MERCATOR\r\n\r\nPURPOSE:\tSwiss projection.\r\nWARNING: X and Y are inverted (weird) in the swiss coordinate system. Not\r\n here, since we want X to be horizontal and Y vertical.\r\n\r\nALGORITHM REFERENCES\r\n1. \"Formules et constantes pour le Calcul pour la\r\n projection cylindrique conforme à axe oblique et pour la transformation entre\r\n des systèmes de référence\".\r\n http://www.swisstopo.admin.ch/internet/swisstopo/fr/home/topics/survey/sys/refsys/switzerland.parsysrelated1.31216.downloadList.77004.DownloadFile.tmp/swissprojectionfr.pdf\r\n\r\n*******************************************************************************/\r\n\r\nProj4js.Proj.somerc = {\r\n init: function() {\r\n var phy0 = this.lat0;\r\n this.lambda0 = this.long0;\r\n var sinPhy0 = Math.sin(phy0);\r\n var semiMajorAxis = this.a;\r\n var invF = this.rf;\r\n var flattening = 1 / invF;\r\n var e2 = 2 * flattening - Math.pow(flattening, 2);\r\n var e = (this.e = Math.sqrt(e2));\r\n this.R =\r\n (this.k0 * semiMajorAxis * Math.sqrt(1 - e2)) /\r\n (1 - e2 * Math.pow(sinPhy0, 2.0));\r\n this.alpha = Math.sqrt(1 + (e2 / (1 - e2)) * Math.pow(Math.cos(phy0), 4.0));\r\n this.b0 = Math.asin(sinPhy0 / this.alpha);\r\n this.K =\r\n Math.log(Math.tan(Math.PI / 4.0 + this.b0 / 2.0)) -\r\n this.alpha * Math.log(Math.tan(Math.PI / 4.0 + phy0 / 2.0)) +\r\n ((this.alpha * e) / 2) * Math.log((1 + e * sinPhy0) / (1 - e * sinPhy0));\r\n },\r\n\r\n forward: function(p) {\r\n var Sa1 = Math.log(Math.tan(Math.PI / 4.0 - p.y / 2.0));\r\n var Sa2 =\r\n (this.e / 2.0) *\r\n Math.log((1 + this.e * Math.sin(p.y)) / (1 - this.e * Math.sin(p.y)));\r\n var S = -this.alpha * (Sa1 + Sa2) + this.K;\r\n\r\n // spheric latitude\r\n var b = 2.0 * (Math.atan(Math.exp(S)) - Math.PI / 4.0);\r\n\r\n // spheric longitude\r\n var I = this.alpha * (p.x - this.lambda0);\r\n\r\n // psoeudo equatorial rotation\r\n var rotI = Math.atan(\r\n Math.sin(I) /\r\n (Math.sin(this.b0) * Math.tan(b) + Math.cos(this.b0) * Math.cos(I))\r\n );\r\n\r\n var rotB = Math.asin(\r\n Math.cos(this.b0) * Math.sin(b) -\r\n Math.sin(this.b0) * Math.cos(b) * Math.cos(I)\r\n );\r\n\r\n p.y =\r\n (this.R / 2.0) * Math.log((1 + Math.sin(rotB)) / (1 - Math.sin(rotB))) +\r\n this.y0;\r\n p.x = this.R * rotI + this.x0;\r\n return p;\r\n },\r\n\r\n inverse: function(p) {\r\n var Y = p.x - this.x0;\r\n var X = p.y - this.y0;\r\n\r\n var rotI = Y / this.R;\r\n var rotB = 2 * (Math.atan(Math.exp(X / this.R)) - Math.PI / 4.0);\r\n\r\n var b = Math.asin(\r\n Math.cos(this.b0) * Math.sin(rotB) +\r\n Math.sin(this.b0) * Math.cos(rotB) * Math.cos(rotI)\r\n );\r\n var I = Math.atan(\r\n Math.sin(rotI) /\r\n (Math.cos(this.b0) * Math.cos(rotI) -\r\n Math.sin(this.b0) * Math.tan(rotB))\r\n );\r\n\r\n var lambda = this.lambda0 + I / this.alpha;\r\n\r\n var S = 0.0;\r\n var phy = b;\r\n var prevPhy = -1000.0;\r\n var iteration = 0;\r\n while (Math.abs(phy - prevPhy) > 0.0000001) {\r\n if (++iteration > 20) {\r\n Proj4js.reportError(\"omercFwdInfinity\");\r\n return;\r\n }\r\n //S = Math.log(Math.tan(Math.PI / 4.0 + phy / 2.0));\r\n S =\r\n (1.0 / this.alpha) *\r\n (Math.log(Math.tan(Math.PI / 4.0 + b / 2.0)) - this.K) +\r\n this.e *\r\n Math.log(\r\n Math.tan(Math.PI / 4.0 + Math.asin(this.e * Math.sin(phy)) / 2.0)\r\n );\r\n prevPhy = phy;\r\n phy = 2.0 * Math.atan(Math.exp(S)) - Math.PI / 2.0;\r\n }\r\n\r\n p.x = lambda;\r\n p.y = phy;\r\n return p;\r\n }\r\n};\r\n/* ======================================================================\r\n projCode/stere.js\r\n ====================================================================== */\r\n\r\n// Initialize the Stereographic projection\r\n\r\nProj4js.Proj.stere = {\r\n ssfn_: function(phit, sinphi, eccen) {\r\n sinphi *= eccen;\r\n return (\r\n Math.tan(0.5 * (Proj4js.common.HALF_PI + phit)) *\r\n Math.pow((1 - sinphi) / (1 + sinphi), 0.5 * eccen)\r\n );\r\n },\r\n TOL: 1e-8,\r\n NITER: 8,\r\n CONV: 1e-10,\r\n S_POLE: 0,\r\n N_POLE: 1,\r\n OBLIQ: 2,\r\n EQUIT: 3,\r\n\r\n init: function() {\r\n this.phits = this.lat_ts ? this.lat_ts : Proj4js.common.HALF_PI;\r\n var t = Math.abs(this.lat0);\r\n if (Math.abs(t) - Proj4js.common.HALF_PI < Proj4js.common.EPSLN) {\r\n this.mode = this.lat0 < 0 ? this.S_POLE : this.N_POLE;\r\n }\n else {\r\n this.mode = t > Proj4js.common.EPSLN ? this.OBLIQ : this.EQUIT;\r\n }\r\n this.phits = Math.abs(this.phits);\r\n if (this.es) {\r\n var X;\r\n\r\n switch (this.mode) {\r\n case this.N_POLE:\r\n case this.S_POLE:\r\n if (\r\n Math.abs(this.phits - Proj4js.common.HALF_PI) < Proj4js.common.EPSLN\r\n ) {\r\n this.akm1 =\r\n (2 * this.k0) /\r\n Math.sqrt(\r\n Math.pow(1 + this.e, 1 + this.e) *\r\n Math.pow(1 - this.e, 1 - this.e)\r\n );\r\n }\n else {\r\n t = Math.sin(this.phits);\r\n this.akm1 =\r\n Math.cos(this.phits) /\r\n Proj4js.common.tsfnz(this.e, this.phits, t);\r\n t *= this.e;\r\n this.akm1 /= Math.sqrt(1 - t * t);\r\n }\r\n break;\r\n case this.EQUIT:\r\n this.akm1 = 2 * this.k0;\r\n break;\r\n case this.OBLIQ:\r\n t = Math.sin(this.lat0);\r\n X =\r\n 2 * Math.atan(this.ssfn_(this.lat0, t, this.e)) -\r\n Proj4js.common.HALF_PI;\r\n t *= this.e;\r\n this.akm1 =\r\n (2 * this.k0 * Math.cos(this.lat0)) / Math.sqrt(1 - t * t);\r\n this.sinX1 = Math.sin(X);\r\n this.cosX1 = Math.cos(X);\r\n break;\r\n }\r\n }\n else {\r\n switch (this.mode) {\r\n case this.OBLIQ:\r\n this.sinph0 = Math.sin(this.lat0);\r\n this.cosph0 = Math.cos(this.lat0);\r\n case this.EQUIT:\r\n this.akm1 = 2 * this.k0;\r\n break;\r\n case this.S_POLE:\r\n case this.N_POLE:\r\n this.akm1 =\r\n Math.abs(this.phits - Proj4js.common.HALF_PI) >=\r\n Proj4js.common.EPSLN\r\n ? Math.cos(this.phits) /\r\n Math.tan(Proj4js.common.FORTPI - 0.5 * this.phits)\r\n : 2 * this.k0;\r\n break;\r\n }\r\n }\r\n },\r\n\r\n // Stereographic forward equations--mapping lat,long to x,y\r\n forward: function(p) {\r\n var lon = p.x;\r\n lon = Proj4js.common.adjust_lon(lon - this.long0);\r\n var lat = p.y;\r\n var x, y;\r\n\r\n if (this.sphere) {\r\n var sinphi, cosphi, coslam, sinlam;\r\n\r\n sinphi = Math.sin(lat);\r\n cosphi = Math.cos(lat);\r\n coslam = Math.cos(lon);\r\n sinlam = Math.sin(lon);\r\n switch (this.mode) {\r\n case this.EQUIT:\r\n y = 1 + cosphi * coslam;\r\n if (y <= Proj4js.common.EPSLN) {\r\n Proj4js.reportError(\"stere:forward:Equit\");\r\n }\r\n y = this.akm1 / y;\r\n x = y * cosphi * sinlam;\r\n y *= sinphi;\r\n break;\r\n case this.OBLIQ:\r\n y = 1 + this.sinph0 * sinphi + this.cosph0 * cosphi * coslam;\r\n if (y <= Proj4js.common.EPSLN) {\r\n Proj4js.reportError(\"stere:forward:Obliq\");\r\n }\r\n y = this.akm1 / y;\r\n x = y * cosphi * sinlam;\r\n y *= this.cosph0 * sinphi - this.sinph0 * cosphi * coslam;\r\n break;\r\n case this.N_POLE:\r\n coslam = -coslam;\r\n lat = -lat;\r\n //Note no break here so it conitnues through S_POLE\r\n case this.S_POLE:\r\n if (Math.abs(lat - Proj4js.common.HALF_PI) < this.TOL) {\r\n Proj4js.reportError(\"stere:forward:S_POLE\");\r\n }\r\n y = this.akm1 * Math.tan(Proj4js.common.FORTPI + 0.5 * lat);\r\n x = sinlam * y;\r\n y *= coslam;\r\n break;\r\n }\r\n }\n else {\r\n coslam = Math.cos(lon);\r\n sinlam = Math.sin(lon);\r\n sinphi = Math.sin(lat);\r\n var sinX, cosX;\r\n if (this.mode == this.OBLIQ || this.mode == this.EQUIT) {\r\n var Xt = 2 * Math.atan(this.ssfn_(lat, sinphi, this.e));\r\n sinX = Math.sin(Xt - Proj4js.common.HALF_PI);\r\n cosX = Math.cos(Xt);\r\n }\r\n switch (this.mode) {\r\n case this.OBLIQ:\r\n var A =\r\n this.akm1 /\r\n (this.cosX1 * (1 + this.sinX1 * sinX + this.cosX1 * cosX * coslam));\r\n y = A * (this.cosX1 * sinX - this.sinX1 * cosX * coslam);\r\n x = A * cosX;\r\n break;\r\n case this.EQUIT:\r\n var A = (2 * this.akm1) / (1 + cosX * coslam);\r\n y = A * sinX;\r\n x = A * cosX;\r\n break;\r\n case this.S_POLE:\r\n lat = -lat;\r\n coslam = -coslam;\r\n sinphi = -sinphi;\r\n case this.N_POLE:\r\n x = this.akm1 * Proj4js.common.tsfnz(this.e, lat, sinphi);\r\n y = -x * coslam;\r\n break;\r\n }\r\n x = x * sinlam;\r\n }\r\n p.x = x * this.a + this.x0;\r\n p.y = y * this.a + this.y0;\r\n return p;\r\n },\r\n\r\n //* Stereographic inverse equations--mapping x,y to lat/long\r\n inverse: function(p) {\r\n var x = (p.x - this.x0) / this.a; /* descale and de-offset */\r\n var y = (p.y - this.y0) / this.a;\r\n var lon, lat;\r\n\r\n var cosphi,\r\n sinphi,\r\n tp = 0.0,\r\n phi_l = 0.0,\r\n rho,\r\n halfe = 0.0,\r\n pi2 = 0.0;\r\n var i;\r\n\r\n if (this.sphere) {\r\n var c, rh, sinc, cosc;\r\n\r\n rh = Math.sqrt(x * x + y * y);\r\n c = 2 * Math.atan(rh / this.akm1);\r\n sinc = Math.sin(c);\r\n cosc = Math.cos(c);\r\n lon = 0;\r\n switch (this.mode) {\r\n case this.EQUIT:\r\n if (Math.abs(rh) <= Proj4js.common.EPSLN) {\r\n lat = 0;\r\n }\n else {\r\n lat = Math.asin((y * sinc) / rh);\r\n }\r\n if (cosc != 0 || x != 0) lon = Math.atan2(x * sinc, cosc * rh);\r\n break;\r\n case this.OBLIQ:\r\n if (Math.abs(rh) <= Proj4js.common.EPSLN) {\r\n lat = this.phi0;\r\n }\n else {\r\n lat = Math.asin(cosc * this.sinph0 + (y * sinc * this.cosph0) / rh);\r\n }\r\n c = cosc - this.sinph0 * Math.sin(lat);\r\n if (c != 0 || x != 0) {\r\n lon = Math.atan2(x * sinc * this.cosph0, c * rh);\r\n }\r\n break;\r\n case this.N_POLE:\r\n y = -y;\r\n case this.S_POLE:\r\n if (Math.abs(rh) <= Proj4js.common.EPSLN) {\r\n lat = this.phi0;\r\n }\n else {\r\n lat = Math.asin(this.mode == this.S_POLE ? -cosc : cosc);\r\n }\r\n lon = x == 0 && y == 0 ? 0 : Math.atan2(x, y);\r\n break;\r\n }\r\n p.x = Proj4js.common.adjust_lon(lon + this.long0);\r\n p.y = lat;\r\n }\n else {\r\n rho = Math.sqrt(x * x + y * y);\r\n switch (this.mode) {\r\n case this.OBLIQ:\r\n case this.EQUIT:\r\n tp = 2 * Math.atan2(rho * this.cosX1, this.akm1);\r\n cosphi = Math.cos(tp);\r\n sinphi = Math.sin(tp);\r\n if (rho == 0.0) {\r\n phi_l = Math.asin(cosphi * this.sinX1);\r\n }\n else {\r\n phi_l = Math.asin(\r\n cosphi * this.sinX1 + (y * sinphi * this.cosX1) / rho\r\n );\r\n }\r\n\r\n tp = Math.tan(0.5 * (Proj4js.common.HALF_PI + phi_l));\r\n x *= sinphi;\r\n y = rho * this.cosX1 * cosphi - y * this.sinX1 * sinphi;\r\n pi2 = Proj4js.common.HALF_PI;\r\n halfe = 0.5 * this.e;\r\n break;\r\n case this.N_POLE:\r\n y = -y;\r\n case this.S_POLE:\r\n tp = -rho / this.akm1;\r\n phi_l = Proj4js.common.HALF_PI - 2 * Math.atan(tp);\r\n pi2 = -Proj4js.common.HALF_PI;\r\n halfe = -0.5 * this.e;\r\n break;\r\n }\r\n for (i = this.NITER; i--; phi_l = lat) {\r\n //check this\r\n sinphi = this.e * Math.sin(phi_l);\r\n lat =\r\n 2 * Math.atan(tp * Math.pow((1 + sinphi) / (1 - sinphi), halfe)) -\r\n pi2;\r\n if (Math.abs(phi_l - lat) < this.CONV) {\r\n if (this.mode == this.S_POLE) lat = -lat;\r\n lon = x == 0 && y == 0 ? 0 : Math.atan2(x, y);\r\n p.x = Proj4js.common.adjust_lon(lon + this.long0);\r\n p.y = lat;\r\n return p;\r\n }\r\n }\r\n }\r\n }\r\n};\r\n/* ======================================================================\r\n projCode/nzmg.js\r\n ====================================================================== */\r\n\r\n/*******************************************************************************\r\nNAME NEW ZEALAND MAP GRID\r\n\r\nPURPOSE:\tTransforms input longitude and latitude to Easting and\r\n\t\tNorthing for the New Zealand Map Grid projection. The\r\n\t\tlongitude and latitude must be in radians. The Easting\r\n\t\tand Northing values will be returned in meters.\r\n\r\n\r\nALGORITHM REFERENCES\r\n\r\n1. Department of Land and Survey Technical Circular 1973/32\r\n http://www.linz.govt.nz/docs/miscellaneous/nz-map-definition.pdf\r\n\r\n2. OSG Technical Report 4.1\r\n http://www.linz.govt.nz/docs/miscellaneous/nzmg.pdf\r\n\r\n\r\nIMPLEMENTATION NOTES\r\n\r\nThe two references use different symbols for the calculated values. This\r\nimplementation uses the variable names similar to the symbols in reference [1].\r\n\r\nThe alogrithm uses different units for delta latitude and delta longitude.\r\nThe delta latitude is assumed to be in units of seconds of arc x 10^-5.\r\nThe delta longitude is the usual radians. Look out for these conversions.\r\n\r\nThe algorithm is described using complex arithmetic. There were three\r\noptions:\r\n * find and use a Javascript library for complex arithmetic\r\n * write my own complex library\r\n * expand the complex arithmetic by hand to simple arithmetic\r\n\r\nThis implementation has expanded the complex multiplication operations\r\ninto parallel simple arithmetic operations for the real and imaginary parts.\r\nThe imaginary part is way over to the right of the display; this probably\r\nviolates every coding standard in the world, but, to me, it makes it much\r\nmore obvious what is going on.\r\n\r\nThe following complex operations are used:\r\n - addition\r\n - multiplication\r\n - division\r\n - complex number raised to integer power\r\n - summation\r\n\r\nA summary of complex arithmetic operations:\r\n (from http://en.wikipedia.org/wiki/Complex_arithmetic)\r\n addition: (a + bi) + (c + di) = (a + c) + (b + d)i\r\n subtraction: (a + bi) - (c + di) = (a - c) + (b - d)i\r\n multiplication: (a + bi) x (c + di) = (ac - bd) + (bc + ad)i\r\n division: (a + bi) / (c + di) = [(ac + bd)/(cc + dd)] + [(bc - ad)/(cc + dd)]i\r\n\r\nThe algorithm needs to calculate summations of simple and complex numbers. This is\r\nimplemented using a for-loop, pre-loading the summed value to zero.\r\n\r\nThe algorithm needs to calculate theta^2, theta^3, etc while doing a summation.\r\nThere are three possible implementations:\r\n - use Math.pow in the summation loop - except for complex numbers\r\n - precalculate the values before running the loop\r\n - calculate theta^n = theta^(n-1) * theta during the loop\r\nThis implementation uses the third option for both real and complex arithmetic.\r\n\r\nFor example\r\n psi_n = 1;\r\n sum = 0;\r\n for (n = 1; n <=6; n++) {\r\n psi_n1 = psi_n * psi; // calculate psi^(n+1)\r\n psi_n = psi_n1;\r\n sum = sum + A[n] * psi_n;\r\n }\r\n\r\n\r\nTEST VECTORS\r\n\r\nNZMG E, N: 2487100.638 6751049.719 metres\r\nNZGD49 long, lat: 172.739194 -34.444066 degrees\r\n\r\nNZMG E, N: 2486533.395 6077263.661 metres\r\nNZGD49 long, lat: 172.723106 -40.512409 degrees\r\n\r\nNZMG E, N: 2216746.425 5388508.765 metres\r\nNZGD49 long, lat: 169.172062 -46.651295 degrees\r\n\r\nNote that these test vectors convert from NZMG metres to lat/long referenced\r\nto NZGD49, not the more usual WGS84. The difference is about 70m N/S and about\r\n10m E/W.\r\n\r\nThese test vectors are provided in reference [1]. Many more test\r\nvectors are available in\r\n http://www.linz.govt.nz/docs/topography/topographicdata/placenamesdatabase/nznamesmar08.zip\r\nwhich is a catalog of names on the 260-series maps.\r\n\r\n\r\nEPSG CODES\r\n\r\nNZMG EPSG:27200\r\nNZGD49 EPSG:4272\r\n\r\nhttp://spatialreference.org/ defines these as\r\n Proj4js.defs[\"EPSG:4272\"] = \"+proj=longlat +ellps=intl +datum=nzgd49 +no_defs \";\r\n Proj4js.defs[\"EPSG:27200\"] = \"+proj=nzmg +lat_0=-41 +lon_0=173 +x_0=2510000 +y_0=6023150 +ellps=intl +datum=nzgd49 +units=m +no_defs \";\r\n\r\n\r\nLICENSE\r\n Copyright: Stephen Irons 2008\r\n Released under terms of the LGPL as per: http://www.gnu.org/copyleft/lesser.html\r\n\r\n*******************************************************************************/\r\n\r\n/**\r\n Initialize New Zealand Map Grip projection\r\n*/\r\n\r\nProj4js.Proj.nzmg = {\r\n /**\r\n * iterations: Number of iterations to refine inverse transform.\r\n * 0 -> km accuracy\r\n * 1 -> m accuracy -- suitable for most mapping applications\r\n * 2 -> mm accuracy\r\n */\r\n iterations: 1,\r\n\r\n init: function() {\r\n this.A = new Array();\r\n this.A[1] = +0.6399175073;\r\n this.A[2] = -0.1358797613;\r\n this.A[3] = +0.063294409;\r\n this.A[4] = -0.02526853;\r\n this.A[5] = +0.0117879;\r\n this.A[6] = -0.0055161;\r\n this.A[7] = +0.0026906;\r\n this.A[8] = -0.001333;\r\n this.A[9] = +0.00067;\r\n this.A[10] = -0.00034;\r\n\r\n this.B_re = new Array();\r\n this.B_im = new Array();\r\n this.B_re[1] = +0.7557853228;\r\n this.B_im[1] = 0.0;\r\n this.B_re[2] = +0.249204646;\r\n this.B_im[2] = +0.003371507;\r\n this.B_re[3] = -0.001541739;\r\n this.B_im[3] = +0.04105856;\r\n this.B_re[4] = -0.10162907;\r\n this.B_im[4] = +0.01727609;\r\n this.B_re[5] = -0.26623489;\r\n this.B_im[5] = -0.36249218;\r\n this.B_re[6] = -0.6870983;\r\n this.B_im[6] = -1.1651967;\r\n\r\n this.C_re = new Array();\r\n this.C_im = new Array();\r\n this.C_re[1] = +1.3231270439;\r\n this.C_im[1] = 0.0;\r\n this.C_re[2] = -0.577245789;\r\n this.C_im[2] = -0.007809598;\r\n this.C_re[3] = +0.508307513;\r\n this.C_im[3] = -0.112208952;\r\n this.C_re[4] = -0.15094762;\r\n this.C_im[4] = +0.18200602;\r\n this.C_re[5] = +1.01418179;\r\n this.C_im[5] = +1.64497696;\r\n this.C_re[6] = +1.9660549;\r\n this.C_im[6] = +2.5127645;\r\n\r\n this.D = new Array();\r\n this.D[1] = +1.5627014243;\r\n this.D[2] = +0.5185406398;\r\n this.D[3] = -0.03333098;\r\n this.D[4] = -0.1052906;\r\n this.D[5] = -0.0368594;\r\n this.D[6] = +0.007317;\r\n this.D[7] = +0.0122;\r\n this.D[8] = +0.00394;\r\n this.D[9] = -0.0013;\r\n },\r\n\r\n /**\r\n New Zealand Map Grid Forward - long/lat to x/y\r\n long/lat in radians\r\n */\r\n forward: function(p) {\r\n var lon = p.x;\r\n var lat = p.y;\r\n\r\n var delta_lat = lat - this.lat0;\r\n var delta_lon = lon - this.long0;\r\n\r\n // 1. Calculate d_phi and d_psi ... // and d_lambda\r\n // For this algorithm, delta_latitude is in seconds of arc x 10-5, so we need to scale to those units. Longitude is radians.\r\n var d_phi = (delta_lat / Proj4js.common.SEC_TO_RAD) * 1e-5;\r\n var d_lambda = delta_lon;\r\n var d_phi_n = 1; // d_phi^0\r\n\r\n var d_psi = 0;\r\n for (var n = 1; n <= 10; n++) {\r\n d_phi_n = d_phi_n * d_phi;\r\n d_psi = d_psi + this.A[n] * d_phi_n;\r\n }\r\n\r\n // 2. Calculate theta\r\n var th_re = d_psi;\r\n var th_im = d_lambda;\r\n\r\n // 3. Calculate z\r\n var th_n_re = 1;\r\n var th_n_im = 0; // theta^0\r\n var th_n_re1;\r\n var th_n_im1;\r\n\r\n var z_re = 0;\r\n var z_im = 0;\r\n for (var n = 1; n <= 6; n++) {\r\n th_n_re1 = th_n_re * th_re - th_n_im * th_im;\r\n th_n_im1 = th_n_im * th_re + th_n_re * th_im;\r\n th_n_re = th_n_re1;\r\n th_n_im = th_n_im1;\r\n z_re = z_re + this.B_re[n] * th_n_re - this.B_im[n] * th_n_im;\r\n z_im = z_im + this.B_im[n] * th_n_re + this.B_re[n] * th_n_im;\r\n }\r\n\r\n // 4. Calculate easting and northing\r\n p.x = z_im * this.a + this.x0;\r\n p.y = z_re * this.a + this.y0;\r\n\r\n return p;\r\n },\r\n\r\n /**\r\n New Zealand Map Grid Inverse - x/y to long/lat\r\n */\r\n inverse: function(p) {\r\n var x = p.x;\r\n var y = p.y;\r\n\r\n var delta_x = x - this.x0;\r\n var delta_y = y - this.y0;\r\n\r\n // 1. Calculate z\r\n var z_re = delta_y / this.a;\r\n var z_im = delta_x / this.a;\r\n\r\n // 2a. Calculate theta - first approximation gives km accuracy\r\n var z_n_re = 1;\r\n var z_n_im = 0; // z^0\r\n var z_n_re1;\r\n var z_n_im1;\r\n\r\n var th_re = 0;\r\n var th_im = 0;\r\n for (var n = 1; n <= 6; n++) {\r\n z_n_re1 = z_n_re * z_re - z_n_im * z_im;\r\n z_n_im1 = z_n_im * z_re + z_n_re * z_im;\r\n z_n_re = z_n_re1;\r\n z_n_im = z_n_im1;\r\n th_re = th_re + this.C_re[n] * z_n_re - this.C_im[n] * z_n_im;\r\n th_im = th_im + this.C_im[n] * z_n_re + this.C_re[n] * z_n_im;\r\n }\r\n\r\n // 2b. Iterate to refine the accuracy of the calculation\r\n // 0 iterations gives km accuracy\r\n // 1 iteration gives m accuracy -- good enough for most mapping applications\r\n // 2 iterations bives mm accuracy\r\n for (var i = 0; i < this.iterations; i++) {\r\n var th_n_re = th_re;\r\n var th_n_im = th_im;\r\n var th_n_re1;\r\n var th_n_im1;\r\n\r\n var num_re = z_re;\r\n var num_im = z_im;\r\n for (var n = 2; n <= 6; n++) {\r\n th_n_re1 = th_n_re * th_re - th_n_im * th_im;\r\n th_n_im1 = th_n_im * th_re + th_n_re * th_im;\r\n th_n_re = th_n_re1;\r\n th_n_im = th_n_im1;\r\n num_re =\r\n num_re + (n - 1) * (this.B_re[n] * th_n_re - this.B_im[n] * th_n_im);\r\n num_im =\r\n num_im + (n - 1) * (this.B_im[n] * th_n_re + this.B_re[n] * th_n_im);\r\n }\r\n\r\n th_n_re = 1;\r\n th_n_im = 0;\r\n var den_re = this.B_re[1];\r\n var den_im = this.B_im[1];\r\n for (var n = 2; n <= 6; n++) {\r\n th_n_re1 = th_n_re * th_re - th_n_im * th_im;\r\n th_n_im1 = th_n_im * th_re + th_n_re * th_im;\r\n th_n_re = th_n_re1;\r\n th_n_im = th_n_im1;\r\n den_re = den_re + n * (this.B_re[n] * th_n_re - this.B_im[n] * th_n_im);\r\n den_im = den_im + n * (this.B_im[n] * th_n_re + this.B_re[n] * th_n_im);\r\n }\r\n\r\n // Complex division\r\n var den2 = den_re * den_re + den_im * den_im;\r\n th_re = (num_re * den_re + num_im * den_im) / den2;\r\n th_im = (num_im * den_re - num_re * den_im) / den2;\r\n }\r\n\r\n // 3. Calculate d_phi ... // and d_lambda\r\n var d_psi = th_re;\r\n var d_lambda = th_im;\r\n var d_psi_n = 1; // d_psi^0\r\n\r\n var d_phi = 0;\r\n for (var n = 1; n <= 9; n++) {\r\n d_psi_n = d_psi_n * d_psi;\r\n d_phi = d_phi + this.D[n] * d_psi_n;\r\n }\r\n\r\n // 4. Calculate latitude and longitude\r\n // d_phi is calcuated in second of arc * 10^-5, so we need to scale back to radians. d_lambda is in radians.\r\n var lat = this.lat0 + d_phi * Proj4js.common.SEC_TO_RAD * 1e5;\r\n var lon = this.long0 + d_lambda;\r\n\r\n p.x = lon;\r\n p.y = lat;\r\n\r\n return p;\r\n }\r\n};\r\n/* ======================================================================\r\n projCode/mill.js\r\n ====================================================================== */\r\n\r\n/*******************************************************************************\r\nNAME MILLER CYLINDRICAL \r\n\r\nPURPOSE:\tTransforms input longitude and latitude to Easting and\r\n\t\tNorthing for the Miller Cylindrical projection. The\r\n\t\tlongitude and latitude must be in radians. The Easting\r\n\t\tand Northing values will be returned in meters.\r\n\r\nPROGRAMMER DATE \r\n---------- ---- \r\nT. Mittan\t\tMarch, 1993\r\n\r\nThis function was adapted from the Lambert Azimuthal Equal Area projection\r\ncode (FORTRAN) in the General Cartographic Transformation Package software\r\nwhich is available from the U.S. Geological Survey National Mapping Division.\r\n \r\nALGORITHM REFERENCES\r\n\r\n1. \"New Equal-Area Map Projections for Noncircular Regions\", John P. Snyder,\r\n The American Cartographer, Vol 15, No. 4, October 1988, pp. 341-355.\r\n\r\n2. Snyder, John P., \"Map Projections--A Working Manual\", U.S. Geological\r\n Survey Professional Paper 1395 (Supersedes USGS Bulletin 1532), United\r\n State Government Printing Office, Washington D.C., 1987.\r\n\r\n3. \"Software Documentation for GCTP General Cartographic Transformation\r\n Package\", U.S. Geological Survey National Mapping Division, May 1982.\r\n*******************************************************************************/\r\n\r\nProj4js.Proj.mill = {\r\n /* Initialize the Miller Cylindrical projection\r\n -------------------------------------------*/\r\n init: function() {\r\n //no-op\r\n },\r\n\r\n /* Miller Cylindrical forward equations--mapping lat,long to x,y\r\n ------------------------------------------------------------*/\r\n forward: function(p) {\r\n var lon = p.x;\r\n var lat = p.y;\r\n /* Forward equations\r\n -----------------*/\r\n var dlon = Proj4js.common.adjust_lon(lon - this.long0);\r\n var x = this.x0 + this.a * dlon;\r\n var y =\r\n this.y0 +\r\n this.a * Math.log(Math.tan(Proj4js.common.PI / 4.0 + lat / 2.5)) * 1.25;\r\n\r\n p.x = x;\r\n p.y = y;\r\n return p;\r\n }, //millFwd()\r\n\r\n /* Miller Cylindrical inverse equations--mapping x,y to lat/long\r\n ------------------------------------------------------------*/\r\n inverse: function(p) {\r\n p.x -= this.x0;\r\n p.y -= this.y0;\r\n\r\n var lon = Proj4js.common.adjust_lon(this.long0 + p.x / this.a);\r\n var lat =\r\n 2.5 *\r\n (Math.atan(Math.exp((0.8 * p.y) / this.a)) - Proj4js.common.PI / 4.0);\r\n\r\n p.x = lon;\r\n p.y = lat;\r\n return p;\r\n } //millInv()\r\n};\r\n/* ======================================================================\r\n projCode/gnom.js\r\n ====================================================================== */\r\n\r\n/*****************************************************************************\r\nNAME GNOMONIC\r\n\r\nPURPOSE:\tTransforms input longitude and latitude to Easting and\r\n\t\tNorthing for the Gnomonic Projection.\r\n Implementation based on the existing sterea and ortho\r\n implementations.\r\n\r\nPROGRAMMER DATE\r\n---------- ----\r\nRichard Marsden November 2009\r\n\r\nALGORITHM REFERENCES\r\n\r\n1. Snyder, John P., \"Flattening the Earth - Two Thousand Years of Map \r\n Projections\", University of Chicago Press 1993\r\n\r\n2. Wolfram Mathworld \"Gnomonic Projection\"\r\n http://mathworld.wolfram.com/GnomonicProjection.html\r\n Accessed: 12th November 2009\r\n******************************************************************************/\r\n\r\nProj4js.Proj.gnom = {\r\n /* Initialize the Gnomonic projection\r\n -------------------------------------*/\r\n init: function(def) {\r\n /* Place parameters in static storage for common use\r\n -------------------------------------------------*/\r\n this.sin_p14 = Math.sin(this.lat0);\r\n this.cos_p14 = Math.cos(this.lat0);\r\n // Approximation for projecting points to the horizon (infinity)\r\n this.infinity_dist = 1000 * this.a;\r\n this.rc = 1;\r\n },\r\n\r\n /* Gnomonic forward equations--mapping lat,long to x,y\r\n ---------------------------------------------------*/\r\n forward: function(p) {\r\n var sinphi, cosphi; /* sin and cos value\t\t\t\t*/\r\n var dlon; /* delta longitude value\t\t\t*/\r\n var coslon; /* cos of longitude\t\t\t\t*/\r\n var ksp; /* scale factor\t\t\t\t\t*/\r\n var g;\r\n var x, y;\r\n var lon = p.x;\r\n var lat = p.y;\r\n /* Forward equations\r\n -----------------*/\r\n dlon = Proj4js.common.adjust_lon(lon - this.long0);\r\n\r\n sinphi = Math.sin(lat);\r\n cosphi = Math.cos(lat);\r\n\r\n coslon = Math.cos(dlon);\r\n g = this.sin_p14 * sinphi + this.cos_p14 * cosphi * coslon;\r\n ksp = 1.0;\r\n if (g > 0 || Math.abs(g) <= Proj4js.common.EPSLN) {\r\n x = this.x0 + (this.a * ksp * cosphi * Math.sin(dlon)) / g;\r\n y =\r\n this.y0 +\r\n (this.a *\r\n ksp *\r\n (this.cos_p14 * sinphi - this.sin_p14 * cosphi * coslon)) /\r\n g;\r\n }\n else {\r\n Proj4js.reportError(\"orthoFwdPointError\");\r\n\r\n // Point is in the opposing hemisphere and is unprojectable\r\n // We still need to return a reasonable point, so we project\r\n // to infinity, on a bearing\r\n // equivalent to the northern hemisphere equivalent\r\n // This is a reasonable approximation for short shapes and lines that\r\n // straddle the horizon.\r\n\r\n x = this.x0 + this.infinity_dist * cosphi * Math.sin(dlon);\r\n y =\r\n this.y0 +\r\n this.infinity_dist *\r\n (this.cos_p14 * sinphi - this.sin_p14 * cosphi * coslon);\r\n }\r\n p.x = x;\r\n p.y = y;\r\n return p;\r\n },\r\n\r\n inverse: function(p) {\r\n var rh; /* Rho */\r\n var z; /* angle */\r\n var sinc, cosc;\r\n var c;\r\n var lon, lat;\r\n\r\n /* Inverse equations\r\n -----------------*/\r\n p.x = (p.x - this.x0) / this.a;\r\n p.y = (p.y - this.y0) / this.a;\r\n\r\n p.x /= this.k0;\r\n p.y /= this.k0;\r\n\r\n if ((rh = Math.sqrt(p.x * p.x + p.y * p.y))) {\r\n c = Math.atan2(rh, this.rc);\r\n sinc = Math.sin(c);\r\n cosc = Math.cos(c);\r\n\r\n lat = Proj4js.common.asinz(\r\n cosc * this.sin_p14 + (p.y * sinc * this.cos_p14) / rh\r\n );\r\n lon = Math.atan2(\r\n p.x * sinc,\r\n rh * this.cos_p14 * cosc - p.y * this.sin_p14 * sinc\r\n );\r\n lon = Proj4js.common.adjust_lon(this.long0 + lon);\r\n }\n else {\r\n lat = this.phic0;\r\n lon = 0.0;\r\n }\r\n\r\n p.x = lon;\r\n p.y = lat;\r\n return p;\r\n }\r\n};\r\n\r\n/* ======================================================================\r\n projCode/sinu.js\r\n ====================================================================== */\r\n\r\n/*******************************************************************************\r\nNAME \t\tSINUSOIDAL\r\n\r\nPURPOSE:\tTransforms input longitude and latitude to Easting and\r\n\t\tNorthing for the Sinusoidal projection. The\r\n\t\tlongitude and latitude must be in radians. The Easting\r\n\t\tand Northing values will be returned in meters.\r\n\r\nPROGRAMMER DATE \r\n---------- ---- \r\nD. Steinwand, EROS May, 1991 \r\n\r\nThis function was adapted from the Sinusoidal projection code (FORTRAN) in the \r\nGeneral Cartographic Transformation Package software which is available from \r\nthe U.S. Geological Survey National Mapping Division.\r\n \r\nALGORITHM REFERENCES\r\n\r\n1. Snyder, John P., \"Map Projections--A Working Manual\", U.S. Geological\r\n Survey Professional Paper 1395 (Supersedes USGS Bulletin 1532), United\r\n State Government Printing Office, Washington D.C., 1987.\r\n\r\n2. \"Software Documentation for GCTP General Cartographic Transformation\r\n Package\", U.S. Geological Survey National Mapping Division, May 1982.\r\n*******************************************************************************/\r\n\r\nProj4js.Proj.sinu = {\r\n /* Initialize the Sinusoidal projection\r\n\t ------------------------------------*/\r\n init: function() {\r\n /* Place parameters in static storage for common use\r\n\t\t -------------------------------------------------*/\r\n\r\n if (!this.sphere) {\r\n this.en = Proj4js.common.pj_enfn(this.es);\r\n }\n else {\r\n this.n = 1;\r\n this.m = 0;\r\n this.es = 0;\r\n this.C_y = Math.sqrt((this.m + 1) / this.n);\r\n this.C_x = this.C_y / (this.m + 1);\r\n }\r\n },\r\n\r\n /* Sinusoidal forward equations--mapping lat,long to x,y\r\n\t-----------------------------------------------------*/\r\n forward: function(p) {\r\n var x, y, delta_lon;\r\n var lon = p.x;\r\n var lat = p.y;\r\n /* Forward equations\r\n\t\t-----------------*/\r\n lon = Proj4js.common.adjust_lon(lon - this.long0);\r\n\r\n if (this.sphere) {\r\n if (!this.m) {\r\n lat = this.n != 1 ? Math.asin(this.n * Math.sin(lat)) : lat;\r\n }\n else {\r\n var k = this.n * Math.sin(lat);\r\n for (var i = Proj4js.common.MAX_ITER; i; --i) {\r\n var V = (this.m * lat + Math.sin(lat) - k) / (this.m + Math.cos(lat));\r\n lat -= V;\r\n if (Math.abs(V) < Proj4js.common.EPSLN) break;\r\n }\r\n }\r\n x = this.a * this.C_x * lon * (this.m + Math.cos(lat));\r\n y = this.a * this.C_y * lat;\r\n }\n else {\r\n var s = Math.sin(lat);\r\n var c = Math.cos(lat);\r\n y = this.a * Proj4js.common.pj_mlfn(lat, s, c, this.en);\r\n x = (this.a * lon * c) / Math.sqrt(1 - this.es * s * s);\r\n }\r\n\r\n p.x = x;\r\n p.y = y;\r\n return p;\r\n },\r\n\r\n inverse: function(p) {\r\n var lat, temp, lon;\r\n\r\n /* Inverse equations\r\n\t\t -----------------*/\r\n p.x -= this.x0;\r\n p.y -= this.y0;\r\n lat = p.y / this.a;\r\n\r\n if (this.sphere) {\r\n p.y /= this.C_y;\r\n lat = this.m\r\n ? Math.asin((this.m * p.y + Math.sin(p.y)) / this.n)\r\n : this.n != 1\r\n ? Math.asin(Math.sin(p.y) / this.n)\r\n : p.y;\r\n lon = p.x / (this.C_x * (this.m + Math.cos(p.y)));\r\n }\n else {\r\n lat = Proj4js.common.pj_inv_mlfn(p.y / this.a, this.es, this.en);\r\n var s = Math.abs(lat);\r\n if (s < Proj4js.common.HALF_PI) {\r\n s = Math.sin(lat);\r\n temp =\r\n this.long0 +\r\n (p.x * Math.sqrt(1 - this.es * s * s)) / (this.a * Math.cos(lat));\r\n //temp = this.long0 + p.x / (this.a * Math.cos(lat));\r\n lon = Proj4js.common.adjust_lon(temp);\r\n }\n else if (s - Proj4js.common.EPSLN < Proj4js.common.HALF_PI) {\r\n lon = this.long0;\r\n }\r\n }\r\n\r\n p.x = lon;\r\n p.y = lat;\r\n return p;\r\n }\r\n};\r\n\r\n/* ======================================================================\r\n projCode/vandg.js\r\n ====================================================================== */\r\n\r\n/*******************************************************************************\r\nNAME VAN DER GRINTEN \r\n\r\nPURPOSE:\tTransforms input Easting and Northing to longitude and\r\n\t\tlatitude for the Van der Grinten projection. The\r\n\t\tEasting and Northing must be in meters. The longitude\r\n\t\tand latitude values will be returned in radians.\r\n\r\nPROGRAMMER DATE \r\n---------- ---- \r\nT. Mittan\t\tMarch, 1993\r\n\r\nThis function was adapted from the Van Der Grinten projection code\r\n(FORTRAN) in the General Cartographic Transformation Package software\r\nwhich is available from the U.S. Geological Survey National Mapping Division.\r\n \r\nALGORITHM REFERENCES\r\n\r\n1. \"New Equal-Area Map Projections for Noncircular Regions\", John P. Snyder,\r\n The American Cartographer, Vol 15, No. 4, October 1988, pp. 341-355.\r\n\r\n2. Snyder, John P., \"Map Projections--A Working Manual\", U.S. Geological\r\n Survey Professional Paper 1395 (Supersedes USGS Bulletin 1532), United\r\n State Government Printing Office, Washington D.C., 1987.\r\n\r\n3. \"Software Documentation for GCTP General Cartographic Transformation\r\n Package\", U.S. Geological Survey National Mapping Division, May 1982.\r\n*******************************************************************************/\r\n\r\nProj4js.Proj.vandg = {\r\n /* Initialize the Van Der Grinten projection\r\n ----------------------------------------*/\r\n init: function() {\r\n this.R = 6370997.0; //Radius of earth\r\n },\r\n\r\n forward: function(p) {\r\n var lon = p.x;\r\n var lat = p.y;\r\n\r\n /* Forward equations\r\n\t\t-----------------*/\r\n var dlon = Proj4js.common.adjust_lon(lon - this.long0);\r\n var x, y;\r\n\r\n if (Math.abs(lat) <= Proj4js.common.EPSLN) {\r\n x = this.x0 + this.R * dlon;\r\n y = this.y0;\r\n }\r\n var theta = Proj4js.common.asinz(2.0 * Math.abs(lat / Proj4js.common.PI));\r\n if (\r\n Math.abs(dlon) <= Proj4js.common.EPSLN ||\r\n Math.abs(Math.abs(lat) - Proj4js.common.HALF_PI) <= Proj4js.common.EPSLN\r\n ) {\r\n x = this.x0;\r\n if (lat >= 0) {\r\n y = this.y0 + Proj4js.common.PI * this.R * Math.tan(0.5 * theta);\r\n }\n else {\r\n y = this.y0 + Proj4js.common.PI * this.R * -Math.tan(0.5 * theta);\r\n }\r\n // return(OK);\r\n }\r\n var al =\r\n 0.5 * Math.abs(Proj4js.common.PI / dlon - dlon / Proj4js.common.PI);\r\n var asq = al * al;\r\n var sinth = Math.sin(theta);\r\n var costh = Math.cos(theta);\r\n\r\n var g = costh / (sinth + costh - 1.0);\r\n var gsq = g * g;\r\n var m = g * (2.0 / sinth - 1.0);\r\n var msq = m * m;\r\n var con =\r\n (Proj4js.common.PI *\r\n this.R *\r\n (al * (g - msq) +\r\n Math.sqrt(asq * (g - msq) * (g - msq) - (msq + asq) * (gsq - msq)))) /\r\n (msq + asq);\r\n if (dlon < 0) {\r\n con = -con;\r\n }\r\n x = this.x0 + con;\r\n con = Math.abs(con / (Proj4js.common.PI * this.R));\r\n if (lat >= 0) {\r\n y =\r\n this.y0 +\r\n Proj4js.common.PI *\r\n this.R *\r\n Math.sqrt(1.0 - con * con - 2.0 * al * con);\r\n }\n else {\r\n y =\r\n this.y0 -\r\n Proj4js.common.PI *\r\n this.R *\r\n Math.sqrt(1.0 - con * con - 2.0 * al * con);\r\n }\r\n p.x = x;\r\n p.y = y;\r\n return p;\r\n },\r\n\r\n /* Van Der Grinten inverse equations--mapping x,y to lat/long\r\n ---------------------------------------------------------*/\r\n inverse: function(p) {\r\n var lon, lat;\r\n var xx, yy, xys, c1, c2, c3;\r\n var al, asq;\r\n var a1;\r\n var m1;\r\n var con;\r\n var th1;\r\n var d;\r\n\r\n /* inverse equations\r\n\t\t-----------------*/\r\n p.x -= this.x0;\r\n p.y -= this.y0;\r\n con = Proj4js.common.PI * this.R;\r\n xx = p.x / con;\r\n yy = p.y / con;\r\n xys = xx * xx + yy * yy;\r\n c1 = -Math.abs(yy) * (1.0 + xys);\r\n c2 = c1 - 2.0 * yy * yy + xx * xx;\r\n c3 = -2.0 * c1 + 1.0 + 2.0 * yy * yy + xys * xys;\r\n d =\r\n (yy * yy) / c3 +\r\n ((2.0 * c2 * c2 * c2) / c3 / c3 / c3 - (9.0 * c1 * c2) / c3 / c3) / 27.0;\r\n a1 = (c1 - (c2 * c2) / 3.0 / c3) / c3;\r\n m1 = 2.0 * Math.sqrt(-a1 / 3.0);\r\n con = (3.0 * d) / a1 / m1;\r\n if (Math.abs(con) > 1.0) {\r\n if (con >= 0.0) {\r\n con = 1.0;\r\n }\n else {\r\n con = -1.0;\r\n }\r\n }\r\n th1 = Math.acos(con) / 3.0;\r\n if (p.y >= 0) {\r\n lat =\r\n (-m1 * Math.cos(th1 + Proj4js.common.PI / 3.0) - c2 / 3.0 / c3) *\r\n Proj4js.common.PI;\r\n }\n else {\r\n lat =\r\n -(-m1 * Math.cos(th1 + Proj4js.common.PI / 3.0) - c2 / 3.0 / c3) *\r\n Proj4js.common.PI;\r\n }\r\n\r\n if (Math.abs(xx) < Proj4js.common.EPSLN) {\r\n lon = this.long0;\r\n }\r\n lon = Proj4js.common.adjust_lon(\r\n this.long0 +\r\n (Proj4js.common.PI *\r\n (xys -\r\n 1.0 +\r\n Math.sqrt(1.0 + 2.0 * (xx * xx - yy * yy) + xys * xys))) /\r\n 2.0 /\r\n xx\r\n );\r\n\r\n p.x = lon;\r\n p.y = lat;\r\n return p;\r\n }\r\n};\r\n/* ======================================================================\r\n projCode/cea.js\r\n ====================================================================== */\r\n\r\n/*******************************************************************************\r\nNAME LAMBERT CYLINDRICAL EQUAL AREA\r\n\r\nPURPOSE:\tTransforms input longitude and latitude to Easting and\r\n\t\tNorthing for the Lambert Cylindrical Equal Area projection.\r\n This class of projection includes the Behrmann and \r\n Gall-Peters Projections. The\r\n\t\tlongitude and latitude must be in radians. The Easting\r\n\t\tand Northing values will be returned in meters.\r\n\r\nPROGRAMMER DATE \r\n---------- ----\r\nR. Marsden August 2009\r\nWinwaed Software Tech LLC, http://www.winwaed.com\r\n\r\nThis function was adapted from the Miller Cylindrical Projection in the Proj4JS\r\nlibrary.\r\n\r\nNote: This implementation assumes a Spherical Earth. The (commented) code \r\nhas been included for the ellipsoidal forward transform, but derivation of \r\nthe ellispoidal inverse transform is beyond me. Note that most of the \r\nProj4JS implementations do NOT currently support ellipsoidal figures. \r\nTherefore this is not seen as a problem - especially this lack of support \r\nis explicitly stated here.\r\n \r\nALGORITHM REFERENCES\r\n\r\n1. \"Cartographic Projection Procedures for the UNIX Environment - \r\n A User's Manual\" by Gerald I. Evenden, USGS Open File Report 90-284\r\n and Release 4 Interim Reports (2003)\r\n\r\n2. Snyder, John P., \"Flattening the Earth - Two Thousand Years of Map \r\n Projections\", Univ. Chicago Press, 1993\r\n*******************************************************************************/\r\n\r\nProj4js.Proj.cea = {\r\n /* Initialize the Cylindrical Equal Area projection\r\n -------------------------------------------*/\r\n init: function() {\r\n //no-op\r\n },\r\n\r\n /* Cylindrical Equal Area forward equations--mapping lat,long to x,y\r\n ------------------------------------------------------------*/\r\n forward: function(p) {\r\n var lon = p.x;\r\n var lat = p.y;\r\n /* Forward equations\r\n -----------------*/\r\n var dlon = Proj4js.common.adjust_lon(lon - this.long0);\r\n var x = this.x0 + this.a * dlon * Math.cos(this.lat_ts);\r\n var y = this.y0 + (this.a * Math.sin(lat)) / Math.cos(this.lat_ts);\r\n /* Elliptical Forward Transform\r\n Not implemented due to a lack of a matchign inverse function\r\n {\r\n var Sin_Lat = Math.sin(lat);\r\n var Rn = this.a * (Math.sqrt(1.0e0 - this.es * Sin_Lat * Sin_Lat ));\r\n x = this.x0 + this.a * dlon * Math.cos(this.lat_ts);\r\n y = this.y0 + Rn * Math.sin(lat) / Math.cos(this.lat_ts);\r\n }\r\n */\r\n\r\n p.x = x;\r\n p.y = y;\r\n return p;\r\n }, //ceaFwd()\r\n\r\n /* Cylindrical Equal Area inverse equations--mapping x,y to lat/long\r\n ------------------------------------------------------------*/\r\n inverse: function(p) {\r\n p.x -= this.x0;\r\n p.y -= this.y0;\r\n\r\n var lon = Proj4js.common.adjust_lon(\r\n this.long0 + p.x / this.a / Math.cos(this.lat_ts)\r\n );\r\n\r\n var lat = Math.asin((p.y / this.a) * Math.cos(this.lat_ts));\r\n\r\n p.x = lon;\r\n p.y = lat;\r\n return p;\r\n } //ceaInv()\r\n};\r\n/* ======================================================================\r\n projCode/eqc.js\r\n ====================================================================== */\r\n\r\n/* similar to equi.js FIXME proj4 uses eqc */\r\nProj4js.Proj.eqc = {\r\n init: function() {\r\n if (!this.x0) this.x0 = 0;\r\n if (!this.y0) this.y0 = 0;\r\n if (!this.lat0) this.lat0 = 0;\r\n if (!this.long0) this.long0 = 0;\r\n if (!this.lat_ts) this.lat_ts = 0;\r\n if (!this.title) this.title = \"Equidistant Cylindrical (Plate Carre)\";\r\n\r\n this.rc = Math.cos(this.lat_ts);\r\n },\r\n\r\n // forward equations--mapping lat,long to x,y\r\n // -----------------------------------------------------------------\r\n forward: function(p) {\r\n var lon = p.x;\r\n var lat = p.y;\r\n\r\n var dlon = Proj4js.common.adjust_lon(lon - this.long0);\r\n var dlat = Proj4js.common.adjust_lat(lat - this.lat0);\r\n p.x = this.x0 + this.a * dlon * this.rc;\r\n p.y = this.y0 + this.a * dlat;\r\n return p;\r\n },\r\n\r\n // inverse equations--mapping x,y to lat/long\r\n // -----------------------------------------------------------------\r\n inverse: function(p) {\r\n var x = p.x;\r\n var y = p.y;\r\n\r\n p.x = Proj4js.common.adjust_lon(\r\n this.long0 + (x - this.x0) / (this.a * this.rc)\r\n );\r\n p.y = Proj4js.common.adjust_lat(this.lat0 + (y - this.y0) / this.a);\r\n return p;\r\n }\r\n};\r\n/* ======================================================================\r\n projCode/cass.js\r\n ====================================================================== */\r\n\r\n/*******************************************************************************\r\nNAME CASSINI\r\n\r\nPURPOSE:\tTransforms input longitude and latitude to Easting and\r\n\t\tNorthing for the Cassini projection. The\r\n\t\tlongitude and latitude must be in radians. The Easting\r\n\t\tand Northing values will be returned in meters.\r\n Ported from PROJ.4.\r\n\r\n\r\nALGORITHM REFERENCES\r\n\r\n1. Snyder, John P., \"Map Projections--A Working Manual\", U.S. Geological\r\n Survey Professional Paper 1395 (Supersedes USGS Bulletin 1532), United\r\n State Government Printing Office, Washington D.C., 1987.\r\n\r\n2. Snyder, John P. and Voxland, Philip M., \"An Album of Map Projections\",\r\n U.S. Geological Survey Professional Paper 1453 , United State Government\r\n*******************************************************************************/\r\n\r\n//Proj4js.defs[\"EPSG:28191\"] = \"+proj=cass +lat_0=31.73409694444445 +lon_0=35.21208055555556 +x_0=170251.555 +y_0=126867.909 +a=6378300.789 +b=6356566.435 +towgs84=-275.722,94.7824,340.894,-8.001,-4.42,-11.821,1 +units=m +no_defs\";\r\n\r\n// Initialize the Cassini projection\r\n// -----------------------------------------------------------------\r\n\r\nProj4js.Proj.cass = {\r\n init: function() {\r\n if (!this.sphere) {\r\n this.en = Proj4js.common.pj_enfn(this.es);\r\n this.m0 = Proj4js.common.pj_mlfn(\r\n this.lat0,\r\n Math.sin(this.lat0),\r\n Math.cos(this.lat0),\r\n this.en\r\n );\r\n }\r\n },\r\n\r\n C1: 0.16666666666666666666,\r\n C2: 0.00833333333333333333,\r\n C3: 0.04166666666666666666,\r\n C4: 0.33333333333333333333,\r\n C5: 0.06666666666666666666,\r\n\r\n /* Cassini forward equations--mapping lat,long to x,y\r\n -----------------------------------------------------------------------*/\r\n forward: function(p) {\r\n /* Forward equations\r\n -----------------*/\r\n var x, y;\r\n var lam = p.x;\r\n var phi = p.y;\r\n lam = Proj4js.common.adjust_lon(lam - this.long0);\r\n\r\n if (this.sphere) {\r\n x = Math.asin(Math.cos(phi) * Math.sin(lam));\r\n y = Math.atan2(Math.tan(phi), Math.cos(lam)) - this.phi0;\r\n }\n else {\r\n //ellipsoid\r\n this.n = Math.sin(phi);\r\n this.c = Math.cos(phi);\r\n y = Proj4js.common.pj_mlfn(phi, this.n, this.c, this.en);\r\n this.n = 1 / Math.sqrt(1 - this.es * this.n * this.n);\r\n this.tn = Math.tan(phi);\r\n this.t = this.tn * this.tn;\r\n this.a1 = lam * this.c;\r\n this.c *= (this.es * this.c) / (1 - this.es);\r\n this.a2 = this.a1 * this.a1;\r\n x =\r\n this.n *\r\n this.a1 *\r\n (1 -\r\n this.a2 *\r\n this.t *\r\n (this.C1 - (8 - this.t + 8 * this.c) * this.a2 * this.C2));\r\n y -=\r\n this.m0 -\r\n this.n *\r\n this.tn *\r\n this.a2 *\r\n (0.5 + (5 - this.t + 6 * this.c) * this.a2 * this.C3);\r\n }\r\n\r\n p.x = this.a * x + this.x0;\r\n p.y = this.a * y + this.y0;\r\n return p;\r\n }, //cassFwd()\r\n\r\n /* Inverse equations\r\n -----------------*/\r\n inverse: function(p) {\r\n p.x -= this.x0;\r\n p.y -= this.y0;\r\n var x = p.x / this.a;\r\n var y = p.y / this.a;\r\n var phi, lam;\r\n\r\n if (this.sphere) {\r\n this.dd = y + this.lat0;\r\n phi = Math.asin(Math.sin(this.dd) * Math.cos(x));\r\n lam = Math.atan2(Math.tan(x), Math.cos(this.dd));\r\n }\n else {\r\n /* ellipsoid */\r\n var ph1 = Proj4js.common.pj_inv_mlfn(this.m0 + y, this.es, this.en);\r\n this.tn = Math.tan(ph1);\r\n this.t = this.tn * this.tn;\r\n this.n = Math.sin(ph1);\r\n this.r = 1 / (1 - this.es * this.n * this.n);\r\n this.n = Math.sqrt(this.r);\r\n this.r *= (1 - this.es) * this.n;\r\n this.dd = x / this.n;\r\n this.d2 = this.dd * this.dd;\r\n phi =\r\n ph1 -\r\n ((this.n * this.tn) / this.r) *\r\n this.d2 *\r\n (0.5 - (1 + 3 * this.t) * this.d2 * this.C3);\r\n lam =\r\n (this.dd *\r\n (1 +\r\n this.t *\r\n this.d2 *\r\n (-this.C4 + (1 + 3 * this.t) * this.d2 * this.C5))) /\r\n Math.cos(ph1);\r\n }\r\n p.x = Proj4js.common.adjust_lon(this.long0 + lam);\r\n p.y = phi;\r\n return p;\r\n } //cassInv()\r\n};\r\n/* ======================================================================\r\n projCode/gauss.js\r\n ====================================================================== */\r\n\r\nProj4js.Proj.gauss = {\r\n init: function() {\r\n var sphi = Math.sin(this.lat0);\r\n var cphi = Math.cos(this.lat0);\r\n cphi *= cphi;\r\n this.rc = Math.sqrt(1.0 - this.es) / (1.0 - this.es * sphi * sphi);\r\n this.C = Math.sqrt(1.0 + (this.es * cphi * cphi) / (1.0 - this.es));\r\n this.phic0 = Math.asin(sphi / this.C);\r\n this.ratexp = 0.5 * this.C * this.e;\r\n this.K =\r\n Math.tan(0.5 * this.phic0 + Proj4js.common.FORTPI) /\r\n (Math.pow(Math.tan(0.5 * this.lat0 + Proj4js.common.FORTPI), this.C) *\r\n Proj4js.common.srat(this.e * sphi, this.ratexp));\r\n },\r\n\r\n forward: function(p) {\r\n var lon = p.x;\r\n var lat = p.y;\r\n\r\n p.y =\r\n 2.0 *\r\n Math.atan(\r\n this.K *\r\n Math.pow(Math.tan(0.5 * lat + Proj4js.common.FORTPI), this.C) *\r\n Proj4js.common.srat(this.e * Math.sin(lat), this.ratexp)\r\n ) -\r\n Proj4js.common.HALF_PI;\r\n p.x = this.C * lon;\r\n return p;\r\n },\r\n\r\n inverse: function(p) {\r\n var DEL_TOL = 1e-14;\r\n var lon = p.x / this.C;\r\n var lat = p.y;\r\n var num = Math.pow(\r\n Math.tan(0.5 * lat + Proj4js.common.FORTPI) / this.K,\r\n 1 / this.C\r\n );\r\n for (var i = Proj4js.common.MAX_ITER; i > 0; --i) {\r\n lat =\r\n 2.0 *\r\n Math.atan(\r\n num * Proj4js.common.srat(this.e * Math.sin(p.y), -0.5 * this.e)\r\n ) -\r\n Proj4js.common.HALF_PI;\r\n if (Math.abs(lat - p.y) < DEL_TOL) break;\r\n p.y = lat;\r\n }\r\n /* convergence failed */\r\n if (!i) {\r\n Proj4js.reportError(\"gauss:inverse:convergence failed\");\r\n return null;\r\n }\r\n p.x = lon;\r\n p.y = lat;\r\n return p;\r\n }\r\n};\r\n\r\n/* ======================================================================\r\n projCode/omerc.js\r\n ====================================================================== */\r\n\r\n/*******************************************************************************\r\nNAME OBLIQUE MERCATOR (HOTINE) \r\n\r\nPURPOSE:\tTransforms input longitude and latitude to Easting and\r\n\t\tNorthing for the Oblique Mercator projection. The\r\n\t\tlongitude and latitude must be in radians. The Easting\r\n\t\tand Northing values will be returned in meters.\r\n\r\nPROGRAMMER DATE\r\n---------- ----\r\nT. Mittan\t\tMar, 1993\r\n\r\nALGORITHM REFERENCES\r\n\r\n1. Snyder, John P., \"Map Projections--A Working Manual\", U.S. Geological\r\n Survey Professional Paper 1395 (Supersedes USGS Bulletin 1532), United\r\n State Government Printing Office, Washington D.C., 1987.\r\n\r\n2. Snyder, John P. and Voxland, Philip M., \"An Album of Map Projections\",\r\n U.S. Geological Survey Professional Paper 1453 , United State Government\r\n Printing Office, Washington D.C., 1989.\r\n*******************************************************************************/\r\n\r\nProj4js.Proj.omerc = {\r\n /* Initialize the Oblique Mercator projection\r\n ------------------------------------------*/\r\n init: function() {\r\n if (!this.mode) this.mode = 0;\r\n if (!this.lon1) {\r\n this.lon1 = 0;\r\n this.mode = 1;\r\n }\r\n if (!this.lon2) this.lon2 = 0;\r\n if (!this.lat2) this.lat2 = 0;\r\n\r\n /* Place parameters in static storage for common use\r\n -------------------------------------------------*/\r\n var temp = this.b / this.a;\r\n var es = 1.0 - Math.pow(temp, 2);\r\n var e = Math.sqrt(es);\r\n\r\n this.sin_p20 = Math.sin(this.lat0);\r\n this.cos_p20 = Math.cos(this.lat0);\r\n\r\n this.con = 1.0 - this.es * this.sin_p20 * this.sin_p20;\r\n this.com = Math.sqrt(1.0 - es);\r\n this.bl = Math.sqrt(\r\n 1.0 + (this.es * Math.pow(this.cos_p20, 4.0)) / (1.0 - es)\r\n );\r\n this.al = (this.a * this.bl * this.k0 * this.com) / this.con;\r\n if (Math.abs(this.lat0) < Proj4js.common.EPSLN) {\r\n this.ts = 1.0;\r\n this.d = 1.0;\r\n this.el = 1.0;\r\n }\n else {\r\n this.ts = Proj4js.common.tsfnz(this.e, this.lat0, this.sin_p20);\r\n this.con = Math.sqrt(this.con);\r\n this.d = (this.bl * this.com) / (this.cos_p20 * this.con);\r\n if (this.d * this.d - 1.0 > 0.0) {\r\n if (this.lat0 >= 0.0) {\r\n this.f = this.d + Math.sqrt(this.d * this.d - 1.0);\r\n }\n else {\r\n this.f = this.d - Math.sqrt(this.d * this.d - 1.0);\r\n }\r\n }\n else {\r\n this.f = this.d;\r\n }\r\n this.el = this.f * Math.pow(this.ts, this.bl);\r\n }\r\n\r\n //this.longc=52.60353916666667;\r\n\r\n if (this.mode != 0) {\r\n this.g = 0.5 * (this.f - 1.0 / this.f);\r\n this.gama = Proj4js.common.asinz(Math.sin(this.alpha) / this.d);\r\n this.longc =\r\n this.longc -\r\n Proj4js.common.asinz(this.g * Math.tan(this.gama)) / this.bl;\r\n\r\n /* Report parameters common to format B\r\n -------------------------------------*/\r\n //genrpt(azimuth * R2D,\"Azimuth of Central Line: \");\r\n //cenlon(lon_origin);\r\n // cenlat(lat_origin);\r\n\r\n this.con = Math.abs(this.lat0);\r\n if (\r\n this.con > Proj4js.common.EPSLN &&\r\n Math.abs(this.con - Proj4js.common.HALF_PI) > Proj4js.common.EPSLN\r\n ) {\r\n this.singam = Math.sin(this.gama);\r\n this.cosgam = Math.cos(this.gama);\r\n\r\n this.sinaz = Math.sin(this.alpha);\r\n this.cosaz = Math.cos(this.alpha);\r\n\r\n if (this.lat0 >= 0) {\r\n this.u =\r\n (this.al / this.bl) *\r\n Math.atan(Math.sqrt(this.d * this.d - 1.0) / this.cosaz);\r\n }\n else {\r\n this.u =\r\n -(this.al / this.bl) *\r\n Math.atan(Math.sqrt(this.d * this.d - 1.0) / this.cosaz);\r\n }\r\n }\n else {\r\n Proj4js.reportError(\"omerc:Init:DataError\");\r\n }\r\n }\n else {\r\n this.sinphi = Math.sin(this.at1);\r\n this.ts1 = Proj4js.common.tsfnz(this.e, this.lat1, this.sinphi);\r\n this.sinphi = Math.sin(this.lat2);\r\n this.ts2 = Proj4js.common.tsfnz(this.e, this.lat2, this.sinphi);\r\n this.h = Math.pow(this.ts1, this.bl);\r\n this.l = Math.pow(this.ts2, this.bl);\r\n this.f = this.el / this.h;\r\n this.g = 0.5 * (this.f - 1.0 / this.f);\r\n this.j =\r\n (this.el * this.el - this.l * this.h) /\r\n (this.el * this.el + this.l * this.h);\r\n this.p = (this.l - this.h) / (this.l + this.h);\r\n this.dlon = this.lon1 - this.lon2;\r\n if (this.dlon < -Proj4js.common.PI)\r\n this.lon2 = this.lon2 - 2.0 * Proj4js.common.PI;\r\n if (this.dlon > Proj4js.common.PI)\r\n this.lon2 = this.lon2 + 2.0 * Proj4js.common.PI;\r\n this.dlon = this.lon1 - this.lon2;\r\n this.longc =\r\n 0.5 * (this.lon1 + this.lon2) -\r\n Math.atan((this.j * Math.tan(0.5 * this.bl * this.dlon)) / this.p) /\r\n this.bl;\r\n this.dlon = Proj4js.common.adjust_lon(this.lon1 - this.longc);\r\n this.gama = Math.atan(Math.sin(this.bl * this.dlon) / this.g);\r\n this.alpha = Proj4js.common.asinz(this.d * Math.sin(this.gama));\r\n\r\n /* Report parameters common to format A\r\n -------------------------------------*/\r\n\r\n if (Math.abs(this.lat1 - this.lat2) <= Proj4js.common.EPSLN) {\r\n Proj4js.reportError(\"omercInitDataError\");\r\n //return(202);\r\n }\n else {\r\n this.con = Math.abs(this.lat1);\r\n }\r\n if (\r\n this.con <= Proj4js.common.EPSLN ||\r\n Math.abs(this.con - Proj4js.common.HALF_PI) <= Proj4js.common.EPSLN\r\n ) {\r\n Proj4js.reportError(\"omercInitDataError\");\r\n //return(202);\r\n }\n else {\r\n if (\r\n Math.abs(Math.abs(this.lat0) - Proj4js.common.HALF_PI) <=\r\n Proj4js.common.EPSLN\r\n ) {\r\n Proj4js.reportError(\"omercInitDataError\");\r\n //return(202);\r\n }\r\n }\r\n\r\n this.singam = Math.sin(this.gam);\r\n this.cosgam = Math.cos(this.gam);\r\n\r\n this.sinaz = Math.sin(this.alpha);\r\n this.cosaz = Math.cos(this.alpha);\r\n\r\n if (this.lat0 >= 0) {\r\n this.u =\r\n (this.al / this.bl) *\r\n Math.atan(Math.sqrt(this.d * this.d - 1.0) / this.cosaz);\r\n }\n else {\r\n this.u =\r\n -(this.al / this.bl) *\r\n Math.atan(Math.sqrt(this.d * this.d - 1.0) / this.cosaz);\r\n }\r\n }\r\n },\r\n\r\n /* Oblique Mercator forward equations--mapping lat,long to x,y\r\n ----------------------------------------------------------*/\r\n forward: function(p) {\r\n var theta; /* angle\t\t\t\t\t*/\r\n var sin_phi, cos_phi; /* sin and cos value\t\t\t\t*/\r\n var b; /* temporary values\t\t\t\t*/\r\n var c, t, tq; /* temporary values\t\t\t\t*/\r\n var con, n, ml; /* cone constant, small m\t\t\t*/\r\n var q, us, vl;\r\n var ul, vs;\r\n var s;\r\n var dlon;\r\n var ts1;\r\n\r\n var lon = p.x;\r\n var lat = p.y;\r\n /* Forward equations\r\n -----------------*/\r\n sin_phi = Math.sin(lat);\r\n dlon = Proj4js.common.adjust_lon(lon - this.longc);\r\n vl = Math.sin(this.bl * dlon);\r\n if (\r\n Math.abs(Math.abs(lat) - Proj4js.common.HALF_PI) > Proj4js.common.EPSLN\r\n ) {\r\n ts1 = Proj4js.common.tsfnz(this.e, lat, sin_phi);\r\n q = this.el / Math.pow(ts1, this.bl);\r\n s = 0.5 * (q - 1.0 / q);\r\n t = 0.5 * (q + 1.0 / q);\r\n ul = (s * this.singam - vl * this.cosgam) / t;\r\n con = Math.cos(this.bl * dlon);\r\n if (Math.abs(con) < 0.0000001) {\r\n us = this.al * this.bl * dlon;\r\n }\n else {\r\n us =\r\n (this.al * Math.atan((s * this.cosgam + vl * this.singam) / con)) /\r\n this.bl;\r\n if (con < 0) us = us + (Proj4js.common.PI * this.al) / this.bl;\r\n }\r\n }\n else {\r\n if (lat >= 0) {\r\n ul = this.singam;\r\n }\n else {\r\n ul = -this.singam;\r\n }\r\n us = (this.al * lat) / this.bl;\r\n }\r\n if (Math.abs(Math.abs(ul) - 1.0) <= Proj4js.common.EPSLN) {\r\n //alert(\"Point projects into infinity\",\"omer-for\");\r\n Proj4js.reportError(\"omercFwdInfinity\");\r\n //return(205);\r\n }\r\n vs = (0.5 * this.al * Math.log((1.0 - ul) / (1.0 + ul))) / this.bl;\r\n us = us - this.u;\r\n var x = this.x0 + vs * this.cosaz + us * this.sinaz;\r\n var y = this.y0 + us * this.cosaz - vs * this.sinaz;\r\n\r\n p.x = x;\r\n p.y = y;\r\n return p;\r\n },\r\n\r\n inverse: function(p) {\r\n var delta_lon; /* Delta longitude (Given longitude - center \t*/\r\n var theta; /* angle\t\t\t\t\t*/\r\n var delta_theta; /* adjusted longitude\t\t\t\t*/\r\n var sin_phi, cos_phi; /* sin and cos value\t\t\t\t*/\r\n var b; /* temporary values\t\t\t\t*/\r\n var c, t, tq; /* temporary values\t\t\t\t*/\r\n var con, n, ml; /* cone constant, small m\t\t\t*/\r\n var vs, us, q, s, ts1;\r\n var vl, ul, bs;\r\n var lon, lat;\r\n var flag;\r\n\r\n /* Inverse equations\r\n -----------------*/\r\n p.x -= this.x0;\r\n p.y -= this.y0;\r\n flag = 0;\r\n vs = p.x * this.cosaz - p.y * this.sinaz;\r\n us = p.y * this.cosaz + p.x * this.sinaz;\r\n us = us + this.u;\r\n q = Math.exp((-this.bl * vs) / this.al);\r\n s = 0.5 * (q - 1.0 / q);\r\n t = 0.5 * (q + 1.0 / q);\r\n vl = Math.sin((this.bl * us) / this.al);\r\n ul = (vl * this.cosgam + s * this.singam) / t;\r\n if (Math.abs(Math.abs(ul) - 1.0) <= Proj4js.common.EPSLN) {\r\n lon = this.longc;\r\n if (ul >= 0.0) {\r\n lat = Proj4js.common.HALF_PI;\r\n }\n else {\r\n lat = -Proj4js.common.HALF_PI;\r\n }\r\n }\n else {\r\n con = 1.0 / this.bl;\r\n ts1 = Math.pow(this.el / Math.sqrt((1.0 + ul) / (1.0 - ul)), con);\r\n lat = Proj4js.common.phi2z(this.e, ts1);\r\n //if (flag != 0)\r\n //return(flag);\r\n //~ con = Math.cos(this.bl * us /al);\r\n theta =\r\n this.longc -\r\n Math.atan2(s * this.cosgam - vl * this.singam, con) / this.bl;\r\n lon = Proj4js.common.adjust_lon(theta);\r\n }\r\n p.x = lon;\r\n p.y = lat;\r\n return p;\r\n }\r\n};\r\n/* ======================================================================\r\n projCode/lcc.js\r\n ====================================================================== */\r\n\r\n/*******************************************************************************\r\nNAME LAMBERT CONFORMAL CONIC\r\n\r\nPURPOSE:\tTransforms input longitude and latitude to Easting and\r\n\t\tNorthing for the Lambert Conformal Conic projection. The\r\n\t\tlongitude and latitude must be in radians. The Easting\r\n\t\tand Northing values will be returned in meters.\r\n\r\n\r\nALGORITHM REFERENCES\r\n\r\n1. Snyder, John P., \"Map Projections--A Working Manual\", U.S. Geological\r\n Survey Professional Paper 1395 (Supersedes USGS Bulletin 1532), United\r\n State Government Printing Office, Washington D.C., 1987.\r\n\r\n2. Snyder, John P. and Voxland, Philip M., \"An Album of Map Projections\",\r\n U.S. Geological Survey Professional Paper 1453 , United State Government\r\n*******************************************************************************/\r\n\r\n//<2104> +proj=lcc +lat_1=10.16666666666667 +lat_0=10.16666666666667 +lon_0=-71.60561777777777 +k_0=1 +x0=-17044 +x0=-23139.97 +ellps=intl +units=m +no_defs no_defs\r\n\r\n// Initialize the Lambert Conformal conic projection\r\n// -----------------------------------------------------------------\r\n\r\n//Proj4js.Proj.lcc = Class.create();\r\nProj4js.Proj.lcc = {\r\n init: function() {\r\n // array of: r_maj,r_min,lat1,lat2,c_lon,c_lat,false_east,false_north\r\n //double c_lat; /* center latitude */\r\n //double c_lon; /* center longitude */\r\n //double lat1; /* first standard parallel */\r\n //double lat2; /* second standard parallel */\r\n //double r_maj; /* major axis */\r\n //double r_min; /* minor axis */\r\n //double false_east; /* x offset in meters */\r\n //double false_north; /* y offset in meters */\r\n\r\n if (!this.lat2) {\r\n this.lat2 = this.lat0;\r\n } //if lat2 is not defined\r\n if (!this.k0) this.k0 = 1.0;\r\n\r\n // Standard Parallels cannot be equal and on opposite sides of the equator\r\n if (Math.abs(this.lat1 + this.lat2) < Proj4js.common.EPSLN) {\r\n Proj4js.reportError(\"lcc:init: Equal Latitudes\");\r\n return;\r\n }\r\n\r\n var temp = this.b / this.a;\r\n this.e = Math.sqrt(1.0 - temp * temp);\r\n\r\n var sin1 = Math.sin(this.lat1);\r\n var cos1 = Math.cos(this.lat1);\r\n var ms1 = Proj4js.common.msfnz(this.e, sin1, cos1);\r\n var ts1 = Proj4js.common.tsfnz(this.e, this.lat1, sin1);\r\n\r\n var sin2 = Math.sin(this.lat2);\r\n var cos2 = Math.cos(this.lat2);\r\n var ms2 = Proj4js.common.msfnz(this.e, sin2, cos2);\r\n var ts2 = Proj4js.common.tsfnz(this.e, this.lat2, sin2);\r\n\r\n var ts0 = Proj4js.common.tsfnz(this.e, this.lat0, Math.sin(this.lat0));\r\n\r\n if (Math.abs(this.lat1 - this.lat2) > Proj4js.common.EPSLN) {\r\n this.ns = Math.log(ms1 / ms2) / Math.log(ts1 / ts2);\r\n }\n else {\r\n this.ns = sin1;\r\n }\r\n this.f0 = ms1 / (this.ns * Math.pow(ts1, this.ns));\r\n this.rh = this.a * this.f0 * Math.pow(ts0, this.ns);\r\n if (!this.title) this.title = \"Lambert Conformal Conic\";\r\n },\r\n\r\n // Lambert Conformal conic forward equations--mapping lat,long to x,y\r\n // -----------------------------------------------------------------\r\n forward: function(p) {\r\n var lon = p.x;\r\n var lat = p.y;\r\n\r\n // convert to radians\r\n if (lat <= 90.0 && lat >= -90.0 && lon <= 180.0 && lon >= -180.0) {\r\n //lon = lon * Proj4js.common.D2R;\r\n //lat = lat * Proj4js.common.D2R;\r\n }\n else {\r\n Proj4js.reportError(\r\n \"lcc:forward: llInputOutOfRange: \" + lon + \" : \" + lat\r\n );\r\n return null;\r\n }\r\n\r\n var con = Math.abs(Math.abs(lat) - Proj4js.common.HALF_PI);\r\n var ts, rh1;\r\n if (con > Proj4js.common.EPSLN) {\r\n ts = Proj4js.common.tsfnz(this.e, lat, Math.sin(lat));\r\n rh1 = this.a * this.f0 * Math.pow(ts, this.ns);\r\n }\n else {\r\n con = lat * this.ns;\r\n if (con <= 0) {\r\n Proj4js.reportError(\"lcc:forward: No Projection\");\r\n return null;\r\n }\r\n rh1 = 0;\r\n }\r\n var theta = this.ns * Proj4js.common.adjust_lon(lon - this.long0);\r\n p.x = this.k0 * (rh1 * Math.sin(theta)) + this.x0;\r\n p.y = this.k0 * (this.rh - rh1 * Math.cos(theta)) + this.y0;\r\n\r\n return p;\r\n },\r\n\r\n // Lambert Conformal Conic inverse equations--mapping x,y to lat/long\r\n // -----------------------------------------------------------------\r\n inverse: function(p) {\r\n var rh1, con, ts;\r\n var lat, lon;\r\n var x = (p.x - this.x0) / this.k0;\r\n var y = this.rh - (p.y - this.y0) / this.k0;\r\n if (this.ns > 0) {\r\n rh1 = Math.sqrt(x * x + y * y);\r\n con = 1.0;\r\n }\n else {\r\n rh1 = -Math.sqrt(x * x + y * y);\r\n con = -1.0;\r\n }\r\n var theta = 0.0;\r\n if (rh1 != 0) {\r\n theta = Math.atan2(con * x, con * y);\r\n }\r\n if (rh1 != 0 || this.ns > 0.0) {\r\n con = 1.0 / this.ns;\r\n ts = Math.pow(rh1 / (this.a * this.f0), con);\r\n lat = Proj4js.common.phi2z(this.e, ts);\r\n if (lat == -9999) return null;\r\n }\n else {\r\n lat = -Proj4js.common.HALF_PI;\r\n }\r\n lon = Proj4js.common.adjust_lon(theta / this.ns + this.long0);\r\n\r\n p.x = lon;\r\n p.y = lat;\r\n return p;\r\n }\r\n};\r\n\r\n/* ======================================================================\r\n projCode/laea.js\r\n ====================================================================== */\r\n\r\n/*******************************************************************************\r\nNAME LAMBERT AZIMUTHAL EQUAL-AREA\r\n \r\nPURPOSE:\tTransforms input longitude and latitude to Easting and\r\n\t\tNorthing for the Lambert Azimuthal Equal-Area projection. The\r\n\t\tlongitude and latitude must be in radians. The Easting\r\n\t\tand Northing values will be returned in meters.\r\n\r\nPROGRAMMER DATE \r\n---------- ---- \r\nD. Steinwand, EROS March, 1991 \r\n\r\nThis function was adapted from the Lambert Azimuthal Equal Area projection\r\ncode (FORTRAN) in the General Cartographic Transformation Package software\r\nwhich is available from the U.S. Geological Survey National Mapping Division.\r\n \r\nALGORITHM REFERENCES\r\n\r\n1. \"New Equal-Area Map Projections for Noncircular Regions\", John P. Snyder,\r\n The American Cartographer, Vol 15, No. 4, October 1988, pp. 341-355.\r\n\r\n2. Snyder, John P., \"Map Projections--A Working Manual\", U.S. Geological\r\n Survey Professional Paper 1395 (Supersedes USGS Bulletin 1532), United\r\n State Government Printing Office, Washington D.C., 1987.\r\n\r\n3. \"Software Documentation for GCTP General Cartographic Transformation\r\n Package\", U.S. Geological Survey National Mapping Division, May 1982.\r\n*******************************************************************************/\r\n\r\nProj4js.Proj.laea = {\r\n S_POLE: 1,\r\n N_POLE: 2,\r\n EQUIT: 3,\r\n OBLIQ: 4,\r\n\r\n /* Initialize the Lambert Azimuthal Equal Area projection\r\n ------------------------------------------------------*/\r\n init: function() {\r\n var t = Math.abs(this.lat0);\r\n if (Math.abs(t - Proj4js.common.HALF_PI) < Proj4js.common.EPSLN) {\r\n this.mode = this.lat0 < 0 ? this.S_POLE : this.N_POLE;\r\n }\n else if (Math.abs(t) < Proj4js.common.EPSLN) {\r\n this.mode = this.EQUIT;\r\n }\n else {\r\n this.mode = this.OBLIQ;\r\n }\r\n if (this.es > 0) {\r\n var sinphi;\r\n\r\n this.qp = Proj4js.common.qsfnz(this.e, 1.0);\r\n this.mmf = 0.5 / (1 - this.es);\r\n this.apa = this.authset(this.es);\r\n switch (this.mode) {\r\n case this.N_POLE:\r\n case this.S_POLE:\r\n this.dd = 1;\r\n break;\r\n case this.EQUIT:\r\n this.rq = Math.sqrt(0.5 * this.qp);\r\n this.dd = 1 / this.rq;\r\n this.xmf = 1;\r\n this.ymf = 0.5 * this.qp;\r\n break;\r\n case this.OBLIQ:\r\n this.rq = Math.sqrt(0.5 * this.qp);\r\n sinphi = Math.sin(this.lat0);\r\n this.sinb1 = Proj4js.common.qsfnz(this.e, sinphi) / this.qp;\r\n this.cosb1 = Math.sqrt(1 - this.sinb1 * this.sinb1);\r\n this.dd =\r\n Math.cos(this.lat0) /\r\n (Math.sqrt(1 - this.es * sinphi * sinphi) * this.rq * this.cosb1);\r\n this.ymf = (this.xmf = this.rq) / this.dd;\r\n this.xmf *= this.dd;\r\n break;\r\n }\r\n }\n else {\r\n if (this.mode == this.OBLIQ) {\r\n this.sinph0 = Math.sin(this.lat0);\r\n this.cosph0 = Math.cos(this.lat0);\r\n }\r\n }\r\n },\r\n\r\n /* Lambert Azimuthal Equal Area forward equations--mapping lat,long to x,y\r\n -----------------------------------------------------------------------*/\r\n forward: function(p) {\r\n /* Forward equations\r\n -----------------*/\r\n var x, y;\r\n var lam = p.x;\r\n var phi = p.y;\r\n lam = Proj4js.common.adjust_lon(lam - this.long0);\r\n\r\n if (this.sphere) {\r\n var coslam, cosphi, sinphi;\r\n\r\n sinphi = Math.sin(phi);\r\n cosphi = Math.cos(phi);\r\n coslam = Math.cos(lam);\r\n switch (this.mode) {\r\n case this.OBLIQ:\r\n case this.EQUIT:\r\n y =\r\n this.mode == this.EQUIT\r\n ? 1 + cosphi * coslam\r\n : 1 + this.sinph0 * sinphi + this.cosph0 * cosphi * coslam;\r\n if (y <= Proj4js.common.EPSLN) {\r\n Proj4js.reportError(\"laea:fwd:y less than eps\");\r\n return null;\r\n }\r\n y = Math.sqrt(2 / y);\r\n x = y * cosphi * Math.sin(lam);\r\n y *=\r\n this.mode == this.EQUIT\r\n ? sinphi\r\n : this.cosph0 * sinphi - this.sinph0 * cosphi * coslam;\r\n break;\r\n case this.N_POLE:\r\n coslam = -coslam;\r\n case this.S_POLE:\r\n if (Math.abs(phi + this.phi0) < Proj4js.common.EPSLN) {\r\n Proj4js.reportError(\"laea:fwd:phi < eps\");\r\n return null;\r\n }\r\n y = Proj4js.common.FORTPI - phi * 0.5;\r\n y = 2 * (this.mode == this.S_POLE ? Math.cos(y) : Math.sin(y));\r\n x = y * Math.sin(lam);\r\n y *= coslam;\r\n break;\r\n }\r\n }\n else {\r\n var coslam,\r\n sinlam,\r\n sinphi,\r\n q,\r\n sinb = 0.0,\r\n cosb = 0.0,\r\n b = 0.0;\r\n\r\n coslam = Math.cos(lam);\r\n sinlam = Math.sin(lam);\r\n sinphi = Math.sin(phi);\r\n q = Proj4js.common.qsfnz(this.e, sinphi);\r\n if (this.mode == this.OBLIQ || this.mode == this.EQUIT) {\r\n sinb = q / this.qp;\r\n cosb = Math.sqrt(1 - sinb * sinb);\r\n }\r\n switch (this.mode) {\r\n case this.OBLIQ:\r\n b = 1 + this.sinb1 * sinb + this.cosb1 * cosb * coslam;\r\n break;\r\n case this.EQUIT:\r\n b = 1 + cosb * coslam;\r\n break;\r\n case this.N_POLE:\r\n b = Proj4js.common.HALF_PI + phi;\r\n q = this.qp - q;\r\n break;\r\n case this.S_POLE:\r\n b = phi - Proj4js.common.HALF_PI;\r\n q = this.qp + q;\r\n break;\r\n }\r\n if (Math.abs(b) < Proj4js.common.EPSLN) {\r\n Proj4js.reportError(\"laea:fwd:b < eps\");\r\n return null;\r\n }\r\n switch (this.mode) {\r\n case this.OBLIQ:\r\n case this.EQUIT:\r\n b = Math.sqrt(2 / b);\r\n if (this.mode == this.OBLIQ) {\r\n y = this.ymf * b * (this.cosb1 * sinb - this.sinb1 * cosb * coslam);\r\n }\n else {\r\n y = (b = Math.sqrt(2 / (1 + cosb * coslam))) * sinb * this.ymf;\r\n }\r\n x = this.xmf * b * cosb * sinlam;\r\n break;\r\n case this.N_POLE:\r\n case this.S_POLE:\r\n if (q >= 0) {\r\n x = (b = Math.sqrt(q)) * sinlam;\r\n y = coslam * (this.mode == this.S_POLE ? b : -b);\r\n }\n else {\r\n x = y = 0;\r\n }\r\n break;\r\n }\r\n }\r\n\r\n //v 1.0\r\n /*\r\n var sin_lat=Math.sin(lat);\r\n var cos_lat=Math.cos(lat);\r\n\r\n var sin_delta_lon=Math.sin(delta_lon);\r\n var cos_delta_lon=Math.cos(delta_lon);\r\n\r\n var g =this.sin_lat_o * sin_lat +this.cos_lat_o * cos_lat * cos_delta_lon;\r\n if (g == -1.0) {\r\n Proj4js.reportError(\"laea:fwd:Point projects to a circle of radius \"+ 2.0 * R);\r\n return null;\r\n }\r\n var ksp = this.a * Math.sqrt(2.0 / (1.0 + g));\r\n var x = ksp * cos_lat * sin_delta_lon + this.x0;\r\n var y = ksp * (this.cos_lat_o * sin_lat - this.sin_lat_o * cos_lat * cos_delta_lon) + this.y0;\r\n */\r\n p.x = this.a * x + this.x0;\r\n p.y = this.a * y + this.y0;\r\n return p;\r\n }, //lamazFwd()\r\n\r\n /* Inverse equations\r\n -----------------*/\r\n inverse: function(p) {\r\n p.x -= this.x0;\r\n p.y -= this.y0;\r\n var x = p.x / this.a;\r\n var y = p.y / this.a;\r\n var lam, phi;\r\n\r\n if (this.sphere) {\r\n var cosz = 0.0,\r\n rh,\r\n sinz = 0.0;\r\n\r\n rh = Math.sqrt(x * x + y * y);\r\n phi = rh * 0.5;\r\n if (phi > 1) {\r\n Proj4js.reportError(\"laea:Inv:DataError\");\r\n return null;\r\n }\r\n phi = 2 * Math.asin(phi);\r\n if (this.mode == this.OBLIQ || this.mode == this.EQUIT) {\r\n sinz = Math.sin(phi);\r\n cosz = Math.cos(phi);\r\n }\r\n switch (this.mode) {\r\n case this.EQUIT:\r\n phi =\r\n Math.abs(rh) <= Proj4js.common.EPSLN\r\n ? 0\r\n : Math.asin((y * sinz) / rh);\r\n x *= sinz;\r\n y = cosz * rh;\r\n break;\r\n case this.OBLIQ:\r\n phi =\r\n Math.abs(rh) <= Proj4js.common.EPSLN\r\n ? this.phi0\r\n : Math.asin(cosz * this.sinph0 + (y * sinz * this.cosph0) / rh);\r\n x *= sinz * this.cosph0;\r\n y = (cosz - Math.sin(phi) * this.sinph0) * rh;\r\n break;\r\n case this.N_POLE:\r\n y = -y;\r\n phi = Proj4js.common.HALF_PI - phi;\r\n break;\r\n case this.S_POLE:\r\n phi -= Proj4js.common.HALF_PI;\r\n break;\r\n }\r\n lam =\r\n y == 0 && (this.mode == this.EQUIT || this.mode == this.OBLIQ)\r\n ? 0\r\n : Math.atan2(x, y);\r\n }\n else {\r\n var cCe,\r\n sCe,\r\n q,\r\n rho,\r\n ab = 0.0;\r\n\r\n switch (this.mode) {\r\n case this.EQUIT:\r\n case this.OBLIQ:\r\n x /= this.dd;\r\n y *= this.dd;\r\n rho = Math.sqrt(x * x + y * y);\r\n if (rho < Proj4js.common.EPSLN) {\r\n p.x = 0;\r\n p.y = this.phi0;\r\n return p;\r\n }\r\n sCe = 2 * Math.asin((0.5 * rho) / this.rq);\r\n cCe = Math.cos(sCe);\r\n x *= sCe = Math.sin(sCe);\r\n if (this.mode == this.OBLIQ) {\r\n ab = cCe * this.sinb1 + (y * sCe * this.cosb1) / rho;\r\n q = this.qp * ab;\r\n y = rho * this.cosb1 * cCe - y * this.sinb1 * sCe;\r\n }\n else {\r\n ab = (y * sCe) / rho;\r\n q = this.qp * ab;\r\n y = rho * cCe;\r\n }\r\n break;\r\n case this.N_POLE:\r\n y = -y;\r\n case this.S_POLE:\r\n q = x * x + y * y;\r\n if (!q) {\r\n p.x = 0;\r\n p.y = this.phi0;\r\n return p;\r\n }\r\n /*\r\n q = this.qp - q;\r\n */\r\n ab = 1 - q / this.qp;\r\n if (this.mode == this.S_POLE) {\r\n ab = -ab;\r\n }\r\n break;\r\n }\r\n lam = Math.atan2(x, y);\r\n phi = this.authlat(Math.asin(ab), this.apa);\r\n }\r\n\r\n /*\r\n var Rh = Math.Math.sqrt(p.x *p.x +p.y * p.y);\r\n var temp = Rh / (2.0 * this.a);\r\n\r\n if (temp > 1) {\r\n Proj4js.reportError(\"laea:Inv:DataError\");\r\n return null;\r\n }\r\n\r\n var z = 2.0 * Proj4js.common.asinz(temp);\r\n var sin_z=Math.sin(z);\r\n var cos_z=Math.cos(z);\r\n\r\n var lon =this.long0;\r\n if (Math.abs(Rh) > Proj4js.common.EPSLN) {\r\n var lat = Proj4js.common.asinz(this.sin_lat_o * cos_z +this. cos_lat_o * sin_z *p.y / Rh);\r\n var temp =Math.abs(this.lat0) - Proj4js.common.HALF_PI;\r\n if (Math.abs(temp) > Proj4js.common.EPSLN) {\r\n temp = cos_z -this.sin_lat_o * Math.sin(lat);\r\n if(temp!=0.0) lon=Proj4js.common.adjust_lon(this.long0+Math.atan2(p.x*sin_z*this.cos_lat_o,temp*Rh));\r\n } else if (this.lat0 < 0.0) {\r\n lon = Proj4js.common.adjust_lon(this.long0 - Math.atan2(-p.x,p.y));\r\n } else {\r\n lon = Proj4js.common.adjust_lon(this.long0 + Math.atan2(p.x, -p.y));\r\n }\r\n } else {\r\n lat = this.lat0;\r\n }\r\n */\r\n //return(OK);\r\n p.x = Proj4js.common.adjust_lon(this.long0 + lam);\r\n p.y = phi;\r\n return p;\r\n }, //lamazInv()\r\n\r\n /* determine latitude from authalic latitude */\r\n P00: 0.33333333333333333333,\r\n P01: 0.17222222222222222222,\r\n P02: 0.10257936507936507936,\r\n P10: 0.06388888888888888888,\r\n P11: 0.06640211640211640211,\r\n P20: 0.01641501294219154443,\r\n\r\n authset: function(es) {\r\n var t;\r\n var APA = new Array();\r\n APA[0] = es * this.P00;\r\n t = es * es;\r\n APA[0] += t * this.P01;\r\n APA[1] = t * this.P10;\r\n t *= es;\r\n APA[0] += t * this.P02;\r\n APA[1] += t * this.P11;\r\n APA[2] = t * this.P20;\r\n return APA;\r\n },\r\n\r\n authlat: function(beta, APA) {\r\n var t = beta + beta;\r\n return (\r\n beta +\r\n APA[0] * Math.sin(t) +\r\n APA[1] * Math.sin(t + t) +\r\n APA[2] * Math.sin(t + t + t)\r\n );\r\n }\r\n};\r\n\r\n/* ======================================================================\r\n projCode/aeqd.js\r\n ====================================================================== */\r\n\r\nProj4js.Proj.aeqd = {\r\n init: function() {\r\n this.sin_p12 = Math.sin(this.lat0);\r\n this.cos_p12 = Math.cos(this.lat0);\r\n },\r\n\r\n forward: function(p) {\r\n var lon = p.x;\r\n var lat = p.y;\r\n var ksp;\r\n\r\n var sinphi = Math.sin(p.y);\r\n var cosphi = Math.cos(p.y);\r\n var dlon = Proj4js.common.adjust_lon(lon - this.long0);\r\n var coslon = Math.cos(dlon);\r\n var g = this.sin_p12 * sinphi + this.cos_p12 * cosphi * coslon;\r\n if (Math.abs(Math.abs(g) - 1.0) < Proj4js.common.EPSLN) {\r\n ksp = 1.0;\r\n if (g < 0.0) {\r\n Proj4js.reportError(\"aeqd:Fwd:PointError\");\r\n return;\r\n }\r\n }\n else {\r\n var z = Math.acos(g);\r\n ksp = z / Math.sin(z);\r\n }\r\n p.x = this.x0 + this.a * ksp * cosphi * Math.sin(dlon);\r\n p.y =\r\n this.y0 +\r\n this.a * ksp * (this.cos_p12 * sinphi - this.sin_p12 * cosphi * coslon);\r\n return p;\r\n },\r\n\r\n inverse: function(p) {\r\n p.x -= this.x0;\r\n p.y -= this.y0;\r\n\r\n var rh = Math.sqrt(p.x * p.x + p.y * p.y);\r\n if (rh > 2.0 * Proj4js.common.HALF_PI * this.a) {\r\n Proj4js.reportError(\"aeqdInvDataError\");\r\n return;\r\n }\r\n var z = rh / this.a;\r\n\r\n var sinz = Math.sin(z);\r\n var cosz = Math.cos(z);\r\n\r\n var lon = this.long0;\r\n var lat;\r\n if (Math.abs(rh) <= Proj4js.common.EPSLN) {\r\n lat = this.lat0;\r\n }\n else {\r\n lat = Proj4js.common.asinz(\r\n cosz * this.sin_p12 + (p.y * sinz * this.cos_p12) / rh\r\n );\r\n var con = Math.abs(this.lat0) - Proj4js.common.HALF_PI;\r\n if (Math.abs(con) <= Proj4js.common.EPSLN) {\r\n if (this.lat0 >= 0.0) {\r\n lon = Proj4js.common.adjust_lon(this.long0 + Math.atan2(p.x, -p.y));\r\n }\n else {\r\n lon = Proj4js.common.adjust_lon(this.long0 - Math.atan2(-p.x, p.y));\r\n }\r\n }\n else {\r\n con = cosz - this.sin_p12 * Math.sin(lat);\r\n if (\r\n Math.abs(con) < Proj4js.common.EPSLN &&\r\n Math.abs(p.x) < Proj4js.common.EPSLN\r\n ) {\r\n //no-op, just keep the lon value as is\r\n }\n else {\r\n var temp = Math.atan2(p.x * sinz * this.cos_p12, con * rh);\r\n lon = Proj4js.common.adjust_lon(\r\n this.long0 + Math.atan2(p.x * sinz * this.cos_p12, con * rh)\r\n );\r\n }\r\n }\r\n }\r\n\r\n p.x = lon;\r\n p.y = lat;\r\n return p;\r\n }\r\n};\r\n/* ======================================================================\r\n projCode/moll.js\r\n ====================================================================== */\r\n\r\n/*******************************************************************************\r\nNAME MOLLWEIDE\r\n\r\nPURPOSE:\tTransforms input longitude and latitude to Easting and\r\n\t\tNorthing for the MOllweide projection. The\r\n\t\tlongitude and latitude must be in radians. The Easting\r\n\t\tand Northing values will be returned in meters.\r\n\r\nPROGRAMMER DATE\r\n---------- ----\r\nD. Steinwand, EROS May, 1991; Updated Sept, 1992; Updated Feb, 1993\r\nS. Nelson, EDC\t\tJun, 2993;\tMade corrections in precision and\r\n\t\t\t\t\tnumber of iterations.\r\n\r\nALGORITHM REFERENCES\r\n\r\n1. Snyder, John P. and Voxland, Philip M., \"An Album of Map Projections\",\r\n U.S. Geological Survey Professional Paper 1453 , United State Government\r\n Printing Office, Washington D.C., 1989.\r\n\r\n2. Snyder, John P., \"Map Projections--A Working Manual\", U.S. Geological\r\n Survey Professional Paper 1395 (Supersedes USGS Bulletin 1532), United\r\n State Government Printing Office, Washington D.C., 1987.\r\n*******************************************************************************/\r\n\r\nProj4js.Proj.moll = {\r\n /* Initialize the Mollweide projection\r\n ------------------------------------*/\r\n init: function() {\r\n //no-op\r\n },\r\n\r\n /* Mollweide forward equations--mapping lat,long to x,y\r\n ----------------------------------------------------*/\r\n forward: function(p) {\r\n /* Forward equations\r\n -----------------*/\r\n var lon = p.x;\r\n var lat = p.y;\r\n\r\n var delta_lon = Proj4js.common.adjust_lon(lon - this.long0);\r\n var theta = lat;\r\n var con = Proj4js.common.PI * Math.sin(lat);\r\n\r\n /* Iterate using the Newton-Raphson method to find theta\r\n -----------------------------------------------------*/\r\n for (var i = 0; true; i++) {\r\n var delta_theta =\r\n -(theta + Math.sin(theta) - con) / (1.0 + Math.cos(theta));\r\n theta += delta_theta;\r\n if (Math.abs(delta_theta) < Proj4js.common.EPSLN) break;\r\n if (i >= 50) {\r\n Proj4js.reportError(\"moll:Fwd:IterationError\");\r\n //return(241);\r\n }\r\n }\r\n theta /= 2.0;\r\n\r\n /* If the latitude is 90 deg, force the x coordinate to be \"0 + false easting\"\r\n this is done here because of precision problems with \"cos(theta)\"\r\n --------------------------------------------------------------------------*/\r\n if (Proj4js.common.PI / 2 - Math.abs(lat) < Proj4js.common.EPSLN)\r\n delta_lon = 0;\r\n var x = 0.900316316158 * this.a * delta_lon * Math.cos(theta) + this.x0;\r\n var y = 1.4142135623731 * this.a * Math.sin(theta) + this.y0;\r\n\r\n p.x = x;\r\n p.y = y;\r\n return p;\r\n },\r\n\r\n inverse: function(p) {\r\n var theta;\r\n var arg;\r\n\r\n /* Inverse equations\r\n -----------------*/\r\n p.x -= this.x0;\r\n //~ p.y -= this.y0;\r\n var arg = p.y / (1.4142135623731 * this.a);\r\n\r\n /* Because of division by zero problems, 'arg' can not be 1.0. Therefore\r\n a number very close to one is used instead.\r\n -------------------------------------------------------------------*/\r\n if (Math.abs(arg) > 0.999999999999) arg = 0.999999999999;\r\n var theta = Math.asin(arg);\r\n var lon = Proj4js.common.adjust_lon(\r\n this.long0 + p.x / (0.900316316158 * this.a * Math.cos(theta))\r\n );\r\n if (lon < -Proj4js.common.PI) lon = -Proj4js.common.PI;\r\n if (lon > Proj4js.common.PI) lon = Proj4js.common.PI;\r\n arg = (2.0 * theta + Math.sin(2.0 * theta)) / Proj4js.common.PI;\r\n if (Math.abs(arg) > 1.0) arg = 1.0;\r\n var lat = Math.asin(arg);\r\n //return(OK);\r\n\r\n p.x = lon;\r\n p.y = lat;\r\n return p;\r\n }\r\n};\r\n","(function($, _, Highcharts) {\r\n var ns = window.nspace(\"ccc.viz.map.views\");\r\n\r\n // Clever way to tell if we are sorting by a number.\r\n // From here: http://stackoverflow.com/questions/18082/validate-numbers-in-javascript-isnumeric/1830844#1830844\r\n function isNumber(n) {\r\n return !isNaN(parseFloat(n)) && isFinite(n);\r\n }\r\n\r\n /**\r\n * Displays the \"region summary\" view on the right hand side of the map that\r\n * shows which location is selected, it's rank, and a trend chart.\r\n */\r\n ns.SelectedRegionSummaryView = Backbone.View.extend({\r\n el: \"#selected-region-summary-container\",\r\n templateSelector: \"#selected-region-summary-template\",\r\n name: \"SelectedRegionSummaryView\",\r\n sparklineContainerId: \"chart-container\",\r\n\r\n initialize: function(options) {\r\n this.initialRenderPromise = $.Deferred();\r\n this.chartAnimationComplete = $.Deferred();\r\n\r\n _.bindAll(\r\n this,\r\n \"render\",\r\n \"initialRender\",\r\n \"loadTemplate\",\r\n \"getCurrentFips\",\r\n );\r\n\r\n this.dataResponseModel = options.dataResponseModel;\r\n\r\n this.model.on(\"change\", _.debounce(this.render, 200));\r\n },\r\n\r\n getInitialRenderPromise: function() {\r\n return this.initialRenderPromise;\r\n },\r\n\r\n loadTemplate: function() {\r\n // Get the underscore template\r\n if (!this.template) {\r\n var $tmpl = $(this.templateSelector);\r\n if ($tmpl.length === 0) {\r\n throw \"Could not find the \" +\r\n this.name +\r\n \" template: \" +\r\n this.templateSelector;\r\n }\r\n\r\n // Pre-compile and cache the template\r\n this.template = _.template($tmpl.html());\r\n }\r\n },\r\n\r\n initialRender: function() {\r\n this.loadTemplate();\r\n\r\n var html = this.template({\r\n sparklineContainerId: this.sparklineContainerId,\r\n });\r\n this.$el.html(html);\r\n\r\n // Save off references to the portions of the DOM that will\r\n // be updated as data changes\r\n this.$name = $(\"[data-name]\", this.el);\r\n this.$dataSummary = $(\"[data-summary]\", this.el);\r\n this.$rank = $(\"[data-rank] .rank\", this.el);\r\n this.$rankSubtext = $(\"[data-rank] .subtext\", this.el);\r\n this.$trendContainer = $(\".legend-chart\", this.el);\r\n },\r\n\r\n renderChart: function(xAxisCategories, dataSeries, displayValues) {\r\n var self = this;\r\n\r\n if (dataSeries.length > 1) {\r\n $(\"#\" + self.sparklineContainerId).show();\r\n\r\n ccc.viz.map.util.ChartRenderer.renderSparkline(\r\n self.sparklineContainerId,\r\n xAxisCategories,\r\n dataSeries,\r\n displayValues,\r\n function() {\r\n self.chartAnimationComplete.resolve();\r\n },\r\n );\r\n }\r\n else {\r\n $(\"#\" + self.sparklineContainerId).hide();\r\n\r\n // Resolve the animation promise, since we don't have to wait for an animation to complete\r\n self.chartAnimationComplete.resolve();\r\n }\r\n },\r\n\r\n updateChart: function(data, timeFramesById) {\r\n var xAxis = [];\r\n var dataSeries = [];\r\n var displayValues = {};\r\n\r\n // Assemble the updated data series\r\n _.each(data, function(dataInfo) {\r\n var tfName = timeFramesById[dataInfo.timeFrameId].name;\r\n xAxis.push(tfName);\r\n if (isNumber(dataInfo.value)) {\r\n dataSeries.push(parseFloat(dataInfo.value));\r\n }\r\n else {\r\n dataSeries.push(null);\r\n }\r\n displayValues[tfName] = dataInfo.displayValue;\r\n });\r\n\r\n this.$chart = this.renderChart(xAxis, dataSeries, displayValues);\r\n },\r\n\r\n getCurrentFips: function() {\r\n return this.model.get(\"selectedFips\");\r\n },\r\n\r\n /**\r\n * Renders the summary area\r\n */\r\n render: function() {\r\n var self = this;\r\n\r\n if (!this.isRendered) {\r\n this.initialRender();\r\n this.isRendered = true;\r\n }\r\n\r\n var fips = this.getCurrentFips();\r\n\r\n // If there's no selected fips, hide the current view\r\n if (!fips || fips === \"a\") {\r\n self.$el.hide();\r\n self.initialRenderPromise.resolve();\r\n return;\r\n }\r\n\r\n // Get the data to display\r\n $.when(this.dataResponseModel.getDataResponse()).done(function() {\r\n // We have a fips. Ensure we're visible\r\n if (!self.$el.is(\":visible\")) {\r\n self.$el.fadeIn();\r\n }\r\n\r\n // Extract the data we need\r\n var response = self.dataResponseModel.get(\"response\");\r\n if (!response) {\r\n self.$el.hide();\r\n return;\r\n }\r\n\r\n var tfId = self.model.get(\"timeFrameId\");\r\n var allYearsData = response.dataByFips[fips];\r\n var data = !allYearsData\r\n ? null\r\n : _.find(allYearsData, function(yearData) {\r\n return yearData.timeFrameId === tfId;\r\n });\r\n\r\n var location = response.locationsByFips[fips];\r\n\r\n // Defaults\r\n var displayVals = {\r\n locationName: \"Location\",\r\n rank: \"\",\r\n rankSubtext: \"\",\r\n };\r\n\r\n // Record items we want to animate\r\n var fadeables = [];\r\n\r\n\r\n // data summary\r\n // Pull it from the global selector instance.\r\n var summary = ccc.viz.map.views.instances.SelectorsView.getDataSummaryByPropertyNames([\"indicatorId\"]);\r\n if (_.str.isBlank(summary)) {\r\n summary = response.indicatorGroupName;\r\n }\r\n\r\n // Actual values\r\n if (location) {\r\n displayVals.locationName = location.name;\r\n fadeables.push(self.$name[0]);\r\n \r\n if (location.isUninhabited) {\r\n summary = \"This area is uninhabited\";\r\n }\r\n }\r\n\r\n if (data) {\r\n displayVals.rank = _.str.isBlank(data.rank)\r\n ? data.displayValue\r\n : \"Ranks \" + data.rank;\r\n fadeables.push(self.$rank[0]);\r\n\r\n displayVals.rankSubtext = response.rankSubtext;\r\n if (_.str.isBlank(displayVals.rankSubtext)) {\r\n displayVals.rankSubtext =\r\n \"in \" + response.timeFramesById[tfId].name;\r\n }\r\n }\r\n\r\n // Hook for subclasses to modify display values\r\n if (self.overrideDisplayValues) {\r\n self.overrideDisplayValues(displayVals);\r\n }\r\n\r\n // Update the name\r\n self.$name.text(displayVals.locationName);\r\n\r\n self.$dataSummary.text(summary);\r\n\r\n // rank\r\n self.$rank.text(displayVals.rank);\r\n\r\n // rank subtext\r\n if (_.str.isBlank(displayVals.rankSubtext)) {\r\n self.$rankSubtext.hide();\r\n }\r\n else {\r\n if (\r\n self.$rankSubtext.text() !== displayVals.rankSubtext ||\r\n !self.$rankSubtext.is(\":visible\")\r\n ) {\r\n fadeables.push(self.$rankSubtext[0]);\r\n }\r\n\r\n self.$rankSubtext.text(displayVals.rankSubtext);\r\n }\r\n \r\n function StringArrayHasDuplicates (array) {\r\n return (new Set(array)).size !== array.length;\r\n }\r\n\r\n if (allYearsData) {\r\n // Trend chart is intended to show data for multiple years, one value per year\r\n // Validate that there is more than one timeframe to show a trend for\r\n // and that there are no duplicate timeframes\r\n var tfIds = allYearsData.map(datum => datum.timeFrameId); \r\n if (tfIds.length > 1) {\r\n if (!StringArrayHasDuplicates(tfIds)) {\r\n self.updateChart(allYearsData, response.timeFramesById);\r\n }\r\n else {\r\n console.warn(\"Selected region's trend chart data has duplicate timeframes.\");\r\n }\r\n }\r\n }\r\n\r\n // Animate the text fields transitions\r\n $(fadeables)\r\n .hide()\r\n .fadeIn(function() {\r\n // Also ensure the chart animation is complete before resolving our initial render promise\r\n $.when(self.chartAnimationComplete).done(function() {\r\n self.initialRenderPromise.resolve();\r\n });\r\n });\r\n });\r\n },\r\n });\r\n})(jQuery, _, Highcharts);\r\n","(function($, _) {\r\n var ns = window.nspace(\"ccc.viz.map.views\");\r\n\r\n var arrowImgPath = \"/images/change/\";\r\n\r\n /**\r\n * Displays the data table view on the right hand side of the map\r\n * that shows data for the currently selected region\r\n */\r\n ns.SelectedRegionTableView = Backbone.View.extend({\r\n el: \"#selected-region-table-container\",\r\n templateSelector: \"#selected-region-table-template\",\r\n name: \"SelectedRegionTableView\",\r\n\r\n arrowUrls: {\r\n up: {\r\n bad: arrowImgPath + \"change-red-up.png\",\r\n good: arrowImgPath + \"change-green-up.png\",\r\n neutral: arrowImgPath + \"change-gray-up.png\"\r\n },\r\n down: {\r\n bad: arrowImgPath + \"change-red-down.png\",\r\n good: arrowImgPath + \"change-green-down.png\",\r\n neutral: arrowImgPath + \"change-gray-down.png\"\r\n },\r\n noChange: arrowImgPath + \"no-change.png\"\r\n },\r\n\r\n initialize: function(options) {\r\n this.initialRenderPromise = $.Deferred();\r\n\r\n _.bindAll(this, \"render\", \"loadTemplate\");\r\n\r\n this.dataResponseModel = options.dataResponseModel;\r\n\r\n this.model.on(\"change\", this.render);\r\n\r\n // Preload all arrow images\r\n this.preloadArrows(this.arrowUrls);\r\n },\r\n\r\n getInitialRenderPromise: function() {\r\n return this.initialRenderPromise;\r\n },\r\n\r\n preloadArrows: function(obj) {\r\n var self = this;\r\n\r\n _.each(obj, function(entry) {\r\n // If it's a URL, preload it\r\n if (typeof entry === \"string\") {\r\n var img = new Image();\r\n img.src = entry;\r\n }\r\n // If it's an object, assume it will contain paths and recurse\r\n if (typeof entry === \"object\") {\r\n self.preloadArrows(entry);\r\n }\r\n });\r\n },\r\n\r\n loadTemplate: function() {\r\n // Get the underscore template\r\n if (!this.template) {\r\n var $tmpl = $(this.templateSelector);\r\n if ($tmpl.length === 0) {\r\n throw \"Could not find the \" +\r\n this.name +\r\n \" template: \" +\r\n this.templateSelector;\r\n }\r\n\r\n // Pre-compile and cache the template\r\n this.template = _.template($tmpl.html());\r\n }\r\n },\r\n\r\n getCurrentFips: function() {\r\n return this.model.get(\"selectedFips\");\r\n },\r\n\r\n /**\r\n * Renders the table area\r\n */\r\n render: function() {\r\n var self = this;\r\n\r\n this.loadTemplate();\r\n\r\n var fips = this.getCurrentFips();\r\n\r\n // If there's no selected fips, hide the current view\r\n if (!fips || fips === \"a\") {\r\n self.$el.hide();\r\n self.initialRenderPromise.resolve();\r\n return;\r\n }\r\n\r\n // Get the data to display\r\n $.when(this.dataResponseModel.getDataResponse()).done(function() {\r\n // Gather the properties necessary to render the template\r\n var response = self.dataResponseModel.get(\"response\");\r\n\r\n if (!response || !response.locationsByFips) {\r\n // no data to display\r\n return;\r\n }\r\n \r\n var currentLocation = response.locationsByFips[fips];\r\n\r\n if (!currentLocation || currentLocation.isUninhabited) {\r\n if (!currentLocation) {\r\n console.warn(\"Data response missing location for fips: \", fips);\r\n }\r\n \r\n self.$el.hide();\r\n self.initialRenderPromise.resolve();\r\n return;\r\n }\r\n\r\n // Data summary -- Pull it from the global selectors instance.\r\n var getSummaryFunc =\r\n ccc.viz.map.views.instances.SelectorsView\r\n .getDataSummaryByPropertyNames;\r\n var summary1 = response.currentDistributionName;\r\n if (_.str.isBlank(summary1)) {\r\n summary1 = response.indicatorGroupName;\r\n }\r\n var summary2 = getSummaryFunc([\"timeFrameId\", \"dataFormatId\"]);\r\n\r\n var templateData = {\r\n dataSummary1: summary1,\r\n dataSummary2: summary2,\r\n previousTfName: response.previousTimeFrameName,\r\n data: []\r\n };\r\n\r\n // Extract data for the current FIPS\r\n var dataForFips = response.tableDataByFips[fips];\r\n _.each(dataForFips, function(data) {\r\n var d = {};\r\n\r\n // Characteristic name for text, if available\r\n if (data.characteristicId) {\r\n d.text = response.characteristicsById[data.characteristicId].name;\r\n\r\n // Highlight the cell when it's the currently selected characteristic\r\n if (data.characteristicId === self.model.get(\"characteristicId\")) {\r\n d.isActive = true;\r\n }\r\n }\r\n // Otherwise, show the selected location name\r\n else {\r\n d.text = response.locationsByFips[fips].name;\r\n\r\n // There's only 1 data row in this table, so highlight it (unless it's the NYC table)\r\n if (fips !== ccc.viz.util.Fips.NYC) {\r\n d.isActive = true;\r\n }\r\n }\r\n\r\n d.displayValue = data.displayValue;\r\n d.changeDisplayValue = data.changeDisplayValue;\r\n\r\n // Figure out which image to show\r\n var change = parseFloat(data.changeValue);\r\n var upDown = \"noChange\";\r\n var altText = \"No change\";\r\n if (change > 0) {\r\n upDown = \"up\";\r\n altText = \"Higher\";\r\n }\r\n else if (change < 0) {\r\n upDown = \"down\";\r\n altText = \"Lower\";\r\n }\r\n\r\n var goodBad = \"neutral\";\r\n if (\r\n (response.largerValuesAre === \"better\" && change > 0) ||\r\n (response.largerValuesAre === \"worse\" && change < 0)\r\n ) {\r\n goodBad = \"good\";\r\n altText += \" (Better)\";\r\n }\r\n else if (\r\n (response.largerValuesAre === \"worse\" && change > 0) ||\r\n (response.largerValuesAre === \"better\" && change < 0)\r\n ) {\r\n goodBad = \"bad\";\r\n altText += \" (Worse)\";\r\n }\r\n\r\n d.changeAltText = altText;\r\n d.changeImgUrl =\r\n upDown === \"noChange\"\r\n ? self.arrowUrls.noChange\r\n : self.arrowUrls[upDown][goodBad];\r\n\r\n // Don't display any image at all if there's no change data available\r\n if (data.changeValue == null) {\r\n d.changeImgUrl = null;\r\n }\r\n\r\n templateData.data.push(d);\r\n });\r\n\r\n // Render the contents\r\n var height = self.$el.outerHeight(true);\r\n if (height > 0) {\r\n self.$el.height(self.$el.outerHeight(true));\r\n }\r\n self.$el.html(self.template(templateData));\r\n\r\n // Ensure we're visible / animate the transition\r\n self.$el\r\n .height(\"auto\")\r\n .hide()\r\n .fadeIn(function() {\r\n self.initialRenderPromise.resolve();\r\n });\r\n });\r\n }\r\n });\r\n})(jQuery, _);\r\n","// positioning per client request\r\n// indices in array correspond to (int)OverlayType enum values\r\nvar hardcodedPositionsByOverlayTypeAndFips = [\r\n { // 0: USCongressionalDistricts\r\n 3: [[40.784869324652725, -73.79702951072787], [40.75799451318282, -73.72946359695007]],\r\n 5: [[40.68788495005717, -73.77732278674912], [40.60125529503077, -73.75533504589843]],\r\n 7: [[40.70242291864709, -73.92081661328125], [40.65138942578652, -73.99566097363281], [40.7114798820512, -73.99154110058593]],\r\n 8: [[40.659383664816204, -73.88525863898879], [40.57518318661758, -73.97437496289062]],\r\n 10: [[40.62874848746662, -73.98825546516066], [40.77879590375711, -73.97437496289062]],\r\n 11: [[40.58688151900327, -74.14340553104262], [40.618682558605144, -74.02427253543715]],\r\n 12: [[40.7549499196378, -73.93813034309035], [40.724254585001546, -73.94843002570754], [40.755390878356025, -73.97338688364732], [40.788054633091924, -73.92142383750117]],\r\n 13: [[40.873472018323184, -73.89593872738803], [40.82066308812443, -73.9408769251216]],\r\n 14: [[40.78357929565804, -73.84001352370788], [40.763271636657265, -73.88113876594191], [40.85371741910896, -73.8478728301057], [40.78892008231452, -73.88266416542801]],\r\n 16: [[40.890360156279506, -73.86053940070754]]\r\n },\r\n { // 1: StateSenateDistricts\r\n 10: [[40.60033549805969, -73.75833865882402], [40.67745040787424, -73.79404422523027]],\r\n 11: [[40.77351074800717, -73.79816409827714]],\r\n 12: [[40.74365635189292, -73.92553683997636], [40.68979093888519, -73.89395114661698]],\r\n 15: [[40.71248738234712, -73.88845798255448], [40.66693051457872, -73.8451993155623], [40.573897948440425, -73.85000583411698]],\r\n 18: [[40.69744404461976, -73.92656680823808]],\r\n 19: [[40.63321516596988, -73.89772769690995], [40.659525080606095, -73.88176318885331]],\r\n 20: [[40.66151368481576, -73.93755313636308]],\r\n 21: [[40.63827882920038, -73.93000003577714], [40.65312714749101, -73.97840854407792]],\r\n 22: [[40.61837169184246, -74.01754733802323], [40.57692289190187, -73.94098636390214]],\r\n 23: [[40.57775733467005, -73.97119876624589]],\r\n 25: [[40.683334339021904, -73.95234491383574]],\r\n 26: [[40.685270488989126, -73.99853862578492], [40.72121400641523, -73.95188285299741], [40.71668974120885, -73.99575130972397]],\r\n 27: [[40.73446346710504, -74.00149299093685], [40.763333856438834, -73.98638678976498]],\r\n 28: [[40.77092650675943, -73.95583106466732]],\r\n 29: [[40.77763435906342, -73.96990729757748], [40.791411932393004, -73.9218421120306], [40.80492677364079, -73.91737891622982]],\r\n 30: [[40.812982389093655, -73.94312812277279]],\r\n 31: [[40.86181484818353, -73.92390204855404]],\r\n 32: [[40.82883090587905, -73.88956977316342]],\r\n 33: [[40.84909070526675, -73.89609290548763]],\r\n 34: [[40.84961010587821, -73.84699775167904], [40.889072638783745, -73.9053626198431], [40.808045192405984, -73.87927009054623], [40.78829273213402, -73.88167334982357]],\r\n },\r\n { // 2: StateAssemblyDistricts\r\n 23: [[40.59839616159631, -73.7465929954793], [40.66692020261446, -73.8454699486043], [40.57258372482687, -73.85233640368243]],\r\n 26: [[40.76646397554606, -73.78474081563351]],\r\n 27: [[40.72588771403487, -73.82319296407101], [40.7779040857792, -73.83829916524289]],\r\n 30: [[40.724638821299244, -73.89597738789914]],\r\n 31: [[40.65721589506579, -73.76551474141476], [40.59233186067387, -73.79572714375851], [40.60197725047939, -73.75727499532101]],\r\n 34: [[40.755513803895454, -73.88670767354367]],\r\n 38: [[40.689684112636705, -73.8554653029382]],\r\n 41: [[40.60398213188293, -73.94816244649289]],\r\n 44: [[40.63936978475293, -73.97735859511437]],\r\n 46: [[40.61253067404839, -74.02439381239952], [40.57446840815796, -73.97838856337609]],\r\n 49: [[40.618264205456605, -74.0013911878878]],\r\n 50: [[40.72452078044448, -73.94862824340387]],\r\n 51: [[40.65146141733449, -74.00046997924372]],\r\n 53: [[40.70067290505296, -73.92390900512262]],\r\n 58: [[40.647293697800364, -73.92562561889216]],\r\n 59: [[40.61706994719295, -73.92150574584528]],\r\n 61: [[40.633486267722105, -74.11548310180231]],\r\n 62: [[40.525272771113656, -74.20577698607966]],\r\n 64: [[40.57692417804279, -74.08939057250544]],\r\n 65: [[40.712121683881016, -73.99137114506294]],\r\n 68: [[40.79456582713964, -73.94090270023872], [40.79014712675658, -73.92133330326607]],\r\n 71: [[40.83458065522495, -73.94364928226997]],\r\n 73: [[40.754910973550366, -73.96875497361741]],\r\n 76: [[40.772853387689814, -73.94884225389085]],\r\n 77: [[40.843016267139056, -73.92000314256272]],\r\n 79: [[40.83262644773503, -73.89597054978928]],\r\n 81: [[40.88481882078327, -73.90524026414475]],\r\n 82: [[40.829249405809605, -73.82730599900803]],\r\n 84: [[40.807164508345934, -73.9186298515471]],\r\n 85: [[40.82457321765843, -73.87880441209397], [40.78892008231452, -73.88266416542801]]\r\n },\r\n { // 3: CityCouncilDistricts\r\n 1: [[40.717047485511024, -73.99864723458758]],\r\n 8: [[40.79239378356402, -73.94042640155932], [40.788234878822934, -73.9229169411101], [40.80717904746301, -73.9218846987007]],\r\n 9: [[40.811895594974885, -73.94435572818226]],\r\n 13: [[40.83919914264212, -73.82999591834027]],\r\n 16: [[40.83114671089866, -73.91308002478559]],\r\n 17: [[40.819455956748854, -73.88904743201215]],\r\n 20: [[40.74952825094271, -73.81694965369184]],\r\n 22: [[40.76825217619735, -73.91136341101605], [40.78892008231452, -73.88266416542801]],\r\n 28: [[40.67945034293794, -73.80236327068604]],\r\n 31: [[40.59763257430382, -73.75811726975324], [40.66146972852111, -73.74335439133527]],\r\n 32: [[40.66737497206612, -73.84147635826494], [40.55373624902019, -73.92112723717119]],\r\n 33: [[40.72460371168821, -73.94932949182534], [40.70238351553799, -73.95982189284045], [40.694704947088745, -73.99183673964221]],\r\n 35: [[40.67631612881499, -73.96501850704765]],\r\n 37: [[40.67527461152218, -73.89395069698905]],\r\n 39: [[40.66798353489923, -73.98218464474296]],\r\n 41: [[40.669806378796565, -73.91626667599296]],\r\n 42: [[40.66173340611894, -73.88433765987968]],\r\n 46: [[40.617966106115155, -73.91798328976249]],\r\n 49: [[40.62545910075206, -74.10290305380799]]\r\n },\r\n { // 4: ZipCodes\r\n // None for now\r\n },\r\n { // 5: PolicePrecincts\r\n 1: [[40.71012689089476, -74.01060903470518]],\r\n 25: [[40.79985094290456, -73.93748128812315], [40.78893448856273, -73.92306173245909]],\r\n 32: [[40.81646269120736, -73.93956685485858]],\r\n 45: [[40.83568726250907, -73.82730031433124]],\r\n 47: [[40.885022121406365, -73.85373616638202]],\r\n 61: [[40.59528589955862, -73.95177918988617]],\r\n 63: [[40.617962386859844, -73.92808991986664]],\r\n 69: [[40.63724437765526, -73.8997314582985]],\r\n 75: [[40.66876104338793, -73.87981873857194]],\r\n 100: [[40.58251069790033, -73.8224838386696]],\r\n 105: [[40.697035153345404, -73.73557753050929]],\r\n 110: [[40.73869789701868, -73.86991198505633]],\r\n 113: [[40.679621386413594, -73.77343829120869]],\r\n 114: [[40.76631612343358, -73.91550863187315], [40.78867455110601, -73.88323629300596]],\r\n 115: [[40.75677031971883, -73.87632863646738]]\r\n },\r\n { // 6: SchoolDistricts\r\n 4: [[40.79316914291773, -73.93950002318613], [40.79005002520676, -73.92267720824472]],\r\n 5: [[40.81032167110717, -73.943619896233]],\r\n 7: [[40.81006181738851, -73.91752736693613], [40.78892008231452, -73.88266416542801]],\r\n 8: [[40.81915609203998, -73.87289540892831], [40.825339487508394, -73.82689015990488]],\r\n 10: [[40.88615541900031, -73.90791432982675]],\r\n 11: [[40.879614285271884, -73.85298268920175]],\r\n 15: [[40.662306550485724, -73.9884269086338]],\r\n 18: [[40.64198976159056, -73.91667245306739]],\r\n 19: [[40.66907743870854, -73.87959359564552]],\r\n 27: [[40.67239619796767, -73.83546670944858], [40.59840369588871, -73.75581583054233]],\r\n 29: [[40.699537928625624, -73.75554433142224]]\r\n },\r\n { // 7: CommunityDistricts\r\n // Note: label text is in the overlay's .dbf file\r\n // \"B10\"\r\n 35: [[40.82755027146717, -73.82774206991563]],\r\n // \"B12\"\r\n 44: [[40.88464965915959, -73.8534912764586]],\r\n // \"M01\"\r\n 36: [[40.71159212456818, -74.00922146163222]],\r\n // \"M04\"\r\n 42: [[40.7552980004871, -74.00029507003066]],\r\n // \"M05\"\r\n 26: [[40.7552980004871, -73.98250000000000]],\r\n // \"Q13\"\r\n 46: [[40.70583642598386, -73.73761073683053]]\r\n },\r\n];",";\r\n\r\nvar CCCLabelEngine = function (map) {\r\n\tthis.map = map;\r\n\r\n\tclass Point {\r\n\t\tconstructor(x, y) {\r\n\t\t\tthis.x = x;\r\n\t\t\tthis.y = y;\r\n\t\t}\r\n\t}\r\n\r\n\tthis.labelGun = new labelgun.default(\r\n\t\tfunction hideLabel(label) {\r\n\t\t\t//console.debug('hideLabel', label.id, label.name);\r\n\t\t\tlabel.labelObject.classList.add(\"overlay-label--hidden\");\r\n\t\t},\r\n\t\tfunction showLabel(label) {\r\n\t\t\t//console.debug('showLabel', label.id, label.name);\r\n\t\t\tlabel.labelObject.classList.remove(\"overlay-label--hidden\");\r\n\t\t}\r\n\t);\r\n\r\n\tthis.renderLabels = _.debounce(function(overlayMarkers, beforeTask, afterTask) {\r\n\t\tif (beforeTask instanceof Function) {\r\n\t\t\tbeforeTask();\r\n\t\t}\r\n\r\n\t\tif (!(overlayMarkers && overlayMarkers.length)) {\r\n\t\t\tconsole.debug('No labels to render');\r\n\t\t\tif (afterTask instanceof Function) {\r\n\t\t\t\tafterTask();\r\n\t\t\t}\r\n\t\t\treturn;\r\n\t\t}\r\n\t\tvar self = this;\r\n\r\n\t\t// Google maps renders map markers (like our labels) asynchronously\r\n\t\t// There's no event to tell when it's done - \"idle\" doesn't work\r\n\t\t// So we just have to wait, based on how many markers there are\r\n\t\tvar delayPerMarker = 13; // 10 works fine, but include a buffer\r\n\t\tvar delayLength = overlayMarkers.length * delayPerMarker;\r\n\t\tconsole.debug('delayLength', delayLength);\r\n\r\n\t\tsetTimeout(function() {\r\n\t\t\tresetAndUpdateLabels(overlayMarkers, afterTask instanceof Function ? afterTask : null);\r\n\t\t}, delayLength);\r\n\t\t\r\n\t\tfunction resetAndUpdateLabels (overlayMarkers, cb) {\r\n\t\t\tconsole.debug('labelGun.reset() start');\r\n\t\t\tself.labelGun.reset();\r\n\t\t\tconsole.debug('labelGun.reset() end');\r\n\t\r\n\t\t\tif (!overlayMarkers) {\r\n\t\t\t\tconsole.debug('No new overlay markers');\r\n\t\t\t\treturn;\r\n\t\t\t}\r\n\t\r\n\t\t\toverlayMarkers.forEach(ingestSingleLabel, self);\r\n\t\r\n\t\t\tconsole.debug('labelGun.update start');\r\n\t\t\tself.labelGun.update(false);\r\n\t\t\tconsole.debug('labelGun.update end');\r\n\t\r\n\t\t\tif (cb instanceof Function) {\r\n\t\t\t\tcb();\r\n\t\t\t}\r\n\t\r\n\t\t\tfunction ingestSingleLabel (element, index, array) {\r\n\t\t\t\t// Use LabelGun to show/hide overlapping labels\r\n\t\t\t\tvar labelDiv = element.label.labelDiv_;\r\n\t\t\r\n\t\t\t\t// We need the bounding rectangle of the label itself\r\n\t\t\t\tvar rect = labelDiv.getBoundingClientRect();\r\n\t\t\r\n\t\t\t\t// We convert the container coordinates (screen space) to Lat/lng\r\n\t\t\t\tvar bottomLeft = point2LatLng(new google.maps.Point(rect.left, rect.bottom), map);\r\n\t\t\t\tvar topRight = point2LatLng(new google.maps.Point(rect.right, rect.top), map);\r\n\t\t\t\tvar boundingBox = {\r\n\t\t\t\t\tbottomLeft: [bottomLeft.lng(), bottomLeft.lat()],\r\n\t\t\t\t\ttopRight: [topRight.lng(), topRight.lat()]\r\n\t\t\t\t}\r\n\t\t\r\n\t\t\t\t// Ingest the label into labelgun itself\r\n\t\t\t\tvar now = performance.now();\r\n\t\t\t\tself.labelGun.ingestLabel(\r\n\t\t\t\t\tboundingBox,\r\n\t\t\t\t\t\"id|\" + index,\r\n\t\t\t\t\tparseInt(Math.random() * (5 - 1) + 1), // Weight\r\n\t\t\t\t\tlabelDiv,\r\n\t\t\t\t\telement.labelContent,\r\n\t\t\t\t\tfalse\r\n\t\t\t\t);\r\n\t\t\t};\r\n\t\t\t\r\n\t\t\tfunction point2LatLng (point, map) {\r\n\t\t\t\tvar topRight = map.getProjection().fromLatLngToPoint(map.getBounds().getNorthEast());\r\n\t\t\t\tvar bottomLeft = map.getProjection().fromLatLngToPoint(map.getBounds().getSouthWest());\r\n\t\t\t\tvar scale = Math.pow(2, map.getZoom());\r\n\t\t\t\tvar worldPoint = new google.maps.Point(point.x / scale + bottomLeft.x, point.y / scale + topRight.y);\r\n\t\t\t\treturn map.getProjection().fromPointToLatLng(worldPoint);\r\n\t\t\t};\r\n\t\t};\r\n\t}, 100);\r\n};","(function() {\r\n var ns = window.nspace(\"ccc.viz.map.config\");\r\n\r\n ns.MapConfig = {\r\n /**\r\n * URL endpoint for our choropleth overlay service\r\n */\r\n serviceUrl: \"/ChoroplethOverlayService.axd\",\r\n\r\n dataUrl: \"/api/MapData/GetMapData\",\r\n\r\n alpha: \"0.7\", // Everywhere else says \"opacity\" instead of \"alpha\", so commenting just to find this more easily: MAP OPACITY HERE\r\n\r\n noDataColor: { color: \"#FFFFFF\" },\r\n\r\n themeColors: [\r\n {\r\n color: \"#FFFFCC\"\r\n },\r\n {\r\n color: \"#A1DAB4\"\r\n },\r\n {\r\n color: \"#41B6C4\"\r\n },\r\n {\r\n color: \"#2C7FB8\"\r\n },\r\n {\r\n color: \"#253494\",\r\n textColor: \"#ececec\"\r\n }\r\n ],\r\n\r\n /**\r\n * Returns a string specifying theme colors in the format required by the choropleth\r\n * overlay service in the form:\r\n * alpha|no data color|color1,color2,...,colorN\r\n */\r\n getThemeColorString: function() {\r\n return (\r\n this.alpha +\r\n \"|\" +\r\n this.noDataColor.color +\r\n \"|\" +\r\n _.map(this.themeColors, function(obj) {\r\n return obj.color;\r\n }).join(\",\")\r\n );\r\n },\r\n\r\n /**\r\n * The number of different \"buckets\" into which to sort the data values.\r\n */\r\n getNumBreaks: function() {\r\n // Calculate numBreaks from the number of themeColors\r\n return this.themeColors.length;\r\n },\r\n\r\n /**\r\n * Minimum map zoom\r\n */\r\n minZoom: 6,\r\n\r\n /**\r\n * Maximum map zoom\r\n */\r\n maxZoom: 18,\r\n\r\n /**\r\n * Mouseover Polygon style\r\n */\r\n mouseoverPolygonStyle: {\r\n strokeColor: \"#333\",\r\n strokeWeight: 2,\r\n fillOpacity: 0,\r\n zIndex: 10\r\n },\r\n\r\n /**\r\n * Selected Polygon style\r\n */\r\n selectedPolygonInnerStyle: {\r\n strokeColor: \"#333\",\r\n strokeWeight: 2,\r\n fillOpacity: 0,\r\n clickable: false,\r\n zIndex: 2\r\n },\r\n selectedPolygonOuterStyle: {\r\n strokeColor: \"#fbd100\",\r\n strokeWeight: 5,\r\n strokeOpacity: 0.8,\r\n fillOpacity: 0,\r\n clickable: false,\r\n zIndex: 1\r\n },\r\n\r\n /**\r\n * The location id for New York City stored statically.\r\n */\r\n nycLocationId: 1,\r\n\r\n /**\r\n * The fips for New York City stored statically.\r\n */\r\n nycFips: 3651000\r\n };\r\n})();\r\n","/// \r\n/// \r\n/// \r\n/// \r\n/// \r\n\r\n(function(_) {\r\n var ns, sharedNs;\r\n\r\n ns = window.nspace(\"ccc.viz.map\");\r\n sharedNs = window.nspace(\"ccc.viz.shared\");\r\n\r\n ns.MapVizRouter = sharedNs.routers.VizRouterBase.extend({\r\n\troutes: {\r\n\t\t\"\": \"initializeViews\",\r\n\t\t\":indicatorId\": \"initializeViews\",\r\n\t\t\":indicatorId/:characteristicId\": \"initializeViews\",\r\n\t\t\":indicatorId/:characteristicId/:locationTypeId\": \"initializeViews\",\r\n\t\t\":indicatorId/:characteristicId/:locationTypeId/:dataFormatId\": \"initializeViews\",\r\n\t\t\":indicatorId/:characteristicId/:locationTypeId/:dataFormatId/:timeFrameId\": \"initializeViews\",\r\n\t\t\":indicatorId/:characteristicId/:locationTypeId/:dataFormatId/:timeFrameId/:selectedFips\": \"initializeViews\",\r\n\t\t\":indicatorId/:characteristicId/:locationTypeId/:dataFormatId/:timeFrameId/:selectedFips/:overlays\": \"initializeViews\"\r\n\t},\r\n\r\n\r\n /**\r\n * This method will only ever be invoked a single time, so use it to initialize\r\n * the model/view classes and trigger the initial rendering\r\n */\r\n initializeViews: function(\r\n indicatorId,\r\n characteristicId,\r\n locationTypeId,\r\n dataFormatId,\r\n timeFrameId,\r\n selectedFips,\r\n overlays\r\n ) {\r\n //// MODELS ////\r\n\r\n function getValue(raw) {\r\n if (typeof raw === \"undefined\" || raw === \"a\") {\r\n return undefined;\r\n }\r\n\r\n return raw;\r\n }\r\n\r\n // Create the selectors model, which represents anything that is selectable by the user and tracked in the URL\r\n this.selectorsModel = new sharedNs.models.SelectorsModel();\r\n this.selectorsModel.set(\r\n {\r\n indicatorId: getValue(indicatorId),\r\n characteristicId: getValue(characteristicId),\r\n locationTypeId: getValue(locationTypeId),\r\n dataFormatId: getValue(dataFormatId),\r\n timeFrameId: getValue(timeFrameId),\r\n\t\t\t\t\tselectedFips: getValue(selectedFips),\r\n\t\t\t\t\toverlays: getValue(overlays)\r\n\t\t\t\t\t},\r\n {\r\n silent: true\r\n }\r\n );\r\n\r\n // Create the data response model, the model that is responsible for querying the server-side for data,\r\n // storing the response, and triggering updates to other views after the response has been retrieved\r\n this.dataModel = new ns.models.DataResponseModel({\r\n selectorsModel: this.selectorsModel,\r\n dispatcher: this.dispatcher,\r\n dataUrl: ns.config.MapConfig.dataUrl\r\n });\r\n\r\n //// VIEWS ////\r\n\r\n this.views = {\r\n // Loading spinner (no model required)\r\n loadingSpinner: new sharedNs.views.LoadingSpinnerView({\r\n dispatcher: this.dispatcher\r\n }),\r\n\r\n // Data summary and table need both models. The SelectorsModel so that we know when a\r\n // new location is selected, and the DataResponseModel for rendering the data.\r\n selectedRegionSummaryView: new ns.views.SelectedRegionSummaryView({\r\n model: this.selectorsModel,\r\n dataResponseModel: this.dataModel\r\n }),\r\n\r\n // Same Summary view as above, but specifically for NYC\r\n nycSummaryView: new ns.views.NYCSummaryView({\r\n model: this.selectorsModel,\r\n dataResponseModel: this.dataModel\r\n }),\r\n\r\n // Currently selected region table view\r\n selectedRegionTableView: new ns.views.SelectedRegionTableView({\r\n model: this.selectorsModel,\r\n dataResponseModel: this.dataModel\r\n }),\r\n\r\n // Same Table view as above, but specifically for NYC\r\n nycTableView: new ns.views.NYCTableView({\r\n model: this.selectorsModel,\r\n dataResponseModel: this.dataModel\r\n }),\r\n\r\n // \"Select a Region\" prompt\r\n selectRegionPromptView: new ns.views.SelectRegionPromptView({\r\n model: this.selectorsModel\r\n }),\r\n\r\n // Map\r\n mapView: new ns.views.GoogleMapView({\r\n model: this.selectorsModel,\r\n dispatcher: this.dispatcher,\r\n dataResponseModel: this.dataModel\r\n }),\r\n\r\n // Legend, popups, & data tables are wired to the DataResponseModel\r\n legendView: new ns.views.LegendView({\r\n model: this.dataModel\r\n }),\r\n\r\n // Source/Definition/Notes\r\n sourceDefinitionNotesView: new sharedNs.views.SourceDefinitionNotesView(\r\n {\r\n selectorsModel: this.selectorsModel,\r\n model: this.dataModel\r\n }\r\n ),\r\n\r\n // Source/Definition/Notes\r\n overlayView: new ns.views.OverlayView({\r\n model: this.dataModel\r\n }),\r\n\r\n // Map popup\r\n mapPopupView: new ns.views.MapPopupView({\r\n model: this.dataModel,\r\n selectorsModel: this.selectorsModel,\r\n dispatcher: this.dispatcher\r\n }),\r\n\r\n // Selectors. These must be instantiated late, since these views are used to bootstrap\r\n // the selectors model values, and certain other views need to hear when the selectors model changes.\r\n selectorsView: new ns.views.SelectorsView({\r\n model: this.selectorsModel,\r\n indicatorGroupId: this.indicatorGroupId,\r\n dispatcher: this.dispatcher\r\n })\r\n };\r\n\r\n this.completeRouterInitialization();\r\n },\r\n\r\n routeUrlParts: function() {\r\n return [\r\n this.selectorsModel.get(\"indicatorId\"),\r\n this.selectorsModel.get(\"characteristicId\"),\r\n this.selectorsModel.get(\"locationTypeId\"),\r\n this.selectorsModel.get(\"dataFormatId\"),\r\n this.selectorsModel.get(\"timeFrameId\"),\r\n\t\t\t\tthis.selectorsModel.get(\"selectedFips\"),\r\n\t\t\t\tthis.selectorsModel.get(\"overlays\")\r\n ];\r\n }\r\n });\r\n})(_);\r\n","(function($, velir, google) {\r\n var ns = nspace(\"ccc.viz.map.layers\");\r\n\r\n /**\r\n * @class ChoroplethOverlay\r\n * The thematic choropleth data overlay\r\n */\r\n\tns.ChoroplethMapType = function (projection, filterString, overlays) {\r\n // \"private\" members\r\n this._projection = projection;\r\n this._filterString = filterString;\r\n this._pendingTileUrls = [];\r\n\t\tthis._overlays = overlays;\r\n };\r\n\r\n /**\r\n * @class ChoroplethOverlay prototype\r\n * The thematic choropleth data overlay\r\n */\r\n (function(proto) {\r\n proto.tileSize = new google.maps.Size(256, 256);\r\n proto.maxZoom = 19;\r\n\r\n /**\r\n * Generate a DOM node representing a tile\r\n */\r\n proto.getTile = function(coord, zoom, ownerDocument) {\r\n // These are the same styles set by the \"out of the box\" ImageMapType layer\r\n var $container = $(\"
\")\r\n .css(\"-webkit-user-select\", \"none\")\r\n .css(\"border-top-width\", \"0px\")\r\n .css(\"border-right-width\", \"0px\")\r\n .css(\"border-bottom-width\", \"0px\")\r\n .css(\"border-left-width\", \"0px\")\r\n .css(\"border-style\", \"initial\")\r\n .css(\"border-color\", \"initial\")\r\n .css(\"padding-top\", \"0px\")\r\n .css(\"padding-right\", \"0px\")\r\n .css(\"padding-bottom\", \"0px\")\r\n .css(\"padding-left\", \"0px\")\r\n .css(\"margin-top\", \"0px\")\r\n .css(\"margin-right\", \"0px\")\r\n .css(\"margin-bottom\", \"0px\")\r\n .css(\"margin-left\", \"0px\")\r\n .css(\"width\", \"256px\")\r\n .css(\"height\", \"256px\")\r\n .css(\"display\", \"inline\");\r\n\r\n // The tile image\r\n var $img = $(\"\");\r\n\r\n // Listen for the image to finish loading\r\n var overlay = this;\r\n $img.bind(\"load error abort\", function(e) {\r\n // Remove the image from our list of pending urls\r\n overlay.removePending($img[0]);\r\n\r\n // If the pending url list is empty emit an event to indicate that the tiles are finished loading\r\n if (overlay._pendingTileUrls.length === 0) {\r\n $(overlay).trigger(\"idle\");\r\n }\r\n\r\n if (e.type !== \"load\") {\r\n return;\r\n }\r\n\r\n // make the tile fade-in\r\n $(this).fadeIn(600);\r\n });\r\n\r\n $img\r\n .hide()\r\n .attr(\"src\", this.getTileUrl(coord, zoom))\r\n .appendTo($container);\r\n\r\n return $container[0];\r\n };\r\n\r\n /**\r\n * Removes a URL from the list of pending URLs\r\n */\r\n proto.removePending = function(imgElement) {\r\n var index = $.inArray(imgElement.src, this._pendingTileUrls);\r\n if (index > -1) {\r\n this._pendingTileUrls.splice(index, 1);\r\n }\r\n };\r\n\r\n /**\r\n * Cleans up the node before for removal from the DOM\r\n */\r\n proto.releaseTile = function(node) {\r\n var self = this;\r\n $(\"img\", node).each(function() {\r\n // clean up any event handlers (cause IE sucks)\r\n $(this).unbind();\r\n\r\n // remove this url from the list of pending urls, if necessary\r\n self.removePending(this);\r\n });\r\n };\r\n\r\n /**\r\n * Generates the URL from which to retrieve a tile\r\n */\r\n proto.getTileUrl = function(coord, zoom) {\r\n // assume square tiles\r\n var size = this.tileSize.width;\r\n\r\n // Figure out the lat/long for the current tile\r\n var zfactor = Math.pow(2, zoom);\r\n var top = this._projection.fromPointToLatLng(\r\n new google.maps.Point(\r\n (coord.x * size) / zfactor,\r\n (coord.y * size) / zfactor\r\n )\r\n );\r\n var bot = this._projection.fromPointToLatLng(\r\n new google.maps.Point(\r\n ((coord.x + 1) * size) / zfactor,\r\n ((coord.y + 1) * size) / zfactor\r\n )\r\n );\r\n\r\n // bounding box\r\n var bbox =\r\n top.lng() + \", \" + bot.lat() + \", \" + bot.lng() + \", \" + top.lat();\r\n\r\n // build our query string\r\n var qs = new velir.collections.NameValueCollection();\r\n qs.add(\"request\", \"GetMap\"); //WMS operation\r\n qs.add(\"service\", \"WMS\"); //WMS service\r\n\t\t\tqs.add(\"version\", \"1.3.0\"); //WMS version\r\n qs.add(\"format\", \"image/png\"); //WMS format\r\n qs.add(\"transparent\", \"true\");\r\n qs.add(\"styles\", \"default\"); // value is options, param is required\r\n qs.add(\"crs\", \"EPSG:4326\"); //set WGS84\r\n qs.add(\"bbox\", bbox); // set bounding box\r\n\r\n qs.add(\"width\", \"\" + size); //tile size\r\n qs.add(\"height\", \"\" + size);\r\n\r\n // uncomment the next line to always force tile regeneration\r\n //qs.add(\"force\", true);\r\n\r\n var parms = ccc.viz.util.UrlParams;\r\n var config = ccc.viz.map.config.MapConfig;\r\n\r\n // filter string\r\n qs.add(parms.filterString, this._filterString);\r\n\r\n // theme colors\r\n qs.add(parms.themeColors, config.getThemeColorString());\r\n\r\n // assemble the URL\r\n\t\t\tvar layersParam = \"&layers=default\" + (this._overlays ? ',' + this._overlays : ''); // WMS layers; add separately so they're not escaped\r\n\t\t\tvar formatOptions = \"&format_options=antialiasing:on;dpi:1000;\"; // add separately so it's not encoded\r\n\t\t\tvar url = config.serviceUrl + \"?\" + qs.toQueryString() + layersParam + formatOptions;\r\n if (!_.str.startsWith(url.toLowerCase(), \"http\")) {\r\n // Prefix with current protocol/port/host\r\n url = _.str.sprintf(\"%(protocol)s//%(host)s%(port)s%(slash)s%(path)s\", {\r\n protocol: window.location.protocol,\r\n host: window.location.host,\r\n port: _.str.isBlank(window.location.port)\r\n ? \"\"\r\n : \":\" + window.location.port,\r\n slash: _.str.startsWith(url, \"/\") ? \"\" : \"/\",\r\n path: url\r\n });\r\n }\r\n\r\n // Add this to the list of tiles that have not yet finished loading\r\n this._pendingTileUrls.push(url);\r\n\r\n // If this is our first pending tile, signal that we just became busy\r\n if (this._pendingTileUrls.length === 1) {\r\n $(this).trigger(\"busy\");\r\n }\r\n\r\n return url; // return URL for the tile\r\n };\r\n })(ns.ChoroplethMapType.prototype);\r\n})(jQuery, velir, google);\r\n","(function($, _) {\r\n var ns = window.nspace(\"ccc.viz.map.layers\");\r\n\r\n /**\r\n * \"Static\" class for managing polygon retrieval\r\n */\r\n\r\n ns.PolygonManager = {\r\n /**\r\n * Cache (polygons are stored in WKT form)\r\n */\r\n polygonsByLocType: {},\r\n\r\n /**\r\n * Global event dispatcher\r\n */\r\n dispatcher: window.ccc.viz.shared.VizApp.dispatcher,\r\n\r\n /**\r\n * Keep track of loading polygons\r\n */\r\n loadingDeferreds: {},\r\n\r\n /**\r\n * Loads the polygon data from the server side for the specified location type\r\n */\r\n loadPolygons: function(locationTypeId) {\r\n var self = this;\r\n\r\n // Do we already have a deferred object for this location type id?\r\n if (this.loadingDeferreds.hasOwnProperty(locationTypeId)) {\r\n return this.loadingDeferreds[locationTypeId];\r\n }\r\n\r\n // Trigger the load and return the deferred\r\n $(self).trigger(\"busy\");\r\n self.dispatcher.trigger(\"add-task\", {\r\n name: \"loading-polygons\",\r\n text: \"Loading polygons...\"\r\n });\r\n\r\n var deferred = $.ajax({\r\n url: \"/api/MapData/GetWktPolygons\",\r\n data: {\r\n locationTypeId: locationTypeId,\r\n isSimplified: true\r\n },\r\n complete: function() {\r\n $(self).trigger(\"idle\");\r\n self.dispatcher.trigger(\"end-task\", { name: \"loading-polygons\" });\r\n },\r\n success: function(response) {\r\n var polygons = {};\r\n\r\n // Parse out the WKT text into google API Polygons\r\n for (var key in response) {\r\n var wktPolygon = response[key];\r\n var polygon = ccc.viz.map.util.MapUtil.wktToGooglePolygon(\r\n wktPolygon\r\n );\r\n\r\n polygons[key] = polygon;\r\n }\r\n\r\n // Save for future use\r\n self.polygonsByLocType[locationTypeId] = polygons;\r\n }\r\n });\r\n\r\n // Record the deferred for future requests for these same polygons\r\n this.loadingDeferreds[locationTypeId] = deferred;\r\n return deferred;\r\n },\r\n\r\n clonePolygon: function(polygon) {\r\n var clone = new google.maps.Polygon();\r\n\r\n // Copy just the paths. Maybe not exactly a true clone, but in order to copy everything\r\n // properly we'd have to walk to full object graph and create new instances of all inner\r\n // reference-type properties. Copying just the paths will suffice for our purposes.\r\n clone.setPaths(polygon.getPaths());\r\n\r\n return clone;\r\n },\r\n\r\n /**\r\n * Returns a single google map API Polygon, via callback, based on the specified FIPS\r\n * and location type ID, or null if none is found.\r\n */\r\n getPolygonByFips: function(locationTypeId, fips, onSuccessCallback) {\r\n var self = this;\r\n\r\n $.when(this.loadPolygons(locationTypeId)).done(function() {\r\n var polygons = self.polygonsByLocType[locationTypeId];\r\n var polygon = polygons[fips];\r\n if (!polygon) {\r\n onSuccessCallback(null);\r\n return;\r\n }\r\n\r\n onSuccessCallback({ fips: fips, polygon: polygon });\r\n });\r\n },\r\n\r\n parsePolygon: function(text) {\r\n var paths = [];\r\n var rings = $.trim(text).split(regExes.parenComma);\r\n for (var i = 0, len = rings.length; i < len; ++i) {\r\n var ring = rings[i].replace(regExes.trimParens, \"$1\");\r\n paths.push(getPolygonLatLngs(ring));\r\n }\r\n\r\n return paths;\r\n },\r\n\r\n parseMultiPolygon: function(text) {\r\n var polygon;\r\n var polygons = $.trim(text).split(regExes.doubleParenComma);\r\n var paths = [];\r\n for (var i = 0, len = polygons.length; i < len; ++i) {\r\n polygon = polygons[i].replace(regExes.trimParens, \"$1\");\r\n var polyPaths = parsePolygon(polygon);\r\n for (var j = 0; j < polyPaths.length; j++) {\r\n paths.push(polyPaths[j]);\r\n }\r\n }\r\n return paths;\r\n },\r\n\r\n getPolygonLatLngs: function(coords) {\r\n // Expects polygon text that looks like this:\r\n // -12211621.104157 4438929.90942386, ... , -12212798.9101653 4438929.90942386\r\n\r\n // split into coord pairs\r\n var pairs = coords.split(\", \");\r\n var latLngs = [];\r\n for (var i = 0; i < pairs.length; i++) {\r\n // create a new LatLng from each pair\r\n var parts = pairs[i].split(\" \");\r\n var lat = parseFloat(parts[1]);\r\n var lng = parseFloat(parts[0]);\r\n\r\n latLngs.push(new google.maps.LatLng(lat, lng));\r\n }\r\n\r\n return latLngs;\r\n },\r\n\r\n /**\r\n * Returns the single google Maps API Polygon that sits underneath the specified mouse coordinates, for\r\n * the specified location type, or null if none is found\r\n */\r\n findPolygon: function(locationTypeId, latLng, onSuccessCallback) {\r\n var self = this;\r\n\r\n $.when(this.loadPolygons(locationTypeId)).done(function() {\r\n var polygons = self.polygonsByLocType[locationTypeId];\r\n for (var fips in polygons) {\r\n var polygon = polygons[fips];\r\n if (polygon.contains(latLng)) {\r\n onSuccessCallback({ fips: fips, polygon: polygon });\r\n return;\r\n }\r\n }\r\n\r\n onSuccessCallback(null);\r\n });\r\n }\r\n };\r\n})(jQuery, _);\r\n","/// \r\n/// \r\n/// \r\n/// \r\n\r\n(function(_) {\r\n var ns, sharedNs;\r\n\r\n ns = window.nspace(\"ccc.viz.map.models\");\r\n sharedNs = window.nspace(\"ccc.viz.shared.models\");\r\n\r\n /**\r\n * Data response model is responsible for querying the server-side for data,\r\n * storing the response, and other views listen for the response to change\r\n * in order to be updated when new data is retrieved\r\n */\r\n ns.DataResponseModel = sharedNs.DataResponseModel.extend({\r\n getDataResponseOnChange: function() {\r\n // Don't bother requesting new data if the only change was to the selectedFips.\r\n if (\r\n _.size(this.selectorsModel.changed) === 1 &&\r\n this.selectorsModel.changed.hasOwnProperty(\"selectedFips\")\r\n ) {\r\n return;\r\n }\r\n\r\n this.getDataResponse();\r\n },\r\n\r\n getFilterString: function() {\r\n var params, filterStringNvc, filterString;\r\n\r\n params = window.ccc.viz.util.UrlParams;\r\n\r\n filterStringNvc = new window.velir.collections.NameValueCollection();\r\n filterStringNvc.add(\r\n params.indicator,\r\n this.selectorsModel.get(\"indicatorId\")\r\n );\r\n filterStringNvc.add(\r\n params.timeFrame,\r\n this.selectorsModel.get(\"timeFrameId\")\r\n );\r\n filterStringNvc.add(\r\n params.locationType,\r\n this.selectorsModel.get(\"locationTypeId\")\r\n );\r\n filterStringNvc.add(\r\n params.dataFormat,\r\n this.selectorsModel.get(\"dataFormatId\")\r\n );\r\n filterStringNvc.add(\r\n params.characteristic,\r\n this.selectorsModel.get(\"characteristicId\")\r\n );\r\n\r\n filterString = filterStringNvc.toQueryString();\r\n\r\n return filterString;\r\n },\r\n\r\n getDataParams: function(filterString) {\r\n return {\r\n filterString: filterString,\r\n numBreaks: window.ccc.viz.map.config.MapConfig.getNumBreaks()\r\n };\r\n },\r\n\r\n hasData: function() {\r\n return this.get(\"response\").hasData;\r\n }\r\n });\r\n})(_);\r\n","(function($, _) {\r\n var ns = nspace(\"ccc.viz.map.util.ChartRenderer\");\r\n\r\n ns.renderSparkline = function(\r\n chartContainer,\r\n xAxisCategories,\r\n dataSeries,\r\n displayValues,\r\n onAnimationCompleteCallback\r\n ) {\r\n return new Highcharts.Chart({\r\n chart: {\r\n renderTo: chartContainer,\r\n margin: [0, 0, 20, 0],\r\n backgroundColor: \"rgba(0, 0, 0, 0)\",\r\n borderWidth: 0\r\n },\r\n title: {\r\n text: null\r\n },\r\n credits: {\r\n enabled: false\r\n },\r\n xAxis: {\r\n maxPadding: 0.06,\r\n minPadding: 0.06,\r\n categories: xAxisCategories,\r\n endOnTick: true,\r\n lineWidth: 0,\r\n tickWidth: 0,\r\n labels: {\r\n enabled: true,\r\n align: \"center\",\r\n useHTML: true,\r\n formatter: function() {\r\n // Only show the first and last labels\r\n if (\r\n this.value === xAxisCategories[0] ||\r\n this.value === xAxisCategories[xAxisCategories.length - 1]\r\n ) {\r\n // We need to manually tweak the label positioning\r\n var style = \"\";\r\n if (this.value === xAxisCategories[0]) {\r\n style += \" left: 10px;\";\r\n }\n else {\r\n style += \" right: 10px;\";\r\n }\r\n\r\n return (\r\n \"
\" +\r\n this.value +\r\n \"
\"\r\n );\r\n }\r\n return null;\r\n }\r\n }\r\n },\r\n yAxis: {\r\n maxPadding: 0.12,\r\n minPadding: 0.12,\r\n labels: {\r\n enabled: false\r\n },\r\n gridLineWidth: 0,\r\n title: null\r\n },\r\n legend: {\r\n enabled: false\r\n },\r\n tooltip: {\r\n enabled: true,\r\n useHTML: true,\r\n borderWidth: 0,\r\n shadow: false,\r\n formatter: function() {\r\n return (\r\n \"
\" +\r\n this.x +\r\n \": \" +\r\n displayValues[this.x] +\r\n \"
\"\r\n );\r\n },\r\n style: {\r\n padding: 0\r\n },\r\n positioner: function(labelWidth, labelHeight, point) {\r\n return { x: point.plotX - labelWidth / 2, y: point.plotY - 50 };\r\n }\r\n },\r\n plotOptions: {\r\n series: {\r\n lineWidth: 2,\r\n shadow: false,\r\n states: {\r\n hover: {\r\n lineWidth: 2\r\n }\r\n },\r\n marker: {\r\n radius: 3,\r\n states: {\r\n hover: {\r\n radius: 4\r\n }\r\n }\r\n }\r\n }\r\n },\r\n series: [\r\n {\r\n color: \"#FE3D34\",\r\n data: dataSeries,\r\n animation: {\r\n complete: function() {\r\n if (onAnimationCompleteCallback) {\r\n onAnimationCompleteCallback();\r\n }\r\n }\r\n }\r\n }\r\n ]\r\n });\r\n };\r\n})(jQuery, _);\r\n","(function(google) {\r\n if (!google) {\r\n throw \"Google Maps API must be loaded before loading extensions\";\r\n }\r\n\r\n // From here: https://github.com/tparkin/Google-Maps-Point-in-Polygon/blob/master/maps.google.polygon.containsLatLng.js\r\n\r\n if (!google.maps.Polygon.prototype.getBounds) {\r\n google.maps.Polygon.prototype.getBounds = function(latLng) {\r\n //If this polygon has a bounding box assigned to it already\r\n if (this.boundingBox) {\r\n return this.boundingBox;\r\n }\r\n\r\n var bounds = new google.maps.LatLngBounds();\r\n var paths = this.getPaths();\r\n var path;\r\n\r\n for (var p = 0; p < paths.getLength(); p++) {\r\n path = paths.getAt(p);\r\n for (var i = 0; i < path.getLength(); i++) {\r\n bounds.extend(path.getAt(i));\r\n }\r\n }\r\n\r\n return bounds;\r\n };\r\n }\r\n\r\n if (!google.maps.Polygon.prototype.contains) {\r\n google.maps.Polygon.prototype.contains = function(latLng) {\r\n // Exclude points outside of bounds as there is no way they are in the poly\r\n var bounds = this.getBounds();\r\n\r\n if (bounds != null && !bounds.contains(latLng)) {\r\n return false;\r\n }\r\n\r\n // Raycast point in polygon method\r\n var inPoly = false;\r\n\r\n var numPaths = this.getPaths().getLength();\r\n for (var p = 0; p < numPaths; p++) {\r\n var path = this.getPaths().getAt(p);\r\n var numPoints = path.getLength();\r\n var j = numPoints - 1;\r\n\r\n for (var i = 0; i < numPoints; i++) {\r\n var vertex1 = path.getAt(i);\r\n var vertex2 = path.getAt(j);\r\n\r\n if (\r\n (vertex1.lng() < latLng.lng() && vertex2.lng() >= latLng.lng()) ||\r\n (vertex2.lng() < latLng.lng() && vertex1.lng() >= latLng.lng())\r\n ) {\r\n if (\r\n vertex1.lat() +\r\n ((latLng.lng() - vertex1.lng()) /\r\n (vertex2.lng() - vertex1.lng())) *\r\n (vertex2.lat() - vertex1.lat()) <\r\n latLng.lat()\r\n ) {\r\n inPoly = !inPoly;\r\n }\r\n }\r\n\r\n j = i;\r\n }\r\n }\r\n\r\n return inPoly;\r\n };\r\n }\r\n})(google);\r\n","/// \r\n\r\n(function($, Proj4js, google) {\r\n var ns = nspace(\"ccc.viz.map.util\");\r\n\r\n var wgs84Coords = new Proj4js.Proj(\"WGS84\");\r\n var epsg3857Coords = new Proj4js.Proj(\"GOOGLE\");\r\n\r\n // These regexes and the WKT polygon parsing code is roughly based off code found in OpenLayers\r\n // https://github.com/openlayers/openlayers/blob/master/lib/OpenLayers/Format/WKT.js\r\n var regExes = {\r\n typeStr: /^\\s*(\\w+)\\s*\\(\\s*(.*)\\s*\\)\\s*$/,\r\n parenComma: /\\)\\s*,\\s*\\(/,\r\n doubleParenComma: /\\)\\s*\\)\\s*,\\s*\\(\\s*\\(/,\r\n trimParens: /^\\s*\\(?(.*?)\\)?\\s*$/\r\n };\r\n\r\n function getPolygonLatLngs(coords) {\r\n // Expects polygon text that looks like this:\r\n // -12211621.104157 4438929.90942386, ... , -12212798.9101653 4438929.90942386\r\n\r\n // split into coord pairs\r\n var pairs = coords.split(\", \");\r\n var latLngs = [];\r\n for (var i = 0; i < pairs.length; i++) {\r\n // create a new LatLng from each pair\r\n var parts = pairs[i].split(\" \");\r\n var lat = parseFloat(parts[1]);\r\n var lng = parseFloat(parts[0]);\r\n\r\n latLngs.push(new google.maps.LatLng(lat, lng));\r\n }\r\n\r\n return latLngs;\r\n }\r\n\r\n function parsePolygon(text) {\r\n var paths = [];\r\n var rings = $.trim(text).split(regExes.parenComma);\r\n for (var i = 0, len = rings.length; i < len; ++i) {\r\n var ring = rings[i].replace(regExes.trimParens, \"$1\");\r\n paths.push(getPolygonLatLngs(ring));\r\n }\r\n\r\n return paths;\r\n }\r\n\r\n function parseMultiPolygon(text) {\r\n var polygon;\r\n var polygons = $.trim(text).split(regExes.doubleParenComma);\r\n var paths = [];\r\n for (var i = 0, len = polygons.length; i < len; ++i) {\r\n polygon = polygons[i].replace(regExes.trimParens, \"$1\");\r\n var polyPaths = parsePolygon(polygon);\r\n for (var j = 0; j < polyPaths.length; j++) {\r\n paths.push(polyPaths[j]);\r\n }\r\n }\r\n return paths;\r\n }\r\n\r\n ns.MapUtil = {\r\n /**\r\n * Translates latitude and longitude into screen pixel coordinates relative to the map container\r\n */\r\n fromPositionToRelativePixels: function(gmap, position) {\r\n var scale = Math.pow(2, gmap.getZoom());\r\n var worldXY = new google.maps.LatLng(\r\n gmap\r\n .getBounds()\r\n .getNorthEast()\r\n .lat(),\r\n gmap\r\n .getBounds()\r\n .getSouthWest()\r\n .lng()\r\n );\r\n var worldEdge = gmap.getProjection().fromLatLngToPoint(worldXY);\r\n var worldPosition = gmap.getProjection().fromLatLngToPoint(position);\r\n\r\n return {\r\n x: Math.floor((worldPosition.x - worldEdge.x) * scale),\r\n y: Math.floor((worldPosition.y - worldEdge.y) * scale)\r\n };\r\n },\r\n\r\n /**\r\n * Converts a latitude/longitude in EPSG 3857 (web mercator meters) to wgs84 (degrees)\r\n */\r\n epsg3857ToWgs84: function(lat, lng) {\r\n var p = new Proj4js.Point(lng, lat);\r\n Proj4js.transform(epsg3857Coords, wgs84Coords, p);\r\n return new google.maps.LatLng(p.y, p.x);\r\n },\r\n\r\n /**\r\n * Converts a google Point in wgs84 (degrees) to EPSG 3857 (web mercator meters)\r\n */\r\n wgs84ToEpsg3857: function(googlePoint) {\r\n var p = new Proj4js.Point(googlePoint.lng(), googlePoint.lat());\r\n Proj4js.transform(wgs84Coords, epsg3857Coords, p);\r\n return p;\r\n },\r\n\r\n /**\r\n * Converts a polygon in WKT format (Well Known Text) into a google maps polygon\r\n */\r\n wktToGooglePolygon: function(wktPolygon) {\r\n // WKT Polygon examples available here: http://en.wikipedia.org/wiki/Well-known_text\r\n\r\n var paths = [];\r\n\r\n wktPolygon = wktPolygon.replace(/[\\n\\r]/g, \" \");\r\n var matches = regExes.typeStr.exec(wktPolygon);\r\n if (matches) {\r\n var type = matches[1].toLowerCase();\r\n var text = matches[2];\r\n if (type === \"multipolygon\") {\r\n paths = parseMultiPolygon(text);\r\n }\n else if (type === \"polygon\") {\r\n paths = parsePolygon(text);\r\n }\n else {\r\n throw \"Unrecognized feature type: \" + type;\r\n }\r\n }\r\n\r\n // create a polygon from the LatLngs\r\n var polygon = new google.maps.Polygon({\r\n paths: paths,\r\n fillColor: \"#eee\",\r\n fillOpacity: 0.9,\r\n strokeColor: \"#e2ecec\",\r\n strokeWeight: 1\r\n });\r\n\r\n return polygon;\r\n }\r\n };\r\n})(jQuery, Proj4js, google);\r\n","/// \r\n/// \r\n/// \r\n/// \r\n/// \r\n/// \r\n\r\n(function($, _, velir, google) {\r\n var ns = window.nspace(\"ccc.viz.map.views\");\r\n\r\n var pushNycClick = function(response, selectedFips) {\r\n var location = \"New York City\";\r\n if (\r\n selectedFips &&\r\n response &&\r\n response.locationsByFips &&\r\n response.locationsByFips[selectedFips]\r\n ) {\r\n location = response.locationsByFips[selectedFips].name || \"New York City\";\r\n }\r\n\r\n // Tracks if user clicks on the map on the \"Explore Data\" page\r\n dataLayer.push({\r\n event: \"Explore Map Clicks\",\r\n eventCategory: \"Interactive Clicks\",\r\n eventAction: \"Explore Map|\" + location,\r\n eventLabel: window.location.pathname\r\n });\r\n };\r\n\r\n ns.GoogleMapView = Backbone.View.extend({\r\n el: \"#gmap-container\",\r\n\r\n initialize: function(options) {\r\n this.initialRenderPromise = $.Deferred();\r\n\r\n var self = this;\r\n\r\n _.bindAll(\r\n this,\r\n \"render\",\r\n \"findAndDrawPolygon\",\r\n \"preLoadPolygons\",\r\n \"selectRegion\",\r\n \"drawSelectedRegion\"\r\n );\r\n\r\n this.dispatcher = options.dispatcher;\r\n this.polygonManager = ccc.viz.map.layers.PolygonManager;\r\n this.currentMouseover = {};\r\n this.dataResponseModel = options.dataResponseModel;\r\n this.initializeMap();\r\n\r\n // When the user's selections change, rerender the map\r\n this.model.on(\"change\", this.render);\r\n\r\n // When the location type ID changes, pre load the new polygons\r\n this.model.on(\"change:locationTypeId\", this.preLoadPolygons);\r\n\r\n // When the selectedFips changes, redraw the highlighted polygon\r\n this.model.on(\"change:selectedFips\", this.drawSelectedRegion);\r\n\r\n // Prevent mouseover popups from getting \"stuck\" when quickly mousing off the map\r\n this.$el.on(\"mouseleave\", function() {\r\n // Remove any previously drawn polygon\r\n if (self.currentMouseover && self.currentMouseover.polygon) {\r\n self.currentMouseover.polygon.setMap(null);\r\n self.currentMouseover = null;\r\n }\r\n self.dispatcher.trigger(\"mouseoff-region\");\r\n });\r\n\r\n // The above change event isn't emitted upon initialization (only on subsequent changes)\r\n // so manually trigger initial draw\r\n this.drawSelectedRegion();\r\n },\r\n\r\n getInitialRenderPromise: function() {\r\n return this.initialRenderPromise;\r\n },\r\n\r\n initializeMap: function() {\r\n var self = this;\r\n\r\n // GMap styles\r\n var styles = [\r\n {\r\n featureType: \"water\",\r\n elementType: \"geometry\",\r\n stylers: [{ color: \"#8d8d8d\" }, { lightness: 17 }]\r\n },\r\n {\r\n featureType: \"landscape\",\r\n elementType: \"geometry\",\r\n stylers: [{ color: \"#f5f5f5\" }, { lightness: 20 }]\r\n },\r\n {\r\n featureType: \"road.highway\",\r\n elementType: \"geometry.fill\",\r\n stylers: [{ color: \"#ffffff\" }, { lightness: 17 }]\r\n },\r\n {\r\n featureType: \"road.highway\",\r\n elementType: \"geometry.stroke\",\r\n stylers: [{ color: \"#ffffff\" }, { lightness: 29 }, { weight: 0.2 }]\r\n },\r\n {\r\n featureType: \"road.arterial\",\r\n elementType: \"geometry\",\r\n stylers: [{ color: \"#ffffff\" }, { lightness: 18 }]\r\n },\r\n {\r\n featureType: \"road.local\",\r\n elementType: \"geometry\",\r\n stylers: [{ color: \"#ffffff\" }, { lightness: 16 }]\r\n },\r\n {\r\n featureType: \"poi\",\r\n elementType: \"geometry\",\r\n stylers: [{ color: \"#f5f5f5\" }, { lightness: 21 }]\r\n },\r\n {\r\n featureType: \"poi.park\",\r\n elementType: \"geometry\",\r\n stylers: [{ color: \"#dedede\" }, { lightness: 21 }]\r\n },\r\n {\r\n elementType: \"labels.text.stroke\",\r\n stylers: [\r\n { visibility: \"on\" },\r\n { color: \"#ffffff\" },\r\n { lightness: 16 }\r\n ]\r\n },\r\n {\r\n elementType: \"labels.text.fill\",\r\n stylers: [{ saturation: 36 }, { color: \"#333333\" }, { lightness: 40 }]\r\n },\r\n { elementType: \"labels.icon\", stylers: [{ visibility: \"off\" }] },\r\n {\r\n featureType: \"transit\",\r\n elementType: \"geometry\",\r\n stylers: [{ color: \"#f2f2f2\" }, { lightness: 19 }]\r\n },\r\n {\r\n featureType: \"administrative\",\r\n elementType: \"geometry.fill\",\r\n stylers: [{ color: \"#fefefe\" }, { lightness: 20 }]\r\n },\r\n {\r\n featureType: \"administrative\",\r\n elementType: \"geometry.stroke\",\r\n stylers: [{ color: \"#fefefe\" }, { lightness: 17 }, { weight: 1.2 }]\r\n }\r\n ];\r\n\r\n var config = ccc.viz.map.config.MapConfig;\r\n\r\n var mapOptions = {\r\n // Show NYC upon load\r\n center: new google.maps.LatLng(40.72332, -74.0039),\r\n zoom: 10,\r\n\r\n // Roadmap\r\n mapTypeId: google.maps.MapTypeId.ROADMAP,\r\n\r\n // Map Controls\r\n panControl: false,\r\n mapTypeControl: false,\r\n scaleControl: false,\r\n streetViewControl: false,\r\n overviewMapControl: false,\r\n zoomControlOptions: {\r\n position: google.maps.ControlPosition.RIGHT_CENTER\r\n },\r\n scrollwheel: false,\r\n\r\n // Min/max zoom\r\n minZoom: config.minZoom,\r\n maxZoom: config.maxZoom,\r\n\r\n // So stylee!\r\n styles: styles\r\n };\r\n\r\n // Notify other components that we're about to load the map\r\n this.gmapLoading = $.Deferred();\r\n this.dispatcher.trigger(\"gmap-busy\");\r\n this.dispatcher.trigger(\"add-task\", {\r\n name: \"gmap-loading\",\r\n text: \"Loading base map...\"\r\n });\r\n\r\n // Load the map\r\n this.gmap = new google.maps.Map(this.$el[0], mapOptions);\r\n\r\n\t\t\tthis.labelEngine = new CCCLabelEngine(this.gmap);\r\n\r\n // Listen for the map to finish loading and emit an event. Map MUST finish loading before a choropleth overlay can be added,\r\n // otherwise no map projection will be set.\r\n google.maps.event.addListenerOnce(this.gmap, \"idle\", function() {\r\n self.gmapLoading.resolve();\r\n self.dispatcher.trigger(\"gmap-idle\");\r\n self.dispatcher.trigger(\"end-task\", { name: \"gmap-loading\" });\r\n\r\n\r\n\t\t\t\t// Google Maps seems to like to refresh the map markers when panning the map\r\n\t\t\t\t// This causes the MarkerWithLabels' class list to get reset to the initial provided values\r\n\t\t\t\t// There doesn't seem to be a good way to prevent this and keep the markers displayed while panning\r\n\t\t\t\t// For now, just re-render the markers on idle (finished panning/zooming/toggling full screen)\r\n\t\t\t\tself.renderLabels();\r\n\t\t\t\tgoogle.maps.event.addListener(self.gmap, 'idle', () => self.renderLabels());\r\n });\r\n\r\n // Listen for the mouse to move over the map and draw polygons as necessary\r\n google.maps.event.addListener(\r\n this.gmap,\r\n \"mousemove\",\r\n self.findAndDrawPolygon\r\n );\r\n\r\n // Listen for clicks on the map and select the clicked region\r\n google.maps.event.addListener(this.gmap, \"click\", self.selectRegion);\r\n },\r\n\r\n\t\trenderLabels: function(takeScreenshot) {\t\t\t\r\n\t\t\tthis.labelEngine.renderLabels(this.overlayMarkers, this.addLoadingLabelsTask(), this.updateLabelsTaskDone(takeScreenshot));\r\n\t\t},\r\n\r\n\t\taddLoadingLabelsTask: function() {\r\n\t\t\tvar self = this;\r\n\t\t\treturn () => {\r\n\t\t\t\tself.dispatcher.trigger(\"add-task\", { name: \"choropleth-labels-loading\", text: \"Loading labels...\" });\r\n\t\t\t};\r\n\t\t},\r\n\r\n\t\tupdateLabelsTaskDone: function(takeScreenshot) {\r\n\t\t\tvar self = this;\t\t\t\r\n\t\t\treturn () => {\r\n self.dispatcher.trigger(\"end-all-tasks\", { name: \"choropleth-labels-loading\" });\r\n \r\n if (takeScreenshot && window.triggerScreenshot instanceof Function) {\r\n window.triggerScreenshot();\r\n }\r\n\t\t\t};\r\n\t\t},\r\n\r\n preLoadPolygons: function() {\r\n this.polygonManager.loadPolygons(this.model.get(\"locationTypeId\"));\r\n },\r\n\r\n render: function() {\r\n var self = this;\r\n\r\n // The above \"change:locationTypeId\" event isn't emitted upon initialization (only on subsequent changes)\r\n // so manually trigger polygon preloading\r\n this.preLoadPolygons();\r\n\r\n $.when(this.gmapLoading).done(function() {\r\n // Don't bother re-rendering if the only change was to the selectedFips. That's handled elsewhere.\r\n if (\r\n _.size(self.model.changed) === 1 &&\r\n self.model.changed.hasOwnProperty(\"selectedFips\")\r\n ) {\r\n return;\r\n }\r\n\r\n // Assemble a filter string from the model\r\n var parms = ccc.viz.util.UrlParams;\r\n\r\n var filterString = new velir.collections.NameValueCollection();\r\n filterString.add(parms.indicator, self.model.get(\"indicatorId\"));\r\n filterString.add(parms.timeFrame, self.model.get(\"timeFrameId\"));\r\n filterString.add(parms.locationType, self.model.get(\"locationTypeId\"));\r\n filterString.add(parms.dataFormat, self.model.get(\"dataFormatId\"));\r\n filterString.add(\r\n parms.characteristic,\r\n self.model.get(\"characteristicId\")\r\n );\r\n\r\n self.updateChoropleth(filterString.toQueryString());\r\n });\r\n },\r\n\r\n\t\toverlayMarkers: null,\r\n\t\tremoveOverlayMarkers: function () {\r\n\t\t\t// Remove old markers\r\n\t\t\tif (this.overlayMarkers) {\r\n\t\t\t\tfor (var index in this.overlayMarkers) {\r\n\t\t\t\t\tvar marker = this.overlayMarkers[index];\r\n\t\t\t\t\tif (marker && marker.setMap) {\r\n\t\t\t\t\t\tmarker.setMap(null);\r\n\t\t\t\t\t}\r\n\t\t\t\t}\r\n\t\t\t}\r\n\t\t},\r\n\r\n\t\tsetLabelTimeout: function(cb) {\r\n\t\t\t// Google maps renders map markers (like our labels) asynchronously\r\n\t\t\t// There's no event to tell when it's done - \"idle\" doesn't work\r\n\t\t\t// So we just have to wait, based on how many markers there are\r\n\t\t\tvar delayPerMarker = 13; // 10 works fine, but include a buffer\r\n\t\t\tvar delayLength = this.overlayMarkers.length * delayPerMarker;\r\n\t\t\tconsole.debug('delayLength', delayLength);\r\n\t\t\tsetTimeout(cb, delayLength);\r\n\t\t},\r\n\r\n\t\tgetOverlayLabels: function () {\r\n\t\t\tconsole.debug('getOverlayLabels start');\r\n\t\t\tlet self = this;\r\n\t\t\tself.removeOverlayMarkers();\r\n\r\n\t\t\tconst zipcodesOverlayTypeId = '4';\r\n\t\t\tvar labelClasslist = \"overlay-label overlay-label--hidden\"; // Hide labels until we're ready, once LabelGun prunes the overlapping ones\r\n\t\t\tvar overlayTypeIds = self.model.get(\"overlays\");\r\n\t\t\tif (overlayTypeIds === zipcodesOverlayTypeId ||\r\n\t\t\t\t(overlayTypeIds instanceof Array && overlayTypeIds.indexOf(zipcodesOverlayTypeId) >= 0)) {\r\n\t\t\t\tlabelClasslist += \" overlay-label--small\"; // Use smaller font for zipcodes\r\n\t\t\t}\r\n\r\n\t\t\t// global\r\n\t\t\tvar hardcodedPositions = hardcodedPositionsByOverlayTypeAndFips;\r\n\t\t\t$.get('/api/MapData/GetWktOverlayPolygons?overlays=' + self.model.get(\"overlays\")).done(function successCallback(response) {\r\n\t\t\t\t// Remove references to the marker objects as late as possible\r\n\t\t\t\t// Doing this too soon results in orphaned markers after zooming\r\n\t\t\t\t// This is because Google's setMap() is asynchronous\r\n\t\t\t\t// See removeOverlayMarkers()\r\n\t\t\t\tself.overlayMarkers = [];\r\n\r\n\t\t\t\t// Parse out the WKT text into google API Polygons\r\n\t\t\t\tfor (var key in response) {\r\n\t\t\t\t\tvar tokens = key.split('|');\r\n\t\t\t\t\tvar overlayType = tokens[0];\r\n\t\t\t\t\tvar fips = tokens[1];\r\n\t\t\t\t\tvar labelContent = tokens[2];\r\n\r\n\t\t\t\t\tvar wktPolygon = response[key];\r\n\r\n\t\t\t\t\tvar polygon = ccc.viz.map.util.MapUtil.wktToGooglePolygon(wktPolygon);\r\n\r\n\t\t\t\t\t// Add label marker for the polygon\r\n\t\t\t\t\tvar noIcon = {\r\n\t\t\t\t\t\t// Workaround to have a label with no icon\r\n\t\t\t\t\t\tpath: google.maps.SymbolPath.CIRCLE,\r\n\t\t\t\t\t\tscale: 0\r\n\t\t\t\t\t};\t\t\t\t\t\t\t\r\n\t\t\t\t\t\r\n\t\t\t\t\t// account for label text itself\r\n\t\t\t\t\tvar labelXOffset = 5 + fips.length * 4;\r\n\t\t\t\t\tvar labelYOffset = 15;\r\n\t\t\t\t\tvar labelAnchor = new google.maps.Point(labelXOffset, labelYOffset);\r\n\t\t\t\t\t\r\n\t\t\t\t\t// hardcoded positions\r\n\t\t\t\t\tvar positions;\r\n\t\t\t\t\tif (hardcodedPositions && hardcodedPositions[overlayType]) {\r\n\t\t\t\t\t\tpositions = hardcodedPositions[overlayType][fips];\r\n\t\t\t\t\t}\r\n\t\t\t\t\t\r\n\t\t\t\t\tif (!positions || !positions.length) {\r\n\t\t\t\t\t\t// Just need one label - position over geometric center\r\n\t\t\t\t\t\tvar center = polygon.getBounds().getCenter();\r\n\t\t\t\t\t\tself.overlayMarkers.push(new MarkerWithLabel({\r\n\t\t\t\t\t\t\tmap: self.gmap,\r\n\t\t\t\t\t\t\tposition: center,\r\n\t\t\t\t\t\t\ticon: noIcon,\r\n\t\t\t\t\t\t\tlabelContent: labelContent,\r\n\t\t\t\t\t\t\tlabelAnchor: labelAnchor,\r\n\t\t\t\t\t\t\tlabelClass: labelClasslist\r\n\t\t\t\t\t\t}));\r\n\t\t\t\t\t}\r\n\t\t\t\t\telse {\r\n\t\t\t\t\t\tpositions.forEach(position => {\r\n\t\t\t\t\t\t\t// Hardcoded positions, and possibly multiple labels for gerrymandered/multipolygon locations\r\n\t\t\t\t\t\t\tself.overlayMarkers.push(new MarkerWithLabel({\r\n\t\t\t\t\t\t\t\tmap: self.gmap,\r\n\t\t\t\t\t\t\t\tposition: new google.maps.LatLng(position[0], position[1]),\r\n\t\t\t\t\t\t\t\ticon: noIcon,\r\n\t\t\t\t\t\t\t\tlabelContent: labelContent,\r\n\t\t\t\t\t\t\t\tlabelAnchor: labelAnchor,\r\n\t\t\t\t\t\t\t\tlabelClass: labelClasslist\r\n\t\t\t\t\t\t\t}));\r\n\t\t\t\t\t\t});\r\n\t\t\t\t\t}\r\n\t\t\t\t} // foreach key in response\r\n\r\n\t\t\t\tself.renderLabels(true);\r\n\r\n\t\t\t\tconsole.debug('getOverlayLabels end');\r\n\t\t\t}) // $.get().done()\r\n\t\t\t.fail(function errorCallback(err) {\r\n\t\t\t\tconsole.error('Failed to get overlay label data. ', err);\r\n\t\t\t}); // $.get()\r\n\t\t}, // getOverlayLabels()\r\n\r\n updateChoropleth: function(filterString) {\r\n var self = this;\r\n\r\n // Assume the choropleth layer is the bottom-most overlay. Remove the old layer\r\n if (this.gmap.overlayMapTypes.length > 0) {\r\n this.gmap.overlayMapTypes.removeAt(0);\r\n }\r\n\r\n // Add a new layer\r\n this.choroplethOverlay = new ccc.viz.map.layers.ChoroplethMapType(\r\n this.gmap.getProjection(),\r\n filterString,\r\n self.model.get(\"overlays\")\r\n );\r\n this.gmap.overlayMapTypes.push(this.choroplethOverlay);\r\n\r\n\t\t\tself.getOverlayLabels();\r\n\r\n // Emit an event whenever the layer is busy\r\n $(this.choroplethOverlay).bind(\"busy\", function() {\r\n self.dispatcher.trigger(\"add-task\", {\r\n name: \"choropleth-overlay-busy\",\r\n text: \"Updating data overlay...\"\r\n });\r\n });\r\n\r\n // Emit an event when the layer finishes loading\r\n $(this.choroplethOverlay).bind(\"idle\", function() {\r\n self.dispatcher.trigger(\"end-all-tasks\", {\r\n name: \"choropleth-overlay-busy\"\r\n });\r\n self.initialRenderPromise.resolve();\r\n });\r\n },\r\n\r\n findAndDrawPolygon: function(mouseEvent) {\r\n var self = this;\r\n\r\n var locTypeId = self.model.get(\"locationTypeId\");\r\n this.polygonManager.findPolygon(locTypeId, mouseEvent.latLng, function(\r\n polygonInfo\r\n ) {\r\n function removePrevious() {\r\n // Remove any previously drawn polygon\r\n if (self.currentMouseover && self.currentMouseover.polygon) {\r\n self.currentMouseover.polygon.setMap(null);\r\n self.currentMouseover = null;\r\n }\r\n }\r\n\r\n // Not over a polygon currently?\r\n if (polygonInfo == null) {\r\n removePrevious();\r\n self.dispatcher.trigger(\"mouseoff-region\");\r\n return;\r\n }\r\n\r\n // Over a polygon? Is it still the same one?\r\n if (\r\n self.currentMouseover &&\r\n polygonInfo.fips == self.currentMouseover.fips\r\n ) {\r\n // Nothing to do\r\n return;\r\n }\r\n\r\n // Over a polygon, but NOT the same one? Remove the previous and draw the new!\r\n removePrevious();\r\n polygonInfo.polygon.setOptions(\r\n ccc.viz.map.config.MapConfig.mouseoverPolygonStyle\r\n );\r\n polygonInfo.polygon.setMap(self.gmap);\r\n\r\n // Events don't propagate\r\n google.maps.event.addListener(\r\n polygonInfo.polygon,\r\n \"click\",\r\n self.selectRegion\r\n );\r\n self.currentMouseover = polygonInfo;\r\n self.dispatcher.trigger(\"mouseover-region\", {\r\n latLng: mouseEvent.latLng,\r\n gmap: self.gmap,\r\n fips: polygonInfo.fips\r\n });\r\n });\r\n },\r\n\r\n selectRegion: function(mouseEvent) {\r\n var self = this;\r\n\r\n // Figure out where the user clicked and highlight/dehighlight regions as necessary\r\n var locTypeId = self.model.get(\"locationTypeId\");\r\n this.polygonManager.findPolygon(locTypeId, mouseEvent.latLng, function(\r\n polygonInfo\r\n ) {\r\n // Update the model\r\n var selectedFips = polygonInfo == null ? null : polygonInfo.fips;\r\n\r\n // If we clicked on NYC data, don't show anything else, since NYC data is already showing.\r\n if (+selectedFips === ccc.viz.map.config.MapConfig.nycFips) {\r\n $(\".legend-column\")\r\n .stop(true, true)\r\n .hide()\r\n .fadeIn();\r\n return;\r\n }\r\n\r\n self.model.set(\"selectedFips\", selectedFips);\r\n\r\n var response = self.dataResponseModel.get(\"response\");\r\n self.debounceExploreMapClicks(response, selectedFips);\r\n });\r\n },\r\n\r\n debounceExploreMapClicks: _.debounce(pushNycClick, 100),\r\n\r\n drawSelectedRegion: function() {\r\n var self = this;\r\n\r\n function removePrevious() {\r\n // Remove the polygon for the previously selected region, if any\r\n if (self.selectedPolygonInfo) {\r\n self.selectedPolygonInfo.innerPolygon.setMap(null);\r\n self.selectedPolygonInfo.outerPolygon.setMap(null);\r\n self.selectedPolygonInfo = null;\r\n }\r\n }\r\n\r\n // Anything selected?\r\n // NOTE: \"a\" is the default value in the URL for when a parameter is absent. That _shouldn't_\r\n // NOTE: won't collide with any actual FIPS values. Probably.\r\n var fips = this.model.get(\"selectedFips\");\r\n if (fips == null || fips == \"a\") {\r\n removePrevious();\r\n return;\r\n }\r\n\r\n // We have something selected, but was it already selected?\r\n if (self.selectedPolygonInfo && self.selectedPolygonInfo.fips === fips) {\r\n // Nothing to do\r\n return;\r\n }\r\n\r\n // New selection. Find the polygon for the selected fips and draw it\r\n var locTypeId = self.model.get(\"locationTypeId\");\r\n this.polygonManager.getPolygonByFips(locTypeId, fips, function(\r\n polygonInfo\r\n ) {\r\n if (!polygonInfo) {\r\n throw \"Could not find polygon for FIPS: \" + fips;\r\n }\r\n\r\n // PolygonManager returns the same polygon instance every time, so clone the polygon\r\n // so that it's a different instance than the one drawn for mouseovers\r\n polygonInfo.innerPolygon = self.polygonManager.clonePolygon(\r\n polygonInfo.polygon\r\n );\r\n polygonInfo.outerPolygon = self.polygonManager.clonePolygon(\r\n polygonInfo.polygon\r\n );\r\n\r\n // Draw it\r\n removePrevious();\r\n polygonInfo.innerPolygon.setOptions(\r\n ccc.viz.map.config.MapConfig.selectedPolygonInnerStyle\r\n );\r\n polygonInfo.innerPolygon.setMap(self.gmap);\r\n polygonInfo.outerPolygon.setOptions(\r\n ccc.viz.map.config.MapConfig.selectedPolygonOuterStyle\r\n );\r\n polygonInfo.outerPolygon.setMap(self.gmap);\r\n self.selectedPolygonInfo = polygonInfo;\r\n });\r\n }\r\n });\r\n})(jQuery, _, velir, google);\r\n","(function($, _) {\r\n var ns = window.nspace(\"ccc.viz.map.views\");\r\n\r\n ns.LegendView = Backbone.View.extend({\r\n\t\tel: \".legend-container\",\r\n name: \"Map Legend\",\r\n templateSelector: \"#map-legend-template\",\r\n\r\n initialize: function() {\r\n this.initialRenderPromise = $.Deferred();\r\n\r\n var self = this;\r\n _.bindAll(this, \"render\");\r\n\r\n this.model.on(\"change\", this.render);\r\n\r\n // Hide the legend text when a data update begins\r\n this.model.on(\"busy\", function() {\r\n self.$el.hide();\r\n });\r\n\r\n // Show/hide the legend when the \"+/-\" button is clicked\r\n this.$el.on(\"click\", \".icon-map-overlay-control\", function(e) {\r\n e.preventDefault();\r\n\r\n\t\t\t\tvar $content = $(\".map-overlay-content\", $(e.target).parents('.map-overlay-block'));\r\n if (self.isClosed) {\r\n // Show it\r\n\t\t\t\t\t$content.parent().removeClass(\"closed\");\r\n $content.slideDown();\r\n self.isClosed = false;\r\n }\r\n else {\r\n // Hide it\r\n $content.slideUp(400, function() {\r\n\t\t\t\t\t\t$content.parent().addClass(\"closed\");\r\n });\r\n self.isClosed = true;\r\n }\r\n\t\t\t});\r\n\r\n\t\t\t// Boundary overlay radios\r\n\t\t\t$('.boundary-radio-hidden, .boundary-radio-hidden::before, .boundary-overlay-list label').click(function (e) {\r\n\t\t\t\t$('.boundary-radio-hidden').each(function (_index, radio) {\r\n\t\t\t\t\t$(radio).prop('checked', null);\r\n\t\t\t\t});\r\n\r\n\t\t\t\tvar $hiddenRadio = $('.boundary-radio-hidden', $(e.target).parents('li'));\r\n\t\t\t\t$hiddenRadio.prop('checked', true);\r\n\t\t\t\tvar radioVal = $hiddenRadio.val();\r\n\t\t\t\tvar overlayVals = radioVal\r\n\t\t\t\t\t? [radioVal]\r\n\t\t\t\t\t: null;\r\n\t\t\t\tself.model.selectorsModel.set('overlays', overlayVals);\r\n\t\t\t\r\n\t\t\t\te.preventDefault();\r\n\t\t\t\te.stopPropagation();\r\n });\r\n },\r\n\r\n getInitialRenderPromise: function() {\r\n return this.initialRenderPromise;\r\n },\r\n\r\n render: function() {\r\n var self = this;\r\n\r\n // Verify this selector's container is present\r\n if (this.$el.length === 0) {\r\n throw \"Could not find the \" + this.name + \" container: \" + this.el;\r\n }\r\n\r\n // Get the underscore template\r\n if (!this.template) {\r\n var $tmpl = $(this.templateSelector);\r\n if ($tmpl.length === 0) {\r\n throw \"Could not find the \" +\r\n this.name +\r\n \" template: \" +\r\n this.templateSelector;\r\n }\r\n\r\n // Pre-compile and cache the template\r\n this.template = _.template($tmpl.html());\r\n }\r\n\t\t\t\r\n\t\t\tvar overlay = self.model.selectorsModel.get('overlays');\r\n\t\t\tif (overlay) {\r\n\t\t\t\t// Update boundary overlay legend so it reflects the model\r\n\t\t\t\tvar overlayId = Array.isArray(overlay)\r\n\t\t\t\t\t? overlay[0]\r\n\t\t\t\t\t: overlay.toString().split(',')[0]; \r\n\t\t\t\t$('.boundary-radio-hidden[value=\"' + overlayId + '\"]')\r\n\t\t\t\t\t.prop('checked', true);\r\n\t\t\t}\r\n // Pull the data summary from the global selector instance.\r\n var summary = ccc.viz.map.views.instances.SelectorsView.getDataSummaryByPropertyNames(\r\n [\"indicatorId\"]\r\n );\r\n var response = this.model.get(\"response\");\r\n if (_.str.isBlank(summary)) {\r\n summary = response.indicatorGroupName;\r\n }\r\n\r\n var largerValuesAre = response.largerValuesAre;\r\n\r\n var themeColors = ccc.viz.map.config.MapConfig.themeColors.slice();\r\n\r\n if (largerValuesAre == \"worse\" || largerValuesAre == \"neutral\") {\r\n themeColors = themeColors.reverse();\r\n }\r\n\r\n // Re-render the control\r\n var legendInfo = _.extend(\r\n {\r\n title: summary,\r\n themeColors: themeColors,\r\n largerValuesAre: largerValuesAre\r\n },\r\n response\r\n );\r\n\r\n // Allow the container to resize to fit content once again\r\n this.$el.css(\"height\", \"auto\");\r\n this.$el.css(\"width\", \"auto\");\r\n\r\n // Insert the new HTML\r\n\t\t\t$('.map-legend-container').remove();\r\n\t\t\tthis.$el.prepend(this.template(legendInfo));\r\n\r\n // Show it\r\n if (this.isClosed) {\r\n $(\".map-overlay-content\", self.el).hide();\r\n }\r\n this.$el.fadeIn(600, function() {\r\n self.initialRenderPromise.resolve();\r\n });\r\n }\r\n });\r\n})(jQuery, _);\r\n","(function($, _) {\r\n var ns = window.nspace(\"ccc.viz.map.views\");\r\n\r\n /**\r\n * Figures out which legend range this data point falls into\r\n */\r\n function findThemeColor(dataPoint, ranges, largerValuesAre) {\r\n for (var i = 0; i < ranges.length; i++) {\r\n var range = ranges[i];\r\n var min = parseFloat(range.minValue);\r\n var max = parseFloat(range.maxValue);\r\n var dp = parseFloat(dataPoint);\r\n\r\n // Assumes non-continuous legend breaks\r\n if (min <= dp && max >= dp) {\r\n break;\r\n }\r\n }\r\n\r\n if (i >= ranges.length) {\r\n i = ranges.length - 1;\r\n }\r\n\r\n var themeColors = ccc.viz.map.config.MapConfig.themeColors.slice();\r\n\r\n if (largerValuesAre == \"worse\" || largerValuesAre == \"neutral\") {\r\n return themeColors.reverse()[i].color;\r\n }\r\n else {\r\n return themeColors[i].color;\r\n }\r\n }\r\n\r\n /**\r\n * Displays a popup with a data point when mouse is hovering over a location\r\n */\r\n ns.MapPopupView = Backbone.View.extend({\r\n el: \"#map-popup-container\",\r\n templateSelector: \"#map-popup-template\",\r\n name: \"Map Popup\",\r\n\r\n initialize: function(options) {\r\n _.bindAll(this, \"showPopup\", \"hidePopup\", \"loadTemplate\");\r\n\r\n this.selectorsModel = options.selectorsModel;\r\n\r\n this.dispatcher = options.dispatcher;\r\n this.dispatcher.on(\"mouseoff-region\", this.hidePopup);\r\n this.dispatcher.on(\"mouseover-region\", this.showPopup);\r\n\r\n this.offset = {\r\n x: 0,\r\n y: 30\r\n };\r\n },\r\n\r\n loadTemplate: function() {\r\n // Get the underscore template\r\n if (!this.template) {\r\n var $tmpl = $(this.templateSelector);\r\n if ($tmpl.length === 0) {\r\n throw \"Could not find the \" +\r\n this.name +\r\n \" template: \" +\r\n this.templateSelector;\r\n }\r\n\r\n // Pre-compile and cache the template\r\n this.template = _.template($tmpl.html());\r\n }\r\n },\r\n\r\n /**\r\n * Hides the map popup\r\n */\r\n hidePopup: function(args) {\r\n this.$el.hide();\r\n },\r\n\r\n /**\r\n * Displays the map popup\r\n */\r\n showPopup: function(args) {\r\n this.loadTemplate();\r\n\r\n var self = this;\r\n\r\n // Get the data to display\r\n var fips = args.fips;\r\n $.when(this.model.getDataResponse()).done(function() {\r\n var response = self.model.get(\"response\");\r\n var tfId = self.selectorsModel.get(\"timeFrameId\");\r\n var allYearsData = response.dataByFips[fips];\r\n var data = !allYearsData\r\n ? null\r\n : _.find(allYearsData, function(yearData) {\r\n return yearData.timeFrameId === tfId;\r\n });\r\n\r\n var location = response.locationsByFips[fips];\r\n\r\n var largerValuesAre = response.largerValuesAre;\r\n\r\n // Defaults\r\n var templateData = {\r\n name: \"Location\",\r\n text: \"No Data\",\r\n swatchColor: \"#fff\",\r\n rank: \"\"\r\n };\r\n\r\n // Fill out the actual values\r\n if (location) {\r\n templateData.name = location.name;\r\n\r\n\t\t if (location.isUninhabited) {\r\n\t\t\ttemplateData.text = \"Area is uninhabited\";\r\n\t\t\ttemplateData.swatchColor = \"gray\";\r\n\t\t }\r\n }\r\n\r\n if (data) {\r\n templateData.text = data.displayValue;\r\n templateData.swatchColor = findThemeColor(\r\n data.value,\r\n response.ranges,\r\n largerValuesAre\r\n );\r\n templateData.rank = _.str.isBlank(data.rank)\r\n ? \"\"\r\n : \"Ranks \" + data.rank;\r\n }\r\n\r\n // Rerender the popup contents\r\n var html = self.template(templateData);\r\n self.$el.html(html);\r\n\r\n // Reposition the popup\r\n var pixels = ccc.viz.map.util.MapUtil.fromPositionToRelativePixels(\r\n args.gmap,\r\n args.latLng\r\n );\r\n\r\n // Move left/right/up/down based on the configured offset\r\n pixels.x += self.offset.x;\r\n pixels.y += self.offset.y;\r\n\r\n // Move west by half the width of the popup in order to center it under cursor\r\n pixels.x -= self.$el.outerWidth() / 2;\r\n\r\n // Set the position\r\n self.$el.css({\r\n left: pixels.x,\r\n top: pixels.y\r\n });\r\n\r\n // Quick fade in\r\n self.$el.stop(true, true).fadeIn(200);\r\n });\r\n }\r\n });\r\n})(jQuery, _);\r\n","/// \r\n/// \r\n\r\n(function($, _) {\r\n var ns = window.nspace(\"ccc.viz.map.views\");\r\n\r\n /**\r\n * Displays the \"NYC summary\" view on the right hand side of the map that\r\n * shows data for New York City for the current selections, if available\r\n */\r\n ns.NYCSummaryView = ns.SelectedRegionSummaryView.extend({\r\n el: \"#nyc-summary-container\",\r\n name: \"NYCSummaryView\",\r\n sparklineContainerId: \"nyc-chart-container\",\r\n\r\n getCurrentFips: function() {\r\n return ccc.viz.util.Fips.NYC;\r\n },\r\n\r\n render: function() {\r\n // Don't bother rerendering if the only thing that changed was the selected region\r\n if (\r\n _.size(this.model.changed) === 1 &&\r\n this.model.changed.hasOwnProperty(\"selectedFips\")\r\n ) {\r\n return;\r\n }\r\n\r\n // Call the base implementation\r\n ns.NYCSummaryView.__super__.render.call(this);\r\n },\r\n\r\n overrideDisplayValues: function(displayVals) {\r\n var response = this.dataResponseModel.get(\"response\");\r\n var tfId = this.model.get(\"timeFrameId\");\r\n\r\n displayVals.rankSubtext = \"In \" + response.timeFramesById[tfId].name;\r\n }\r\n });\r\n})(jQuery, _);\r\n","/// \r\n/// \r\n\r\n(function($, _) {\r\n var ns = window.nspace(\"ccc.viz.map.views\");\r\n\r\n /**\r\n * Displays the \"NYC table\" view on the right hand side of the map that\r\n * shows data for New York City for the current selections, if available\r\n */\r\n ns.NYCTableView = ns.SelectedRegionTableView.extend({\r\n el: \"#nyc-table-container\",\r\n name: \"NYCTableView\",\r\n\r\n getCurrentFips: function() {\r\n return ccc.viz.util.Fips.NYC;\r\n },\r\n\r\n render: function() {\r\n // Don't bother rerendering if the only thing that changed was the selected region\r\n if (\r\n _.size(this.model.changed) === 1 &&\r\n this.model.changed.hasOwnProperty(\"selectedFips\")\r\n ) {\r\n return;\r\n }\r\n\r\n // Call the base implementation\r\n ns.NYCTableView.__super__.render.call(this);\r\n }\r\n });\r\n})(jQuery, _);\r\n","(function($, _) {\r\n var ns = window.nspace(\"ccc.viz.map.views\");\r\n\r\n ns.OverlayView = Backbone.View.extend({\r\n el: \"#overlay\",\r\n name: \"No Data Overlay\",\r\n\r\n initialize: function() {\r\n var self = this;\r\n _.bindAll(this, \"render\");\r\n\r\n this.model.on(\"change\", this.render);\r\n\r\n // Hide the legend text when a data update begins\r\n this.model.on(\"busy\", function() {\r\n self.$el.hide();\r\n });\r\n },\r\n\r\n render: function() {\r\n this.$el.toggle(!this.model.hasData());\r\n }\r\n });\r\n})(jQuery, _);\r\n","/// \r\n/// \r\n\r\n(function($, _) {\r\n var ns, selectorNs, sharedNs;\r\n\r\n ns = window.nspace(\"ccc.viz.map.views\");\r\n selectorNs = window.nspace(\"ccc.viz.selectors\");\r\n sharedNs = window.nspace(\"ccc.viz.shared\");\r\n\r\n ns.SelectorsView = sharedNs.views.SelectorsView.extend({\r\n initializeView: function() {\r\n // Expose this (presumably one-and-only) instance globally so that other components\r\n // can call \"public\" methods and get selector information, such as for building data summaries.\r\n // TODO: What's a better way to architect this?\r\n ns.instances = { SelectorsView: this };\r\n\r\n this.model.on(\"change\", this.updateDataSummary);\r\n },\r\n\r\n initializeSelectors: function() {\r\n this.allSelectors = [\r\n // Breakdown\r\n (this.breakdownSelectorView = new selectorNs.BreakdownSelectorView({\r\n model: this.model\r\n })),\r\n // Location Type\r\n (this.locationTypeSelectorView = new selectorNs.LocationTypeSelectorView(\r\n {\r\n model: this.model\r\n }\r\n )),\r\n // Data Type\r\n (this.dataTypeSelectorView = new selectorNs.DataTypeSelectorView({\r\n model: this.model,\r\n getSelectorInfoFunc: this.getSelectorInfoOrThrow\r\n })),\r\n // TimeFrame\r\n (this.timeFrameSelectorView = new selectorNs.TimeFrameSelectorView({\r\n model: this.model,\r\n getSelectorInfoFunc: this.getSelectorInfoOrThrow\r\n }))\r\n ];\r\n },\r\n\r\n getIndicatorSpecificSelectors: function() {\r\n return [\r\n this.locationTypeSelectorView,\r\n this.dataTypeSelectorView,\r\n this.timeFrameSelectorView\r\n ];\r\n },\r\n\r\n updateDataSummary: function() {\r\n $(\"#data-summary\").text(this.getDataSummary());\r\n }\r\n });\r\n})(jQuery, _);\r\n","(function($, _) {\r\n var ns = window.nspace(\"ccc.viz.map.views\");\r\n\r\n /**\r\n * The \"select a region from the map\" prompt that appears when no location is selected\r\n */\r\n ns.SelectRegionPromptView = Backbone.View.extend({\r\n el: \"#select-region-prompt-container\",\r\n name: \"Select a Region prompt\",\r\n\r\n initialize: function() {\r\n _.bindAll(this, \"render\");\r\n\r\n this.initialRenderPromise = $.Deferred();\r\n\r\n this.model.on(\"change:selectedFips change:locationTypeId\", this.render);\r\n // Toggle the prompt the first time we come to the page.\r\n this.model.once(\"change\", this.render);\r\n this.render();\r\n },\r\n\r\n getInitialRenderPromise: function() {\r\n return this.initialRenderPromise;\r\n },\r\n\r\n render: function() {\r\n var self = this;\r\n\r\n // Verify this selector's container is present\r\n if (this.$el.length === 0) {\r\n throw \"Could not find the \" + this.name + \" container: \" + this.el;\r\n }\r\n\r\n if (\r\n +this.model.get(\"locationTypeId\") ===\r\n ccc.viz.map.config.MapConfig.nycLocationId\r\n ) {\r\n self.$el.hide();\r\n self.initialRenderPromise.resolve();\r\n return;\r\n }\r\n\r\n var fips = this.model.get(\"selectedFips\");\r\n if (!fips || fips === \"a\") {\r\n self.$el.hide().fadeIn(function() {\r\n self.initialRenderPromise.resolve();\r\n });\r\n }\n else {\r\n self.$el.hide();\r\n self.initialRenderPromise.resolve();\r\n }\r\n }\r\n });\r\n})(jQuery, _);\r\n"]}