[Mapserver-users] SHP file simplification (continued)

Steve Lime steve.lime at dnr.state.mn.us
Mon Dec 16 13:20:33 EST 2002


--=_D884166A.CEAFD836
Content-Type: text/plain; charset=ISO-8859-1
Content-Transfer-Encoding: 8bit
Content-Disposition: inline

Attached is perl mapscript that does line thinning. It's a port of the
ArcView thinning
script. A bit slow but seems to work fine.

Steve

Stephen Lime
Data & Applications Manager

Minnesota DNR
500 Lafayette Road
St. Paul, MN 55155
651-297-2937

>>> Frédérique Boyer <frederique.boyer at infotracs.net> 10/04/02 07:30AM
>>>
Hi all,

It seems, my first explanation was not very good ;-)

whe already have selected the major roads when we display 100 to 600
kilometers.

My problem is not this selection !

It is to find a tool able to reduce the number of vectors in a
shapefile. (or number or nodes)

hope it exists !!!

Thanks a lot

Frederique

--=_D884166A.CEAFD836
Content-Type: application/octet-stream; name="thin.pl"
Content-Transfer-Encoding: base64
Content-Disposition: attachment; filename="thin.pl"

IyEvdXNyL2Jpbi9wZXJsCgojIFNjcmlwdDogVGhpbi5wbCAKIyAKIyBQdXJwb3NlOiBBbiBhZGFw
dGlvbiBvZiB0aGUgQXJjVmlldyBBdmVudWUgZXhhbXBsZSBzY3JpcHQgZ2VuZmVhdC5hdmUuIEl0
J3MKIyAgICAgICAgICBiYXNpY2FsbHkgdGhlIERvdWdsYXMtUGV1Y2tlciBnZW5lcmFsaXphdGlv
biBhbGdvcml0aG0uCiMKIyBJbml0aWFsIENvZGluZzogMDQvMTAvMjAwMAojIExhc3QgTW9kaWZp
ZWQ6IDA0LzE3LzIwMDAKIyBWZXJzaW9uOiAxLjEKIwojIEF1dGhvcjogU3RlcGhlbiBMaW1lIChz
dGV2ZS5saW1lQGRuci5zdGF0ZS5tbi51cykKCnVzZSBQT1NJWDsKdXNlIFhCYXNlOwp1c2UgbWFw
c2NyaXB0Owp1c2UgR2V0b3B0OjpMb25nOwoKJkdldE9wdGlvbnMoImlucHV0PXMiLCBcJGluZmls
ZSwKCSAgICAib3V0cHV0PXMiLCBcJG91dGZpbGUsCgkgICAgInRvbGVyYW5jZT1uIiwgXCR0b2xl
cmFuY2UKCSAgICk7CgppZighJGluZmlsZSBvciAhJG91dGZpbGUgb3IgISR0b2xlcmFuY2UpIHsK
ICBwcmludCAiU3ludGF4OiB0aGluLnBsIC1pbnB1dD1bZmlsZW5hbWVdIC1vdXRwdXQ9W2ZpbGVu
YW1lXSAtdG9sZXJhbmNlPVttYXhpbXVtIGRpc3RhbmNlIGJldHdlZW4gdmVydGljZXNdXG4iOwog
IGV4aXQgMDsKfQoKZGllICJUb2xlcmFuY2UgbXVzdCBiZSBncmVhdGVyIHRoYW4gemVyby4iIHVu
bGVzcyAkdG9sZXJhbmNlID4gMDsKCiMgaW5pdGlhbGl6ZSBjb3VudGVycyBmb3IgcmVwb3J0aW5n
CiRpbmNvdW50ID0gMDsKJG91dGNvdW50ID0gMDsKCiMgb3BlbiB0aGUgaW5wdXQgc2hhcGVmaWxl
CiRpblNIUCA9IG5ldyBzaGFwZWZpbGVPYmooJGluZmlsZSwgLTEpIG9yIGRpZSAiVW5hYmxlIHRv
IG9wZW4gc2hhcGVmaWxlICRpbmZpbGUuIjsKZGllICJDYW5ub3QgdGhpbiBwb2ludC9tdWx0aXBv
aW50IHNoYXBlZmlsZXMuIiB1bmxlc3MgKCRpblNIUC0+e3R5cGV9ID09IDUgb3IgJGluU0hQLT57
dHlwZX0gPT0gMyk7CgojIGNyZWF0ZSB0aGUgb3V0cHV0IHNoYXBlZmlsZQpzeXN0ZW0oInJtICRv
dXRmaWxlLnNocCAkb3V0ZmlsZS5zaHggJG91dGZpbGUuZGJmICRvdXRmaWxlLnFpeCIpOwokb3V0
U0hQID0gbmV3IHNoYXBlZmlsZU9iaigkb3V0ZmlsZSwgJGluU0hQLT57dHlwZX0pIG9yIGRpZSAi
VW5hYmxlIHRvIGNyZWF0ZSBzaGFwZWZpbGUgJyRvdXRmaWxlJy4gIiwgJG1hcHNjcmlwdDo6bXNf
ZXJyb3ItPnttZXNzYWdlfTsKc3lzdGVtKCJjcCAkaW5maWxlLmRiZiAkb3V0ZmlsZS5kYmYiKTsK
CiRpbnNoYXBlID0gbmV3IHNoYXBlT2JqKC0xKTsgIyBzb21ldGhpbmcgdG8gaG9sZCBzaGFwZXMK
CmZvcigkaT0wOyAkaTwkaW5TSFAtPntudW1zaGFwZXN9OyAkaSsrKSB7CgogICRpblNIUC0+Z2V0
KCRpLCAkaW5zaGFwZSk7CiAgJG91dHNoYXBlID0gbmV3IHNoYXBlT2JqKC0xKTsKICAKICBmb3Io
JGo9MDsgJGo8JGluc2hhcGUtPntudW1saW5lc307ICRqKyspIHsKCiAgICAkaW5wYXJ0ID0gJGlu
c2hhcGUtPmdldCgkaik7CiAgICAkb3V0cGFydCA9IG5ldyBsaW5lT2JqKCk7CgogICAgQHN0YWNr
ID0gKCk7CgogICAgJGluY291bnQgKz0gJGlucGFydC0+e251bXBvaW50c307CgogICAgJGFuY2hv
ciA9ICRpbnBhcnQtPmdldCgwKTsgIyBzYXZlIGZpcnN0IHBvaW50CiAgICAkb3V0cGFydC0+YWRk
KCRhbmNob3IpOwogICAgJGFJbmRleCA9IDA7CgogICAgJGZJbmRleCA9ICRpbnBhcnQtPntudW1w
b2ludHN9IC0gMTsKICAgIHB1c2ggQHN0YWNrLCAkZkluZGV4OwoKICAgICMgRG91Z2xhcyAtIFBl
dWNrZXIgYWxnb3JpdGhtCiAgICB3aGlsZShAc3RhY2spIHsKICAgICAgIAogICAgICAkZkluZGV4
ID0gJHN0YWNrWyQjc3RhY2tdOwogICAgICAkZlBvaW50ID0gJGlucGFydC0+Z2V0KCRmSW5kZXgp
OwoKICAgICAgJG1heCA9ICR0b2xlcmFuY2U7ICMgY29tcGFyaXNvbiB2YWx1ZXMKICAgICAgJG1h
eEluZGV4ID0gMDsKCiAgICAgICMgcHJvY2VzcyBtaWRkbGUgcG9pbnRzICAgICAgCiAgICAgIGZv
ciAoKCRhSW5kZXgrMSkgLi4gKCRmSW5kZXgtMSkpIHsKCgkkcG9pbnQgPSAkaW5wYXJ0LT5nZXQo
JF8pOwkKCSRkaXN0ID0gJHBvaW50LT5kaXN0YW5jZVRvTGluZSgkYW5jaG9yLCAkZlBvaW50KTsK
CglpZigkZGlzdCA+PSAkbWF4KSB7CgkgICRtYXggPSAkZGlzdDsKCSAgJG1heEluZGV4ID0gJF87
Cgl9CiAgICAgIH0KCiAgICAgIGlmKCRtYXhJbmRleCA+IDApIHsKCXB1c2ggQHN0YWNrLCAkbWF4
SW5kZXg7CiAgICAgIH0gZWxzZSB7Cgkkb3V0cGFydC0+YWRkKCRmUG9pbnQpOwkKCSRhbmNob3Ig
PSAkaW5wYXJ0LT5nZXQocG9wIEBzdGFjayk7CgkkYUluZGV4ID0gJGZJbmRleDsKICAgICAgfQog
ICAgfQoKICAgICMgY2hlY2sgZm9yIGNvbGxhcHNlZCBwb2x5Z29ucywgdXNlIG9yaWdpbmFsIGRh
dGEgaW4gdGhhdCBjYXNlCiAgICBpZigoJG91dHBhcnQtPntudW1wb2ludHN9IDwgNCkgYW5kICgk
aW5TSFAtPnt0eXBlfSA9PSA1KSkgewogICAgICAkb3V0cGFydCA9ICRpbnBhcnQ7CiAgICB9Cgog
ICAgJG91dGNvdW50ICs9ICRvdXRwYXJ0LT57bnVtcG9pbnRzfTsKICAgICRvdXRzaGFwZS0+YWRk
KCRvdXRwYXJ0KTsKCiAgfSAjIGZvciBlYWNoIHBhcnQKCiAgJG91dFNIUC0+YWRkKCRvdXRzaGFw
ZSk7CiAgdW5kZWYoJG91dHNoYXBlKTsgIyBmcmVlIG1lbW9yeSBhc3NvY2lhdGVkIHdpdGggc2hh
cGUKCn0gIyBmb3IgZWFjaCBzaGFwZQoKJG91dFNIUCA9ICcnOyAjIHdyaXRlIHRoZSBmaWxlCnBy
aW50ICJUaGUgb2xkIGZpbGUgKCRpbmNvdW50IHZlcnRpY2VzKSBoYXMgYmVlbiBnZW5lcmFsaXpl
ZCB0byAkb3V0Y291bnQgdmVydGljZXMuXG4iOwoK

--=_D884166A.CEAFD836--



More information about the mapserver-users mailing list