766{
767 double minx, miny, maxx, maxy;
768 double latmax, latmin, lonmax, lonmin;
769 double lonwidth, latwidth;
770 double latmaxadjust, lonmaxadjust, latminadjust, lonminadjust;
772
773
778
779 if ( minx == maxx && miny == maxy )
780 {
781
782
783 return 20;
784 }
785
786 lonmin = -180.0;
787 latmin = -90.0;
788 lonmax = 180.0;
789 latmax = 90.0;
790
791
792
793 while ( 1 )
794 {
795 lonwidth = lonmax - lonmin;
796 latwidth = latmax - latmin;
797 latmaxadjust = lonmaxadjust = latminadjust = lonminadjust = 0.0;
798
799 if ( minx > lonmin + lonwidth / 2.0 )
800 {
801 lonminadjust = lonwidth / 2.0;
802 }
803 else if ( maxx < lonmax - lonwidth / 2.0 )
804 {
805 lonmaxadjust = -1 * lonwidth / 2.0;
806 }
807 if ( lonminadjust || lonmaxadjust )
808 {
809 lonmin += lonminadjust;
810 lonmax += lonmaxadjust;
811
812
814 }
815 else
816 {
817 break;
818 }
819
820 if ( miny > latmin + latwidth / 2.0 )
821 {
822 latminadjust = latwidth / 2.0;
823 }
824 else if (maxy < latmax - latwidth / 2.0 )
825 {
826 latmaxadjust = -1 * latwidth / 2.0;
827 }
828
829 if ( latminadjust || latmaxadjust )
830 {
831 latmin += latminadjust;
832 latmax += latmaxadjust;
833
834
836 }
837 else
838 {
839 break;
840 }
841 }
842
843
844 bounds->
xmin = lonmin;
845 bounds->
xmax = lonmax;
846 bounds->
ymin = latmin;
847 bounds->
ymax = latmax;
848
849
850
852}