Compare two points and conclude direction The 2019 Stack Overflow Developer Survey Results Are InCalculate 'Rectangle' Coordinates Given 2 Points and widthDisabling XML schema when using GML3 decodeFeatureCollection in GeoToolsGeotools produces different GEOGCS value for ESRI WKTI am trying to have markers in a KML to follow the direction of the view in Google Earthdistance between two points on different directionGeoTools convert albers projection to image X,YModifying feature attributes of a shapefile in geotoolsSelecting points that fall within classified(?) rasterConic projection view transformationGiven a line find whether another line is along side, N,E,S,W or not

Is it possible to build an equivalent function just looking at the input and output of the original function?

Can't find the latex code for the ⍎ (down tack jot) symbol

It's possible to achieve negative score?

Springs with some finite mass

What are the motivations for publishing new editions of an existing textbook, beyond new discoveries in a field?

Does light intensity oscillate really fast since it is a wave?

What do the Banks children have against barley water?

I looked up a future colleague on linkedin before I started a job. I told my colleague about it and he seemed surprised. Should I apologize?

Evaluating number of iteration with a certain map with While

Is "plugging out" electronic devices an American expression?

Poison Arrows Piercing damage reduced to 0, do you still get poisoned?

Seven sins, seven Wizards, seven symbols, seven times repeated, but six super-heroes

JSON.serialize: is it possible to suppress null values of a map?

Spanish for "widget"

The difference between dialogue marks

Why is it "Tumoren" and not "Tumore"?

If Wish Duplicates Simulacrum, Are Existing Duplicates Destroyed?

Landlord wants to switch my lease to a "Land contract" to "get back at the city"

Output the Arecibo Message

How to answer pointed "are you quitting" questioning when I don't want them to suspect

How to manage monthly salary

sleep command using command is not displayed in ps

Is it worth rebuilding a wheel myself to save money?

How can I create a character who can assume the widest possible range of creature sizes?



Compare two points and conclude direction



The 2019 Stack Overflow Developer Survey Results Are InCalculate 'Rectangle' Coordinates Given 2 Points and widthDisabling XML schema when using GML3 decodeFeatureCollection in GeoToolsGeotools produces different GEOGCS value for ESRI WKTI am trying to have markers in a KML to follow the direction of the view in Google Earthdistance between two points on different directionGeoTools convert albers projection to image X,YModifying feature attributes of a shapefile in geotoolsSelecting points that fall within classified(?) rasterConic projection view transformationGiven a line find whether another line is along side, N,E,S,W or not



.everyoneloves__top-leaderboard:empty,.everyoneloves__mid-leaderboard:empty,.everyoneloves__bot-mid-leaderboard:empty margin-bottom:0;








2















Is there a simple method in geotools or JTS to conclude the direction between two geospatial points?



I would like to conclude if point A is (north, south, east, west, NW, NE, SW, SE) when compared with point B?



