CnC Tiberium Alliances - Compass - CCE

Creates compass poiting to the currently selected base (compass points from the center of the screen). - EDIT by Chillchef - current position of center-screen added

// ==UserScript==
// @name        CnC Tiberium Alliances - Compass - CCE
// @namespace   http*://prodgame*.alliances.commandandconquer.com/*/index.aspx*
// @description Creates compass poiting to the currently selected base (compass points from the center of the screen). - EDIT by Chillchef - current position of center-screen added
// @version     1.0.1.3
// @author      Caine, Chillchef
// @include     http*://prodgame*.alliances.commandandconquer.com/*/index.aspx*
// @include     http*://cncapp*.alliances.commandandconquer.com/*/index.aspx*
// ==/UserScript==

(function () {
    var CompassMain = function () {
        try {
            function createCompass() {
                console.log('Compass loaded'); qx.Class.define('Compass', {
                    type: 'singleton',
                    extend: qx.core.Object,
                    members: {
                        needle: null,
                        ctx: null,
                        background: null,
                        size: 50,
                        initialize: function () {
                            try {
                                this.background = new Image();
                                this.background.src = '';
                                this.needle = new Image();
                                this.needle.src = '';
                                var ec = document.createElement('canvas');
                                document.body.appendChild(ec);

                                ec.width = 90;//70
                                ec.height = 110;//90
                                ec.style.position = 'absolute';
                                ec.style.top = '35px';//35
                                ec.style.left = '140px';
                                ec.style.zIndex = 999999;
                                this.ctx = ec.getContext('2d');

                                phe.cnc.Util.attachNetEvent(ClientLib.Vis.VisMain.GetInstance().get_Region(), "PositionChange", ClientLib.Vis.PositionChange, this, this.displayCompass);
                                this.displayCompass();
                            } catch (e) {
                                console.log("Compass.initialize: ", e);
                            }
                        },
                        displayCompass: function () {
                            try {
                                var currentCity = ClientLib.Data.MainData.GetInstance().get_Cities().get_CurrentOwnCity();
                                var cityCoordX = currentCity.get_PosX();
                                var cityCoordY = currentCity.get_PosY();
                                var region = ClientLib.Vis.VisMain.GetInstance().get_Region();
                                var zoom = region.get_ZoomFactor();
                                var targetCoordX = region.get_ViewWidth() / 2;
                                var targetCoordY = region.get_ViewHeight() / 2;
                                var gridW = region.get_GridWidth();
                                var gridH = region.get_GridHeight();
                                var viewCoordX = (region.get_PosX() + targetCoordX / zoom - zoom * gridW / 2) / gridW;
                                var viewCoordY = (region.get_PosY() + targetCoordY / zoom - zoom * gridH / 2) / gridH;
                                var dx = viewCoordX - cityCoordX;
                                var dy = cityCoordY - viewCoordY;
                                var distance = Math.sqrt(dx * dx + dy * dy);
                                var ctx = this.ctx;
                                ctx.clearRect(0, 0, 90, 110);    //70,90
                                ctx.save();
                                ctx.font = '18px Tahoma';

                                ctx.fillStyle = "rgba(200, 20, 20, 0.6)";
                                ctx.fillRect(0, 0, 90, 110);

                                var grd = ctx.createRadialGradient(50,50,10,45,-30,160);
                                grd.addColorStop(0,"rgba(0, 0, 0, 0.7)");
                                grd.addColorStop(1,"rgba(225, 0, 0, 0.7)");

                                ctx.fillStyle = grd;
                                ctx.fillRect(0,0,90,110);

                                ctx.fillStyle = "rgba(220, 0, 0, 1)";
                                ctx.lineWidth = 3;
                                ctx.strokeRect(0, 0, 90, 110);

                                ctx.translate(45, 35);//35
                                ctx.fillStyle = '#FCDE7E';
                                //ctx.drawImage(this.background, -30, -30);//-35,-35
                                var dtext = Math.round(10 * distance) / 10;
                                var dtext2 =  String (viewCoordX.toFixed(0)) + ":" + String(viewCoordY.toFixed(0));
                                ctx.fillText(dtext, -dtext.toString().length * 9 / 2, 40);
                                ctx.fillText(dtext2, -dtext2.toString().length * 9 / 2, 60);
                                ctx.rotate(dy > 0 ? Math.asin(dx / distance) + Math.PI : -Math.asin(dx / distance));
                                ctx.drawImage(this.needle, - this.size / 2, - this.size / 2);

                                ctx.restore();
                            } catch (e) {
                                console.log("displayCompass", e);
                            }
                        }
                    }
                });
            }
        } catch (e) {
            console.log('createCompass: ', e);
        }
        function CompassCheckLoaded() {
            try {
                if (typeof qx != 'undefined' && qx.core.Init.getApplication() && qx.core.Init.getApplication().getUIItem(ClientLib.Data.Missions.PATH.BAR_NAVIGATION) && qx.core.Init.getApplication().getUIItem(ClientLib.Data.Missions.PATH.BAR_NAVIGATION).isVisible()) {
                    createCompass(); window.Compass.getInstance().initialize();
                } else {
                    window.setTimeout(CompassCheckLoaded, 1000);
                }
            } catch (e) {
                console.log('CompassCheckLoaded: ', e);
            }
        }
        if (/commandandconquer\.com/i.test(document.domain)) {
            window.setTimeout(CompassCheckLoaded, 1000);
        }
    };
    try {
        var CompassScript = document.createElement('script');
        CompassScript.innerHTML = "(" + CompassMain.toString() + ')();';
        CompassScript.type = 'text/javascript';
        if (/commandandconquer\.com/i.test(document.domain)) {
            document.getElementsByTagName('head')[0].appendChild(CompassScript);
        }
    } catch (e) {
        console.log('Compass: init error: ', e);
    }
})();