Ignore:
Timestamp:
2014-05-21T22:41:44+02:00 (11 years ago)
Author:
mkyral
Message:

PointInfo: Add support for ghost buildings.

Location:
applications/editors/josm/plugins/pointInfo
Files:
8 edited

Legend:

Unmodified
Added
Removed
  • applications/editors/josm/plugins/pointInfo/build.xml

    r30416 r30466  
    33
    44    <!-- enter the SVN commit message -->
    5     <property name="commit.message" value="PointInfo: Add more external links, nicer icons."/>
     5    <property name="commit.message" value="PointInfo: Add support for ghost buildings."/>
    66    <!-- enter the *lowest* JOSM version this plugin is currently compatible with -->
    77    <property name="plugin.main.version" value="7001"/>
  • applications/editors/josm/plugins/pointInfo/po/cs.po

    r30328 r30466  
    77"Project-Id-Version: \n"
    88"Report-Msgid-Bugs-To: \n"
    9 "POT-Creation-Date: 2014-03-19 20:18+0100\n"
     9"POT-Creation-Date: 2014-05-14 20:25+0200\n"
    1010"PO-Revision-Date: 2014-02-09 22:48+0100\n"
    1111"Last-Translator: Marian Kyral <mkyral@email.cz>\n"
     
    1818"X-Generator: Lokalize 1.5\n"
    1919
    20 #: ../src/org/openstreetmap/josm/plugins/pointinfo/PointInfoAction.java:71
     20#: ../src/org/openstreetmap/josm/plugins/pointinfo/PointInfoAction.java:74
    2121msgid "Point info"
    2222msgstr "Informace o bodu"
    2323
    24 #: ../src/org/openstreetmap/josm/plugins/pointinfo/PointInfoAction.java:71
     24#: ../src/org/openstreetmap/josm/plugins/pointinfo/PointInfoAction.java:74
    2525msgid "Point info."
    2626msgstr "Informace o bodu."
    2727
    28 #: ../src/org/openstreetmap/josm/plugins/pointinfo/PointInfoAction.java:71
     28#: ../src/org/openstreetmap/josm/plugins/pointinfo/PointInfoAction.java:74
    2929#, java-format
    3030msgid "Tool: {0}"
    3131msgstr "Nástroje: {0}"
    3232
    33 #: ../src/org/openstreetmap/josm/plugins/pointinfo/PointInfoAction.java:118
     33#: ../src/org/openstreetmap/josm/plugins/pointinfo/PointInfoAction.java:107
    3434msgid "Connecting server"
    3535msgstr "Připojuji se na server"
    3636
    37 #: ../src/org/openstreetmap/josm/plugins/pointinfo/PointInfoAction.java:156
     37#: ../src/org/openstreetmap/josm/plugins/pointinfo/PointInfoAction.java:148
     38msgid "Data not available."
     39msgstr "Data nejsou dostupná."
     40
     41#: ../src/org/openstreetmap/josm/plugins/pointinfo/PointInfoAction.java:249
    3842msgid "PointInfo"
    3943msgstr "Informace o bodu"
    4044
    41 #: ../src/org/openstreetmap/josm/plugins/pointinfo/PointInfoAction.java:185
    42 msgid "Data not available."
    43 msgstr "Data nejsou dostupná."
    44 
    45 #: ../src/org/openstreetmap/josm/plugins/pointinfo/ruianModule.java:835
     45#: ../src/org/openstreetmap/josm/plugins/pointinfo/ruianModule.java:1088
    4646msgid "Add new address point"
    4747msgstr "Přidán nový adresní bod"
    4848
    49 #: ../src/org/openstreetmap/josm/plugins/pointinfo/ruianModule.java:857
     49#: ../src/org/openstreetmap/josm/plugins/pointinfo/ruianModule.java:1110
    5050msgid "Tags copied to clipboard."
    5151msgstr "Tagy byly zkopírovány do schránky."
    5252
    53 #: ../src/org/openstreetmap/josm/plugins/pointinfo/ruianModule.java:865
     53#: ../src/org/openstreetmap/josm/plugins/pointinfo/ruianModule.java:1118
    5454msgid "New address point added."
    5555msgstr "Adresní bod byl přidán."
  • applications/editors/josm/plugins/pointInfo/po/pointInfo.po

    r30328 r30466  
    99"Project-Id-Version: PACKAGE VERSION\n"
    1010"Report-Msgid-Bugs-To: \n"
    11 "POT-Creation-Date: 2014-03-19 20:18+0100\n"
     11"POT-Creation-Date: 2014-05-20 07:17+0200\n"
    1212"PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n"
    1313"Last-Translator: FULL NAME <EMAIL@ADDRESS>\n"
     
    1818"Content-Transfer-Encoding: 8bit\n"
    1919
    20 #: ../src/org/openstreetmap/josm/plugins/pointinfo/PointInfoAction.java:71
     20#: ../src/org/openstreetmap/josm/plugins/pointinfo/PointInfoAction.java:74
    2121msgid "Point info"
    2222msgstr ""
    2323
    24 #: ../src/org/openstreetmap/josm/plugins/pointinfo/PointInfoAction.java:71
     24#: ../src/org/openstreetmap/josm/plugins/pointinfo/PointInfoAction.java:74
    2525msgid "Point info."
    2626msgstr ""
    2727
    28 #: ../src/org/openstreetmap/josm/plugins/pointinfo/PointInfoAction.java:71
     28#: ../src/org/openstreetmap/josm/plugins/pointinfo/PointInfoAction.java:74
    2929#, java-format
    3030msgid "Tool: {0}"
    3131msgstr ""
    3232
    33 #: ../src/org/openstreetmap/josm/plugins/pointinfo/PointInfoAction.java:118
     33#: ../src/org/openstreetmap/josm/plugins/pointinfo/PointInfoAction.java:107
    3434msgid "Connecting server"
    3535msgstr ""
    3636
    37 #: ../src/org/openstreetmap/josm/plugins/pointinfo/PointInfoAction.java:156
     37#: ../src/org/openstreetmap/josm/plugins/pointinfo/PointInfoAction.java:148
     38msgid "Data not available."
     39msgstr ""
     40
     41#: ../src/org/openstreetmap/josm/plugins/pointinfo/PointInfoAction.java:249
    3842msgid "PointInfo"
    3943msgstr ""
    4044
    41 #: ../src/org/openstreetmap/josm/plugins/pointinfo/PointInfoAction.java:185
    42 msgid "Data not available."
    43 msgstr ""
    44 
    45 #: ../src/org/openstreetmap/josm/plugins/pointinfo/ruianModule.java:835
     45#: ../src/org/openstreetmap/josm/plugins/pointinfo/ruianModule.java:1088
    4646msgid "Add new address point"
    4747msgstr ""
    4848
    49 #: ../src/org/openstreetmap/josm/plugins/pointinfo/ruianModule.java:857
     49#: ../src/org/openstreetmap/josm/plugins/pointinfo/ruianModule.java:1110
    5050msgid "Tags copied to clipboard."
    5151msgstr ""
    5252
    53 #: ../src/org/openstreetmap/josm/plugins/pointinfo/ruianModule.java:865
     53#: ../src/org/openstreetmap/josm/plugins/pointinfo/ruianModule.java:1118
    5454msgid "New address point added."
    5555msgstr ""
  • applications/editors/josm/plugins/pointInfo/servers/RUIAN/index.php

    r30373 r30466  
    44$lon=$_REQUEST['lon'];
    55if ( !is_numeric($lat) or !is_numeric($lon) ) die;
     6
     7
     8// From:   http://www.sitepoint.com/forums/showthread.php?656315-Adding-Distance-To-GPS-Coordinates-To-Get-Bounding-Box&p=4519646&viewfull=1#post4519646
     9function new_coords($lat, $lon, $bearing, $distance)
     10{
     11  // Radius of Earth in meters
     12  $radius = 6371000;
     13
     14  //  New latitude in degrees.
     15  $new_lat = rad2deg(asin(sin(deg2rad($lat)) * cos($distance / $radius) + cos(deg2rad($lat)) * sin($distance / $radius) * cos(deg2rad($bearing))));
     16
     17  //  New longitude in degrees.
     18  $new_lon = rad2deg(deg2rad($lon) + atan2(sin(deg2rad($bearing)) * sin($distance / $radius) * cos(deg2rad($lat)), cos($distance / $radius) - sin(deg2rad($lat)) * sin(deg2rad($new_lat))));
     19
     20  //  Assign new latitude and longitude to an array to be returned to the caller.
     21  $coord['lat'] = $new_lat;
     22  $coord['lon'] = $new_lon;
     23
     24  return $coord;
     25}
     26
     27// Boundary box 20x20 meters around the point
     28$x1_coor = new_coords($lat, $lon, 315, 10); // Left upper point
     29$x2_coor = new_coords($lat, $lon, 135, 10); // Right down point
     30
     31$x1_lon = $x1_coor['lon'];
     32$x2_lon = $x2_coor['lon'];
     33$x1_lat = $x1_coor['lat'];
     34$x2_lat = $x2_coor['lat'];;
     35
     36$boundary_polygon=($x1_lon) . " " . ($x1_lat) . ", " . ($x1_lon) . " " . ($x2_lat) . ", " . ($x2_lon) . " " . ($x2_lat) . ", " . ($x2_lon) . " " . ($x1_lat) . ", " . ($x1_lon) . " " . ($x1_lat);
     37
    638header('Content-Type: application/json');
    739
     
    4375} else
    4476    $data["stavebni_objekt"] = array();
     77
     78// Ghosts: Buildings without geometry in close neighbourhood
     79$query="
     80select * from (
     81  select s.kod,
     82        s.pocet_podlazi, a.nazev zpusob_vyuziti, s.plati_od, s.pocet_bytu, s.dokonceni,
     83        s.zpusob_vyuziti_kod, a.osmtag_k, a.osmtag_v,
     84        s.definicni_bod,
     85        st_distance( (st_transform(s.definicni_bod,4326))::geography, (st_setsrid(st_makepoint(".$lon.",".$lat."),4326))::geography ) dist
     86  from rn_stavebni_objekt s
     87      left outer join osmtables.zpusob_vyuziti_objektu a on s.zpusob_vyuziti_kod = a.kod
     88  where st_intersects(s.definicni_bod, st_transform(st_geometryfromtext(
     89      'POLYGON (( $boundary_polygon ))' ,4326),900913))
     90    and not s.deleted
     91    and s.hranice is null
     92    order by definicni_bod <->
     93          st_transform(st_setsrid(st_makepoint(".$lon.",".$lat."),4326),900913)
     94  limit 5) as x
     95  order by dist;
     96";
     97$result=pg_query($CONNECT,$query);
     98
     99if (pg_num_rows($result) > 0)
     100{
     101    $so = array();
     102    for ($i = 0; $i < pg_num_rows($result); $i++)
     103    {
     104      $row = pg_fetch_array($result, $i);
     105      array_push($so,
     106                  array( "ruian_id" => $row["kod"],
     107                         "pocet_podlazi" => $row["pocet_podlazi"],
     108                         "zpusob_vyuziti" => $row["zpusob_vyuziti"],
     109                         "zpusob_vyuziti_kod" => $row["zpusob_vyuziti_kod"],
     110                         "zpusob_vyuziti_key" => $row["osmtag_k"],
     111                         "zpusob_vyuziti_val" => $row["osmtag_v"],
     112                         "pocet_bytu" => $row["pocet_bytu"],
     113                         "dokonceni" => $row["dokonceni"],
     114                         "plati_od" => $row["plati_od"],
     115                         "vzdalenost" => $row["dist"]
     116                        ));
     117    }
     118      $data["so_bez_geometrie"] = $so;
     119} else
     120    $data["so_bez_geometrie"] = array();
    45121
    46122// Addresses
     
    136212         am.adrp_psc psc, ul.nazev ulice, c.nazev cast_obce,
    137213         momc.nazev mestska_cast,
    138          ob.nazev obec, ok.nazev okres, vu.nazev kraj
     214         ob.nazev obec, ok.nazev okres, vu.nazev kraj,
     215         st_distance( (st_transform(am.definicni_bod,4326))::geography, (st_setsrid(st_makepoint(".$lon.", ".$lat."),4326))::geography ) dist
    139216  from ( select kod, stavobj_kod,
    140217                cislo_domovni, cislo_orientacni_hodnota, cislo_orientacni_pismeno,
     
    155232      left outer join rn_vusc vu on ok.vusc_kod = vu.kod and not vu.deleted
    156233  where st_distance( (st_transform(am.definicni_bod,4326))::geography, (st_setsrid(st_makepoint(".$lon.", ".$lat."),4326))::geography ) < 100
    157   order by st_distance( (st_transform(am.definicni_bod,4326))::geography,
    158                         (st_setsrid(st_makepoint(".$lon.", ".$lat."),4326))::geography)
     234  order by dist
    159235  limit 5
    160236  ;
     
    183259                        "okres" => $row["okres"],
    184260                        "kraj" => $row["kraj"],
    185                         "psc" => $row["psc"]
     261                        "psc" => $row["psc"],
     262                        "vzdalenost" => $row["dist"]
    186263                        ));
    187264    }
  • applications/editors/josm/plugins/pointInfo/src/org/openstreetmap/josm/plugins/pointinfo/PointInfoAction.java

    r30372 r30466  
    103103                @Override
    104104                protected void realRun() throws SAXException {
    105                     infoSync(pos, progressMonitor.createSubTaskMonitor(ProgressMonitor.ALL_TICKS, false));
     105                    infoSync(pos, progressMonitor.createSubTaskMonitor(ProgressMonitor.ALL_TICKS, true));
    106106                }
    107107
  • applications/editors/josm/plugins/pointInfo/src/org/openstreetmap/josm/plugins/pointinfo/ruianModule.java

    r30373 r30466  
    3737import java.io.InputStream;
    3838import java.io.ByteArrayInputStream;
     39
     40import java.text.DecimalFormat;
     41import java.text.DecimalFormatSymbols;
    3942
    4043import javax.json.Json;
     
    7477    private String  m_kraj;
    7578    private String  m_psc;
     79    private float   m_vzdalenost;
    7680
    7781    public addrPlaces () {
     
    99103      m_kraj = "";
    100104      m_psc = "";
     105      m_vzdalenost = 0;
    101106    }
    102107
     
    177182    }
    178183
     184    public void setVzdalenost (float v) {
     185      m_vzdalenost = v;
     186    }
     187
    179188    public long getRuianID () {
    180189      return m_ruian_id;
     
    253262    }
    254263
     264    public String getVzdalenost () {
     265      DecimalFormat df = new DecimalFormat("0.00");
     266      return df.format(m_vzdalenost) + "m";
     267    }
     268
     269}
     270
     271class objectWithoutGeometry {
     272    private long     m_ruian_id;
     273    private int      m_podlazi;
     274    private int      m_byty;
     275    private String   m_zpusob_vyuziti;
     276    private String   m_zpusob_vyuziti_kod;
     277    private String   m_zpusob_vyuziti_key;
     278    private String   m_zpusob_vyuziti_val;
     279    private String   m_dokonceni;
     280    private String   m_plati_od;
     281    private float    m_vzdalenost;
     282
     283    public objectWithoutGeometry () {
     284      init();
     285    }
     286
     287    private void init () {
     288      m_ruian_id = 0;
     289      m_podlazi = 0;
     290      m_byty = 0;
     291      m_zpusob_vyuziti = "";
     292      m_zpusob_vyuziti_kod = "";
     293      m_zpusob_vyuziti_key = "";
     294      m_zpusob_vyuziti_val = "";
     295      m_dokonceni = "";
     296      m_plati_od = "";
     297      m_vzdalenost = 0;
     298    }
     299
     300    public void setRuianID (long v) {
     301      m_ruian_id = v;
     302    }
     303
     304    public void setPodlazi (int v) {
     305      m_podlazi = v;
     306    }
     307
     308    public void setByty (int v) {
     309      m_byty = v;
     310    }
     311
     312    public void setZpusobVyuziti (String v) {
     313      m_zpusob_vyuziti = v;
     314    }
     315
     316    public void setZpusobVyuzitiKod (String v) {
     317      m_zpusob_vyuziti_kod = v;
     318    }
     319
     320    public void setZpusobVyuzitiKey (String v) {
     321      m_zpusob_vyuziti_key = v;
     322    }
     323
     324    public void setZpusobVyuzitiVal (String v) {
     325      m_zpusob_vyuziti_val = v;
     326    }
     327
     328    public void setDokonceni (String v) {
     329      m_dokonceni = v;
     330    }
     331
     332    public void setPlatiOd (String v) {
     333      m_plati_od = v;
     334    }
     335
     336    public void setVzdalenost (float v) {
     337      m_vzdalenost = v;
     338    }
     339
     340    public long getRuianID () {
     341      return m_ruian_id;
     342    }
     343
     344    public int getPodlazi () {
     345      return m_podlazi;
     346    }
     347
     348    public int getByty () {
     349      return m_byty;
     350    }
     351
     352    public String getZpusobVyuziti () {
     353      return m_zpusob_vyuziti;
     354    }
     355
     356    public String getZpusobVyuzitiKod () {
     357      return m_zpusob_vyuziti_kod;
     358    }
     359
     360    public String getZpusobVyuzitiKey () {
     361      return m_zpusob_vyuziti_key;
     362    }
     363
     364    public String getZpusobVyuzitiVal () {
     365      return m_zpusob_vyuziti_val;
     366    }
     367
     368    public String getDokonceni () {
     369      return m_dokonceni;
     370    }
     371
     372    public String getPlatiOd () {
     373      return m_plati_od;
     374    }
     375
     376    public String getVzdalenost () {
     377      DecimalFormat df = new DecimalFormat("0.00");
     378      return df.format(m_vzdalenost) + "m";
     379    }
    255380}
    256381
     
    275400    private String   m_objekt_plati_od;
    276401
     402    private ArrayList <objectWithoutGeometry> m_so_bez_geometrie;
     403
    277404    private ArrayList <addrPlaces> m_adresni_mista;
    278405
     
    323450      m_objekt_plati_od = "";
    324451
     452      m_so_bez_geometrie = new ArrayList<objectWithoutGeometry> ();
    325453      m_adresni_mista = new ArrayList<addrPlaces> ();
    326454
     
    446574// =========================================================================
    447575      try {
     576        JsonArray arr = obj.getJsonArray("so_bez_geometrie");
     577
     578        for(int i = 0; i < arr.size(); i++)
     579        {
     580          JsonObject soBezGeom = arr.getJsonObject(i);
     581          objectWithoutGeometry so = new objectWithoutGeometry();
     582
     583          try {
     584            so.setRuianID(Long.parseLong(soBezGeom.getString("ruian_id")));
     585          } catch (Exception e) {
     586            System.out.println("so_bez_geometrie.ruian_id: " + e.getMessage());
     587          }
     588
     589          try {
     590            so.setPodlazi(Integer.parseInt(soBezGeom.getString("pocet_podlazi")));
     591          } catch (Exception e) {
     592            System.out.println("so_bez_geometrie.pocet_podlazi: " + e.getMessage());
     593          }
     594
     595          try {
     596            so.setByty(Integer.parseInt(soBezGeom.getString("pocet_bytu")));
     597          } catch (Exception e) {
     598            System.out.println("so_bez_geometrie.pocet_bytu: " + e.getMessage());
     599          }
     600
     601          try {
     602            so.setZpusobVyuziti(soBezGeom.getString("zpusob_vyuziti"));
     603          } catch (Exception e) {
     604            System.out.println("so_bez_geometrie.zpusob_vyuziti: " + e.getMessage());
     605          }
     606
     607          try {
     608            so.setZpusobVyuzitiKod(soBezGeom.getString("zpusob_vyuziti_kod"));
     609          } catch (Exception e) {
     610            System.out.println("so_bez_geometrie.zpusob_vyuziti_kod: " + e.getMessage());
     611          }
     612
     613          try {
     614            so.setZpusobVyuzitiKey(soBezGeom.getString("zpusob_vyuziti_key"));
     615          } catch (Exception e) {
     616            System.out.println("so_bez_geometrie.zpusob_vyuziti_key: " + e.getMessage());
     617          }
     618
     619          try {
     620            so.setZpusobVyuzitiVal(soBezGeom.getString("zpusob_vyuziti_val"));
     621          } catch (Exception e) {
     622            System.out.println("so_bez_geometrie.zpusob_vyuziti_val: " + e.getMessage());
     623          }
     624
     625          try {
     626            so.setDokonceni(soBezGeom.getString("dokonceni"));
     627          } catch (Exception e) {
     628            System.out.println("so_bez_geometrie.dokonceni: " + e.getMessage());
     629          }
     630
     631          try {
     632            so.setPlatiOd(soBezGeom.getString("plati_od"));
     633          } catch (Exception e) {
     634            System.out.println("so_bez_geometrie.plati_od: " + e.getMessage());
     635          }
     636
     637          try {
     638            so.setVzdalenost(Float.parseFloat(soBezGeom.getString("vzdalenost")));
     639          } catch (Exception e) {
     640            System.out.println("so_bez_geometrie.vzdalenost: " + e.getMessage());
     641          }
     642
     643          m_so_bez_geometrie.add(so);
     644        }
     645      } catch (Exception e) {
     646        System.out.println("so_bez_geometrie: " + e.getMessage());
     647      }
     648
     649// =========================================================================
     650      try {
    448651        JsonArray arr = obj.getJsonArray("adresni_mista");
    449652
     
    569772          } catch (Exception e) {
    570773            System.out.println("adresni_mista.psc: " + e.getMessage());
     774          }
     775
     776          try {
     777            am.setVzdalenost(Float.parseFloat(adresniMisto.getString("vzdalenost")));
     778          } catch (Exception e) {
     779            System.out.println("adresni_mista.vzdalenost: " + e.getMessage());
    571780          }
    572781
     
    8791088          r.append("<tr><td bgcolor=#e5e5ff>");
    8801089          if (!m_adresni_mista.get(i).getUlice().isEmpty()) {
     1090            r.append(m_adresni_mista.get(i).getVzdalenost());
     1091            r.append("</td><td valign=\"top\"  bgcolor=#e5e5ff>");
    8811092            r.append(m_adresni_mista.get(i).getUlice() + " " + x);
    8821093            r.append("<br/><u>" + m_adresni_mista.get(i).getObec() + "</u>");
     
    8871098            r.append("&nbsp;&nbsp;<a href=file://tags.create-on-place/address:"+i+">"+ icon_create_addr_ruian +"</a>");
    8881099          } else {
     1100            r.append(m_adresni_mista.get(i).getVzdalenost());
     1101            r.append("</td><td valign=\"top\"  bgcolor=#e5e5ff>");
    8891102            r.append(m_adresni_mista.get(i).getCastObce() + " " + x + "&nbsp;");
    8901103            if (!m_adresni_mista.get(i).getCastObce().equals(m_adresni_mista.get(i).getObec())) {
     
    9011114        r.append("</table><br/>");
    9021115      }
     1116
     1117      if (m_so_bez_geometrie.size() > 0) {
     1118        r.append("<i><u>Budovy bez geometrie v okolí</u></i><br/>");
     1119        r.append("<table>");
     1120        for (int i=0; i<m_so_bez_geometrie.size(); i++) {
     1121          r.append("<tr><td bgcolor=#e5e5ff>");
     1122          r.append(m_so_bez_geometrie.get(i).getVzdalenost());
     1123          r.append("</td><td valign=\"top\"  bgcolor=#e5e5ff>");
     1124          r.append(m_so_bez_geometrie.get(i).getRuianID());
     1125          if (m_so_bez_geometrie.get(i).getZpusobVyuziti().length() > 0) {
     1126            r.append(" - " + m_so_bez_geometrie.get(i).getZpusobVyuziti());
     1127          }
     1128          r.append("</td><td valign=\"top\"  bgcolor=#e5e5ff>");
     1129          r.append("&nbsp;&nbsp;<a href="+ url_stavebni_objekt + m_so_bez_geometrie.get(i).getRuianID() + ">"+ icon_ext_link +"</a> ");
     1130          r.append("&nbsp;&nbsp;<a href=file://tags.copy/building>"+ icon_copy_tags +"</a></br>");
     1131          r.append("</td></tr>");
     1132        }
     1133        r.append("</table><br/>");
     1134        r.append("<br/>");
     1135      }
     1136
    9031137      r.append("<hr/>");
    9041138      r.append("<center><i><small>Zdroj: <a href=\"http://www.ruian.cz/\">" + m_source + "</a></small></i></center>");
     
    11301364
    11311365    private String m_text = "";
    1132     private String URL = "http://josm.poloha.net/pointInfo/v2/index.php";
     1366    private String URL = "http://josm.poloha.net/pointInfo/v3/index.php";
    11331367    protected PointInfoServer server = new PointInfoServer();
    11341368
Note: See TracChangeset for help on using the changeset viewer.