Or would I need to manually compute the angle between the points (possibly similar to http://docs.geotools.org/stable/userguide/library/referencing/calculator.html) and bin it into the aforementioned directions?










share|improve this question






























    2















    Is there a simple method in geotools or JTS to conclude the direction between two geospatial points?



    I would like to conclude if point A is (north, south, east, west, NW, NE, SW, SE) when compared with point B?



    Or would I need to manually compute the angle between the points (possibly similar to http://docs.geotools.org/stable/userguide/library/referencing/calculator.html) and bin it into the aforementioned directions?










    share|improve this question


























      2












      2








      2








      Is there a simple method in geotools or JTS to conclude the direction between two geospatial points?



      I would like to conclude if point A is (north, south, east, west, NW, NE, SW, SE) when compared with point B?



      Or would I need to manually compute the angle between the points (possibly similar to http://docs.geotools.org/stable/userguide/library/referencing/calculator.html) and bin it into the aforementioned directions?










      share|improve this question
















      Is there a simple method in geotools or JTS to conclude the direction between two geospatial points?



      I would like to conclude if point A is (north, south, east, west, NW, NE, SW, SE) when compared with point B?



      Or would I need to manually compute the angle between the points (possibly similar to http://docs.geotools.org/stable/userguide/library/referencing/calculator.html) and bin it into the aforementioned directions?







      point geotools direction jts-topology-suite






      share|improve this question















      share|improve this question













      share|improve this question




      share|improve this question








      edited Apr 4 at 15:34









      Ian Turton

      50.2k548118




      50.2k548118










      asked Apr 4 at 15:15









      Georg HeilerGeorg Heiler

      1998




      1998




















          1 Answer
          1






          active

          oldest

          votes


















          2














          As it happens I have some code lying around that does most of this, so this should do what you need.



          import java.util.ArrayList;

          import org.geotools.geometry.DirectPosition2D;
          import org.geotools.referencing.GeodeticCalculator;
          import org.geotools.referencing.crs.DefaultGeographicCRS;
          import org.geotools.util.factory.GeoTools;
          import org.locationtech.jts.geom.Point;
          import org.opengis.referencing.operation.TransformException;

          import com.ianturton.cookbook.utilities.GenerateRandomData;

          /**
          * given a direction in degrees (from North) return the Compass Point on an 8
          * element compass rose.
          *
          * @author ian
          */

          public class CompassRose8
          private static final int SIZE = 8;
          static final float STEP = 360f / SIZE;
          static final float HALF_STEP = STEP / 2.0f;
          static final GeodeticCalculator gc = new GeodeticCalculator();

          static final String points[] = "N", "NE", "E", "SE", "S", "SW", "W", "NW", "N" ;
          static ArrayList<Direction> directions = new ArrayList<>();

          static
          int k = 0;
          for (float i = 0; i <= 360; i += (360.0 / SIZE), k++)
          Direction d = new Direction(points[k], i);
          directions.add(d);



          public static String getDirection(Point p1, Point p2) throws TransformException
          gc.setStartingPosition(new DirectPosition2D(DefaultGeographicCRS.WGS84, p1.getX(), p1.getY()));
          gc.setDestinationPosition(new DirectPosition2D(DefaultGeographicCRS.WGS84, p2.getX(), p2.getY()));
          float heading = (float) (gc.getAzimuth() + 180.0f);
          return getDirection(heading);


          public static String getDirection(float heading)
          while (heading < 0)
          heading += 360;

          while (heading > 360)
          heading -= 360;

          for (Direction d : directions)
          if (d.contains(heading))
          return d.name;


          return "bad heading " + heading;


          public static void main(String[] args) throws TransformException
          // Make sure we know our axis order (doesn't matter which we pick)
          System.setProperty(GeoTools.FORCE_LONGITUDE_FIRST_AXIS_ORDER, "true");
          Point p1 = GenerateRandomData.createRandomPoint();
          Point p2 = GenerateRandomData.createRandomPoint();
          System.out.println(p1 + " is " + CompassRose8.getDirection(p1, p2) + " of " + p2);


          static public class Direction
          private float start;
          private float end;
          private float centre;
          final String name;

          Direction(String name, float centre)
          this.name = name;
          this.centre = centre;
          start = this.centre - HALF_STEP;
          end = this.centre + HALF_STEP;


          public boolean contains(float degree)
          return (start < degree && end > degree);









          share|improve this answer























            Your Answer








            StackExchange.ready(function()
            var channelOptions =
            tags: "".split(" "),
            id: "79"
            ;
            initTagRenderer("".split(" "), "".split(" "), channelOptions);

            StackExchange.using("externalEditor", function()
            // Have to fire editor after snippets, if snippets enabled
            if (StackExchange.settings.snippets.snippetsEnabled)
            StackExchange.using("snippets", function()
            createEditor();
            );

            else
            createEditor();

            );

            function createEditor()
            StackExchange.prepareEditor(
            heartbeatType: 'answer',
            autoActivateHeartbeat: false,
            convertImagesToLinks: false,
            noModals: true,
            showLowRepImageUploadWarning: true,
            reputationToPostImages: null,
            bindNavPrevention: true,
            postfix: "",
            imageUploader:
            brandingHtml: "Powered by u003ca class="icon-imgur-white" href="https://imgur.com/"u003eu003c/au003e",
            contentPolicyHtml: "User contributions licensed under u003ca href="https://creativecommons.org/licenses/by-sa/3.0/"u003ecc by-sa 3.0 with attribution requiredu003c/au003e u003ca href="https://stackoverflow.com/legal/content-policy"u003e(content policy)u003c/au003e",
            allowUrls: true
            ,
            onDemand: true,
            discardSelector: ".discard-answer"
            ,immediatelyShowMarkdownHelp:true
            );



            );













            draft saved

            draft discarded


















            StackExchange.ready(
            function ()
            StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fgis.stackexchange.com%2fquestions%2f317803%2fcompare-two-points-and-conclude-direction%23new-answer', 'question_page');

            );

            Post as a guest















            Required, but never shown

























            1 Answer
            1






            active

            oldest

            votes








            1 Answer
            1






            active

            oldest

            votes









            active

            oldest

            votes






            active

            oldest

            votes









            2














            As it happens I have some code lying around that does most of this, so this should do what you need.



            import java.util.ArrayList;

            import org.geotools.geometry.DirectPosition2D;
            import org.geotools.referencing.GeodeticCalculator;
            import org.geotools.referencing.crs.DefaultGeographicCRS;
            import org.geotools.util.factory.GeoTools;
            import org.locationtech.jts.geom.Point;
            import org.opengis.referencing.operation.TransformException;

            import com.ianturton.cookbook.utilities.GenerateRandomData;

            /**
            * given a direction in degrees (from North) return the Compass Point on an 8
            * element compass rose.
            *
            * @author ian
            */

            public class CompassRose8
            private static final int SIZE = 8;
            static final float STEP = 360f / SIZE;
            static final float HALF_STEP = STEP / 2.0f;
            static final GeodeticCalculator gc = new GeodeticCalculator();

            static final String points[] = "N", "NE", "E", "SE", "S", "SW", "W", "NW", "N" ;
            static ArrayList<Direction> directions = new ArrayList<>();

            static
            int k = 0;
            for (float i = 0; i <= 360; i += (360.0 / SIZE), k++)
            Direction d = new Direction(points[k], i);
            directions.add(d);



            public static String getDirection(Point p1, Point p2) throws TransformException
            gc.setStartingPosition(new DirectPosition2D(DefaultGeographicCRS.WGS84, p1.getX(), p1.getY()));
            gc.setDestinationPosition(new DirectPosition2D(DefaultGeographicCRS.WGS84, p2.getX(), p2.getY()));
            float heading = (float) (gc.getAzimuth() + 180.0f);
            return getDirection(heading);


            public static String getDirection(float heading)
            while (heading < 0)
            heading += 360;

            while (heading > 360)
            heading -= 360;

            for (Direction d : directions)
            if (d.contains(heading))
            return d.name;


            return "bad heading " + heading;


            public static void main(String[] args) throws TransformException
            // Make sure we know our axis order (doesn't matter which we pick)
            System.setProperty(GeoTools.FORCE_LONGITUDE_FIRST_AXIS_ORDER, "true");
            Point p1 = GenerateRandomData.createRandomPoint();
            Point p2 = GenerateRandomData.createRandomPoint();
            System.out.println(p1 + " is " + CompassRose8.getDirection(p1, p2) + " of " + p2);


            static public class Direction
            private float start;
            private float end;
            private float centre;
            final String name;

            Direction(String name, float centre)
            this.name = name;
            this.centre = centre;
            start = this.centre - HALF_STEP;
            end = this.centre + HALF_STEP;


            public boolean contains(float degree)
            return (start < degree && end > degree);









            share|improve this answer



























              2














              As it happens I have some code lying around that does most of this, so this should do what you need.



              import java.util.ArrayList;

              import org.geotools.geometry.DirectPosition2D;
              import org.geotools.referencing.GeodeticCalculator;
              import org.geotools.referencing.crs.DefaultGeographicCRS;
              import org.geotools.util.factory.GeoTools;
              import org.locationtech.jts.geom.Point;
              import org.opengis.referencing.operation.TransformException;

              import com.ianturton.cookbook.utilities.GenerateRandomData;

              /**
              * given a direction in degrees (from North) return the Compass Point on an 8
              * element compass rose.
              *
              * @author ian
              */

              public class CompassRose8
              private static final int SIZE = 8;
              static final float STEP = 360f / SIZE;
              static final float HALF_STEP = STEP / 2.0f;
              static final GeodeticCalculator gc = new GeodeticCalculator();

              static final String points[] = "N", "NE", "E", "SE", "S", "SW", "W", "NW", "N" ;
              static ArrayList<Direction> directions = new ArrayList<>();

              static
              int k = 0;
              for (float i = 0; i <= 360; i += (360.0 / SIZE), k++)
              Direction d = new Direction(points[k], i);
              directions.add(d);



              public static String getDirection(Point p1, Point p2) throws TransformException
              gc.setStartingPosition(new DirectPosition2D(DefaultGeographicCRS.WGS84, p1.getX(), p1.getY()));
              gc.setDestinationPosition(new DirectPosition2D(DefaultGeographicCRS.WGS84, p2.getX(), p2.getY()));
              float heading = (float) (gc.getAzimuth() + 180.0f);
              return getDirection(heading);


              public static String getDirection(float heading)
              while (heading < 0)
              heading += 360;

              while (heading > 360)
              heading -= 360;

              for (Direction d : directions)
              if (d.contains(heading))
              return d.name;


              return "bad heading " + heading;


              public static void main(String[] args) throws TransformException
              // Make sure we know our axis order (doesn't matter which we pick)
              System.setProperty(GeoTools.FORCE_LONGITUDE_FIRST_AXIS_ORDER, "true");
              Point p1 = GenerateRandomData.createRandomPoint();
              Point p2 = GenerateRandomData.createRandomPoint();
              System.out.println(p1 + " is " + CompassRose8.getDirection(p1, p2) + " of " + p2);


              static public class Direction
              private float start;
              private float end;
              private float centre;
              final String name;

              Direction(String name, float centre)
              this.name = name;
              this.centre = centre;
              start = this.centre - HALF_STEP;
              end = this.centre + HALF_STEP;


              public boolean contains(float degree)
              return (start < degree && end > degree);









              share|improve this answer

























                2












                2








                2







                As it happens I have some code lying around that does most of this, so this should do what you need.



                import java.util.ArrayList;

                import org.geotools.geometry.DirectPosition2D;
                import org.geotools.referencing.GeodeticCalculator;
                import org.geotools.referencing.crs.DefaultGeographicCRS;
                import org.geotools.util.factory.GeoTools;
                import org.locationtech.jts.geom.Point;
                import org.opengis.referencing.operation.TransformException;

                import com.ianturton.cookbook.utilities.GenerateRandomData;

                /**
                * given a direction in degrees (from North) return the Compass Point on an 8
                * element compass rose.
                *
                * @author ian
                */

                public class CompassRose8
                private static final int SIZE = 8;
                static final float STEP = 360f / SIZE;
                static final float HALF_STEP = STEP / 2.0f;
                static final GeodeticCalculator gc = new GeodeticCalculator();

                static final String points[] = "N", "NE", "E", "SE", "S", "SW", "W", "NW", "N" ;
                static ArrayList<Direction> directions = new ArrayList<>();

                static
                int k = 0;
                for (float i = 0; i <= 360; i += (360.0 / SIZE), k++)
                Direction d = new Direction(points[k], i);
                directions.add(d);



                public static String getDirection(Point p1, Point p2) throws TransformException
                gc.setStartingPosition(new DirectPosition2D(DefaultGeographicCRS.WGS84, p1.getX(), p1.getY()));
                gc.setDestinationPosition(new DirectPosition2D(DefaultGeographicCRS.WGS84, p2.getX(), p2.getY()));
                float heading = (float) (gc.getAzimuth() + 180.0f);
                return getDirection(heading);


                public static String getDirection(float heading)
                while (heading < 0)
                heading += 360;

                while (heading > 360)
                heading -= 360;

                for (Direction d : directions)
                if (d.contains(heading))
                return d.name;


                return "bad heading " + heading;


                public static void main(String[] args) throws TransformException
                // Make sure we know our axis order (doesn't matter which we pick)
                System.setProperty(GeoTools.FORCE_LONGITUDE_FIRST_AXIS_ORDER, "true");
                Point p1 = GenerateRandomData.createRandomPoint();
                Point p2 = GenerateRandomData.createRandomPoint();
                System.out.println(p1 + " is " + CompassRose8.getDirection(p1, p2) + " of " + p2);


                static public class Direction
                private float start;
                private float end;
                private float centre;
                final String name;

                Direction(String name, float centre)
                this.name = name;
                this.centre = centre;
                start = this.centre - HALF_STEP;
                end = this.centre + HALF_STEP;


                public boolean contains(float degree)
                return (start < degree && end > degree);









                share|improve this answer













                As it happens I have some code lying around that does most of this, so this should do what you need.



                import java.util.ArrayList;

                import org.geotools.geometry.DirectPosition2D;
                import org.geotools.referencing.GeodeticCalculator;
                import org.geotools.referencing.crs.DefaultGeographicCRS;
                import org.geotools.util.factory.GeoTools;
                import org.locationtech.jts.geom.Point;
                import org.opengis.referencing.operation.TransformException;

                import com.ianturton.cookbook.utilities.GenerateRandomData;

                /**
                * given a direction in degrees (from North) return the Compass Point on an 8
                * element compass rose.
                *
                * @author ian
                */

                public class CompassRose8
                private static final int SIZE = 8;
                static final float STEP = 360f / SIZE;
                static final float HALF_STEP = STEP / 2.0f;
                static final GeodeticCalculator gc = new GeodeticCalculator();

                static final String points[] = "N", "NE", "E", "SE", "S", "SW", "W", "NW", "N" ;
                static ArrayList<Direction> directions = new ArrayList<>();

                static
                int k = 0;
                for (float i = 0; i <= 360; i += (360.0 / SIZE), k++)
                Direction d = new Direction(points[k], i);
                directions.add(d);



                public static String getDirection(Point p1, Point p2) throws TransformException
                gc.setStartingPosition(new DirectPosition2D(DefaultGeographicCRS.WGS84, p1.getX(), p1.getY()));
                gc.setDestinationPosition(new DirectPosition2D(DefaultGeographicCRS.WGS84, p2.getX(), p2.getY()));
                float heading = (float) (gc.getAzimuth() + 180.0f);
                return getDirection(heading);


                public static String getDirection(float heading)
                while (heading < 0)
                heading += 360;

                while (heading > 360)
                heading -= 360;

                for (Direction d : directions)
                if (d.contains(heading))
                return d.name;


                return "bad heading " + heading;


                public static void main(String[] args) throws TransformException
                // Make sure we know our axis order (doesn't matter which we pick)
                System.setProperty(GeoTools.FORCE_LONGITUDE_FIRST_AXIS_ORDER, "true");
                Point p1 = GenerateRandomData.createRandomPoint();
                Point p2 = GenerateRandomData.createRandomPoint();
                System.out.println(p1 + " is " + CompassRose8.getDirection(p1, p2) + " of " + p2);


                static public class Direction
                private float start;
                private float end;
                private float centre;
                final String name;

                Direction(String name, float centre)
                this.name = name;
                this.centre = centre;
                start = this.centre - HALF_STEP;
                end = this.centre + HALF_STEP;


                public boolean contains(float degree)
                return (start < degree && end > degree);










                share|improve this answer












                share|improve this answer



                share|improve this answer










                answered Apr 4 at 16:05









                Ian TurtonIan Turton

                50.2k548118




                50.2k548118



























                    draft saved

                    draft discarded
















































                    Thanks for contributing an answer to Geographic Information Systems Stack Exchange!


                    • Please be sure to answer the question. Provide details and share your research!

                    But avoid


                    • Asking for help, clarification, or responding to other answers.

                    • Making statements based on opinion; back them up with references or personal experience.

                    To learn more, see our tips on writing great answers.




                    draft saved


                    draft discarded














                    StackExchange.ready(
                    function ()
                    StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fgis.stackexchange.com%2fquestions%2f317803%2fcompare-two-points-and-conclude-direction%23new-answer', 'question_page');

                    );

                    Post as a guest















                    Required, but never shown





















































                    Required, but never shown














                    Required, but never shown












                    Required, but never shown







                    Required, but never shown

































                    Required, but never shown














                    Required, but never shown












                    Required, but never shown







                    Required, but never shown







                    Popular posts from this blog

                    Romeo and Juliet ContentsCharactersSynopsisSourcesDate and textThemes and motifsCriticism and interpretationLegacyScene by sceneSee alsoNotes and referencesSourcesExternal linksNavigation menu"Consumer Price Index (estimate) 1800–"10.2307/28710160037-3222287101610.1093/res/II.5.31910.2307/45967845967810.2307/2869925286992510.1525/jams.1982.35.3.03a00050"Dada Masilo: South African dancer who breaks the rules"10.1093/res/os-XV.57.1610.2307/28680942868094"Sweet Sorrow: Mann-Korman's Romeo and Juliet Closes Sept. 5 at MN's Ordway"the original10.2307/45957745957710.1017/CCOL0521570476.009"Ram Leela box office collections hit massive Rs 100 crore, pulverises prediction"Archived"Broadway Revival of Romeo and Juliet, Starring Orlando Bloom and Condola Rashad, Will Close Dec. 8"Archived10.1075/jhp.7.1.04hon"Wherefore art thou, Romeo? To make us laugh at Navy Pier"the original10.1093/gmo/9781561592630.article.O006772"Ram-leela Review Roundup: Critics Hail Film as Best Adaptation of Romeo and Juliet"Archived10.2307/31946310047-77293194631"Romeo and Juliet get Twitter treatment""Juliet's Nurse by Lois Leveen""Romeo and Juliet: Orlando Bloom's Broadway Debut Released in Theaters for Valentine's Day"Archived"Romeo and Juliet Has No Balcony"10.1093/gmo/9781561592630.article.O00778110.2307/2867423286742310.1076/enst.82.2.115.959510.1080/00138380601042675"A plague o' both your houses: error in GCSE exam paper forces apology""Juliet of the Five O'Clock Shadow, and Other Wonders"10.2307/33912430027-4321339124310.2307/28487440038-7134284874410.2307/29123140149-661129123144728341M"Weekender Guide: Shakespeare on The Drive""balcony"UK public library membership"romeo"UK public library membership10.1017/CCOL9780521844291"Post-Zionist Critique on Israel and the Palestinians Part III: Popular Culture"10.2307/25379071533-86140377-919X2537907"Capulets and Montagues: UK exam board admit mixing names up in Romeo and Juliet paper"Istoria Novellamente Ritrovata di Due Nobili Amanti2027/mdp.390150822329610820-750X"GCSE exam error: Board accidentally rewrites Shakespeare"10.2307/29176390149-66112917639"Exam board apologises after error in English GCSE paper which confused characters in Shakespeare's Romeo and Juliet""From Mariotto and Ganozza to Romeo and Guilietta: Metamorphoses of a Renaissance Tale"10.2307/37323537323510.2307/2867455286745510.2307/28678912867891"10 Questions for Taylor Swift"10.2307/28680922868092"Haymarket Theatre""The Zeffirelli Way: Revealing Talk by Florentine Director""Michael Smuin: 1938-2007 / Prolific dance director had showy career"The Life and Art of Edwin BoothRomeo and JulietRomeo and JulietRomeo and JulietRomeo and JulietEasy Read Romeo and JulietRomeo and Julieteeecb12003684p(data)4099369-3n8211610759dbe00d-a9e2-41a3-b2c1-977dd692899302814385X313670221313670221

                    Creating closest line along the point''s azimuth using PostgreSQL Planned maintenance scheduled April 17/18, 2019 at 00:00UTC (8:00pm US/Eastern) Announcing the arrival of Valued Associate #679: Cesar Manara Unicorn Meta Zoo #1: Why another podcast?Drawing line between points at specific distance in PostGIS?How to efficiently find the closest point over the dateline?How to find the nearest point by using PostGIS function?PostGIS nearest point with LATERAL JOIN in PostgreSQL 9.3+Creating a table and inserting selected streets using plpgsql functionsCreating a table that stores Distances and other columnSaving select query results (year wise) from PostgreSQL/PostGIS to text filesWhat is the information behind this geometry?How to give start and end vertex ids dynamically in pgr_dijkstra?Point to Polygon nearest distance DS_distance is not using geography index & knn <-> or <#> does not give result in orderLine to point conversion with start point and end point detection?

                    Crop image to path created in TikZ? Announcing the arrival of Valued Associate #679: Cesar Manara Planned maintenance scheduled April 17/18, 2019 at 00:00UTC (8:00pm US/Eastern)Crop an inserted image?TikZ pictures does not appear in posterImage behind and beyond crop marks?Tikz picture as large as possible on A4 PageTransparency vs image compression dilemmaHow to crop background from image automatically?Image does not cropTikzexternal capturing crop marks when externalizing pgfplots?How to include image path that contains a dollar signCrop image with left size given