פפּ און סקל: רעכענען אָדער אָנפֿרעגן גרויס קרייז דיסטאַנסע צווישן ווייזט פון ברייט און לאַנדזשאַטוד מיט די האַווערסינע פאָרמולע

האַווערסינע פאָרמולע - רעכענען גרויס קרייז דיסטאַנסע מיט פפּ אָדער מיסקל

דעם חודש איך'ווע פּראָגראַממינג אַ ביסל אין PHP און MySQL וועגן GIS. סנאָאָפּינג אַרום די נעץ, איך פאקטיש האט אַ שווער מאָל צו געפֿינען עטלעכע פון ​​די דזשיאַגראַפיק חשבונות צו געפֿינען די ווייַטקייט צווישן צוויי לאָוקיישאַנז, אַזוי איך געוואלט צו טיילן זיי דאָ.

פלי מאַפּע אייראָפּע מיט גרויס קרייז דיסטאַנסע

די פּשוט וועג צו רעכענען אַ ווייַטקייט צווישן צוויי פונקטן איז ניצן די פּיטהאַגאָרעאַן פאָרמולע צו רעכענען די כייפּאַטענאַס פון אַ דרייַעק (A² + B² = C²). דאָס איז באַוווסט ווי דער עוקלידיאַן ווייַטקייט.

דאָס איז אַ טשיקאַווע אָנהייב, אָבער דאָס איז נישט גילטיק פֿאַר געאָגראַפי, ווייַל די ווייַטקייט צווישן ברייט און לאַנדזשאַטוד שורות זענען ניט אַן גלייַך ווייַטקייט באַזונדער. ווען איר באַקומען נעענטער צו דער עקוואַטאָר, די ברייט פון די ברייט זענען ווייטער באַזונדער. אויב איר נוצן אַ טיפּ פון פּשוט טריאַנגולאַטיאָן יקווייזשאַן, עס קען מעסטן דיסטאַנסע אַקיעראַטלי אין איין אָרט און טעראַבלי פאַלש אין די אנדערע ווייַל פון די קערוואַטשער פון דער ערד.

גרויס סירקלע דיסטאַנסע

די רוץ וואָס זענען געפארן לאַנג דיסטאַנסאַז אַרום דער ערד זענען באַוווסט ווי דער גרויס סירקלע דיסטאַנסע. דאָס איז ... די שאָרטיסט ווייַטקייט צווישן צוויי פונקטן אויף אַ קויל איז אַנדערש ווי די ווייזט אין אַ פלאַך מאַפּע. קאַמביין דעם מיט די פאַקט אַז די ברייט און לאַנדזשאַטוד שורות זענען נישט יקווידיסטאַנט ... און איר האָט אַ שווער כעזשבן.

דאָ ס אַ פאַנטאַסטיש ווידעא דערקלערונג פון ווי גרויס קרייזן אַרבעט.

די האַווערסינע פאָרמולע

די ווייַטקייט ניצן די קערוואַטשער פון דער ערד איז ינקאָרפּערייטיד אין די האַווערסינע פאָרמולע, וואָס ניצט טריגאָנאָמעטרי צו לאָזן די קערוואַטשער פון דער ערד. אויב איר געפֿינען די ווייַטקייט צווישן 2 ערטער אויף דער ערד (ווי די קראָו פליעס), אַ גלייך ליניע איז טאַקע אַ קרייַזבויגן.

דאָס איז אָנווענדלעך אין לופט פלי - האָבן איר טאָמיד געקוקט אויף די פאַקטיש מאַפּע פון ​​פלייץ און באמערקט אַז זיי זענען אַרטשט? דאָס איז ווייַל עס איז קירצער צו פליען אין אַ אַרטש צווישן צוויי פונקטן ווי גלייַך צו דעם אָרט.

PHP: רעכענען דיסטאַנסע צווישן 2 פונקטן פון ברייט און לאַנדזשאַטוד

סייַ ווי סייַ, דאָ איז די PHP פאָרמולע פֿאַר קאַלקיאַלייטינג די ווייַטקייט צווישן צוויי פונקטן (צוזאמען מיט די מייל קעגן קילאָמעטער קאַנווערזשאַן) ראַונדיד צו צוויי דעצימאַל ערטער.

function getDistanceBetweenPointsNew($latitude1, $longitude1, $latitude2, $longitude2, $unit = 'miles') {
  $theta = $longitude1 - $longitude2; 
  $distance = (sin(deg2rad($latitude1)) * sin(deg2rad($latitude2))) + (cos(deg2rad($latitude1)) * cos(deg2rad($latitude2)) * cos(deg2rad($theta))); 
  $distance = acos($distance); 
  $distance = rad2deg($distance); 
  $distance = $distance * 60 * 1.1515; 
  switch($unit) { 
    case 'miles': 
      break; 
    case 'kilometers' : 
      $distance = $distance * 1.609344; 
  } 
  return (round($distance,2)); 
}

סקל: צוריקקריגן אַלע רעקאָרדס אין אַ קייט דורך קאַלקיאַלייטינג דיסטאַנסע אין מייל ניצן ברייט און לאַנדזשאַטוד

עס איז אויך מעגלעך צו נוצן סקל צו מאַכן אַ כעזשבן צו געפֿינען אַלע רעקאָרדס אין אַ ספּעציפיש ווייַטקייט. אין דעם בייַשפּיל, איך וועל אָנפרעגן MyTable אין MySQL צו געפֿינען אַלע רעקאָרדס וואָס זענען ווייניקער ווי אָדער גלייַך צו בייַטעוודיק $ דיסטאַנסע (אין מייל) צו מיין אָרט ביי $ ברייט און $ לאַנדזשאַטוד:

די אָנפֿרעג פֿאַר ריטריווינג אַלע די רעקאָרדס אין אַ ספּעציפיש מעהאַלעך דורך קאַלקיאַלייטינג דיסטאַנסע אין מייל צווישן צוויי פּוינץ פון ברייט און לאַנדזשאַטוד זענען:

$query = "SELECT *, (((acos(sin((".$latitude."*pi()/180)) * sin((`latitude`*pi()/180)) + cos((".$latitude."*pi()/180)) * cos((`latitude`*pi()/180)) * cos(((".$longitude."- `longitude`)*pi()/180)))) * 180/pi()) * 60 * 1.1515) as distance FROM `table` WHERE distance <= ".$distance."

איר דאַרפֿן צו קאַסטאַמייז דעם:

  • $ לאַנדזשאַטוד - דאָס איז אַ פפּ בייַטעוודיק וווּ איך פאָרן די לאַנדזשאַטוד פון די פונט.
  • $ ברייט - דאָס איז אַ פפּ בייַטעוודיק וווּ איך פאָרן די לאַנדזשאַטוד פון די פונט.
  • $ ווייטקייט - דאָס איז די ווייַטקייט וואָס איר ווילט צו געפֿינען אַלע רעקאָרדס ווייניקער אָדער גלייַך צו.
  • טיש - דאָס איז דער טיש ... איר וועט וועלן צו פאַרבייַטן דעם מיט דיין טיש נאָמען.
  • ברייט - דאָס איז די פעלד פון דיין ברייט.
  • לאַנדזשאַטוד - דאָס איז די פעלד פון דיין לאַנדזשאַטוד.

סקל: ריטריווינג אַלע רעקאָרדס אין אַ קייט דורך קאַלקיאַלייטינג דיסטאַנסע אין קילאָמעטערס ניצן ברייט און לאַנדזשאַטוד

און דאָ ס די SQL אָנפֿרעג מיט קילאָמעטערס אין MySQL:

$query = "SELECT *, (((acos(sin((".$latitude."*pi()/180)) * sin((`latitude`*pi()/180)) + cos((".$latitude."*pi()/180)) * cos((`latitude`*pi()/180)) * cos(((".$longitude."- `longitude`) * pi()/180)))) * 180/pi()) * 60 * 1.1515 * 1.609344) as distance FROM `table` WHERE distance <= ".$distance."

איר דאַרפֿן צו קאַסטאַמייז דעם:

  • $ לאַנדזשאַטוד - דאָס איז אַ פפּ בייַטעוודיק וווּ איך פאָרן די לאַנדזשאַטוד פון די פונט.
  • $ ברייט - דאָס איז אַ פפּ בייַטעוודיק וווּ איך פאָרן די לאַנדזשאַטוד פון די פונט.
  • $ ווייטקייט - דאָס איז די ווייַטקייט וואָס איר ווילט צו געפֿינען אַלע רעקאָרדס ווייניקער אָדער גלייַך צו.
  • טיש - דאָס איז דער טיש ... איר וועט וועלן צו פאַרבייַטן דעם מיט דיין טיש נאָמען.
  • ברייט - דאָס איז די פעלד פון דיין ברייט.
  • לאַנדזשאַטוד - דאָס איז די פעלד פון דיין לאַנדזשאַטוד.

איך האָב גענוצט דעם קאָד אין אַ פֿירמע מאַפּינג פּלאַטפאָרמע אַז מיר געוויינט פֿאַר אַ לאַכאָדימ קראָם מיט איבער 1,000 לאָוקיישאַנז אַריבער צפון אַמעריקע, און עס אַרבעט ביוטאַפלי.

קסנומקס באַמערקונגען

  1. 1

    דאַנקען דיר זייער פיל פֿאַר ייַנטיילונג. דאָס איז געווען אַ גרינג קאָפּיע און פּאַפּ אַרבעט און אַרבעט גרויס. איר'ווע געראטעוועט מיר אַ פּלאַץ פון צייַט.
    FYI פֿאַר ווער עס יז וואָס פאָרן צו C:
    טאָפּל דעג 2 ראַד (טאָפּל דעג) {צוריק דעג * (3.14159265358979323846 / 180.0); }

  2. 2

    זייער שיין שטיק פון פּאָוסטינג - געארבעט זייער פייַן - איך נאָר האָבן צו טוישן דעם נאָמען פון די טיש מיט די לאַט-לאַנג. עס אַרבעט שיין שנעל צו .. איך האָבן אַ ריזאַנאַבלי קליין נומער פון לאַט-לאָנגס (<400) אָבער איך טראַכטן דעם וואָלט נייסלי וואָג. פייַן פּלאַץ אויך - איך האָב דאָס פּונקט צוגעגעבן צו מיין del.icio.us חשבון און איך וועל קעסיידער טשעק צוריק.

  3. 4
  4. 5

    איך האָב די גאנצע טאָג געזוכט פֿאַר ווייַטקייט חשבונות און געפֿונען די האַרווערסינע אַלגערידאַם, דאַנק צו איר פֿאַר די ביישפּיל פון דעם שטייגער אין אַ סקלע דערקלערונג. דאַנקען און גרוס, דניאל

  5. 8

    איך טראַכטן דיין סקל דאַרף אַ דערקלערונג.
    אַנשטאָט וואו דיסטאַנסע <= $ ווייַטקייט איר קען דאַרפֿן
    נוצן HAVING ווייַטקייט <= $ ווייַטקייט

    אַנדערש דאַנק פֿאַר שפּאָרן מיר אַ בינטל פון צייט און ענערגיע.

  6. 10
  7. 11
  8. 12
  9. 14

    די פאָרמולע שפּאָרן מיר אַ פּלאַץ פון צייט. א גרויסן יישר כח.
    איך אויך האָבן צו באַשטימען צווישן די NMEA פֿאָרמאַט און דיגריז. איך געפֿונען אַ פאָרמולע אין דעם URL אין די דנאָ פון די בלאַט. http://www.errorforum.com/knowledge-base/16273-converting-nmea-sentence-latitude-longitude-decimal-degrees.html

    קען ווער עס יז וויסן ווי צו באַשטעטיקן דעם?

    דאנק איר!
    מאַטערן

  10. 15
  11. 16

    איך האָב אויך געפֿונען אַז ווו קען נישט אַרבעטן פֿאַר מיר. געביטן עס צו ווייל און אַלץ אַרבעט שליימעסדיק. אין ערשטער איך האט נישט לייענען די באַמערקונגען און ריראָו עס מיט אַ נעסטעד סעלעקטירן. ביידע וועלן אַרבעט נאָר פייַן.

  12. 17

    דאַנקען דיר זייער מאָוטש פֿאַר די שריפט געשריבן אין מיסקל, נאָר האט צו מאַכן ביסל מינערווערטיק אַדזשאַסטמאַנץ (ווייל) 🙂
    גרעט אַרבעט

  13. 18

    ינקרעדאַבלי נוציק, דאַנקען דיר זייער פיל! איך האָב עטלעכע פּראָבלעמס מיט די נייַע "HAVING", אלא ווי "WHERE", אָבער אַמאָל איך לייענען די באַמערקונגען דאָ (נאָך וועגן אַ האַלב שעה פון גרינדינג מיין ציין אין פראַסטריישאַן = P), איך גאַט עס ארבעטן נייסלי. דאנק איר ^ _ ^

  14. 19
  15. 20

    געדענקען אַז אַזאַ אַ ויסזאָגונג ויסזאָגונג וועט זיין זייער טיף און דעריבער פּאַמעלעך. אויב איר האָט אַ פּלאַץ פון די פֿראגן, עס קען זיין געשווינד געשווינד.

    א פיל ווייניקער טיף צוגאַנג איז צו לויפן אַ ערשטער (גראָב) סעלעקטירן ניצן אַ קוואדראט געגנט דיפיינד דורך אַ קאַלקיאַלייטיד ווייַטקייט, ד"ה "סעלעקטירן * פֿון טאַבלענאַמע וווּ ברייט צווישן לאַט 1 און לאַט 2 און לאַנדזשאַטוד צווישן לאָנ 1 און לאָנ 2. לאַט 1 = טאַרגאַטיטודע - לאַטדיפף, לאַט 2 = טאַרגאַטיטודע + לאַטדיפף, ענלעך מיט לאָן. latdiff ~ = דיסטאַנסע / 111 (פֿאַר קילאמעטער), אָדער דיסטאַנסע / 69 פֿאַר מייל זינט 1 גראַד פון ברייט איז ~ 111 קילאמעטער (קליין ווערייישאַן זינט ערד איז אַ ביסל אָוואַל, אָבער גענוג פֿאַר דעם צוועק). לאָנדיפף = דיסטאַנסע / (אַבס (קאָס (דעג 2 ראַד (ברייט)) * 111)) - אָדער 69 פֿאַר מייל (איר קענט טאַקע נעמען אַ ביסל גרעסערע קוואַדראַט צו זיין אַקאַונטאַד פֿאַר ווערייישאַנז). דערנאָך נעמען די רעזולטאַט פון אים און קאָרמען עס אין די ריידיאַל סעלעקטירן. נאָר טאָן ניט פאַרגעסן צו נעמען אַ קאָואָרדאַנאַץ וואָס זענען נישט אין דער געגנט - דאָס הייסט די קייט פון פּאַסיק לאַנדזשאַטוד איז -180 צו +180 און די קייט פון פּאַסיק ברייט איז -90 צו +90 - אין פאַל דיין לאַטדיף אָדער לאָנדיפף לויפן אַרויס דעם קייט . באַמערקונג אַז אין רובֿ פאלן, דאָס קען נישט זיין אָנווענדלעך, ווייַל דאָס איז בלויז אַפעקץ קאַלקיאַליישאַנז איבער אַ פּאַסיפיק אקעאן פון פלאָקן צו פלאָקן, כאָטש עס איז אַ טייל פון טשוקאָטקאַ און אַ טייל פון אַלאַסקאַ.

    וואָס מיר דערגרייכן דאָס איז אַ באַטייטיק רעדוקציע אין די נומער פון ווייזט קעגן וואָס איר רעכענען דעם חשבון. אויב איר האָבן אַ מיליאָן גלאבאלע פונקטן אין די דאַטאַבייס פאַרשפּרייטן בעערעך יוואַנלי און איר ווילן צו זוכן אין 100 קילאמעטער, דיין ערשטער (שנעל) זוכן איז אַ שטח פון 10000 סק.מ., און מיסטאָמע וועט געבן וועגן 20 רעזולטאַטן (באזירט אויף גלייך פאַרשפּרייטונג ייבערפלאַך געגנט פון וועגן 500 ם סק. קילאמעטער), וואָס מיטל אַז איר מאַכן דעם קאָמפּלעקס דיסטאַנסע כעזשבן 20 מאָל פֿאַר דעם אָנפֿרעג אַנשטאָט פון אַ מיליאָן מאָל

    • 21

      מינדערווערטיק גרייַז אין דעם בייַשפּיל ... וואָס וואָלט זיין ין 50 קילאמעטער (נישט 100), ווייַל מיר קוקן אין די "ראַדיוס" פון אונדזער ... קוואַדראַט.

      • 22

        פאַנטאַסטיש עצה! איך האָב טאַקע געארבעט מיט אַ דעוועלאָפּער וואָס האָט געשריבן אַ פונקציע וואָס פּולד די ין קוואַדראַט און דערנאָך אַ רעקורסיווע פונקציע וואָס געמאכט 'סקווערז' אַרום די פּערימעטער צו אַרייַננעמען און ויסשליסן די רוען פונקטן. דער רעזולטאַט איז געווען אַ ינקרעדאַבלי שנעל רעזולטאַט - ער קען אָפּשאַצן מיליאַנז פון פונקטן אין מיקראָסעקאַנדז.

        מיין צוגאַנג אויבן איז באשטימט 'גראָב' אָבער טויגעוודיק. א דאנק, נאכאמאהל!

        • 23

          דאַג,

          איך האָב געפרוווט צו נוצן מיסקל און פפּ צו אָפּשאַצן צי אַ לאַט לאַנג פונט איז ין אַ פילעק. צי איר וויסן אויב דיין דעוועלאָפּער פרייַנד האָט פארעפנטלעכט ביישפילן וועגן ווי צו דערגרייכן דעם אַרבעט? אָדער טאָן איר וויסן גוטע ביישפילן. דאַנקען אין שטייַגן.

  16. 24

    הי אַלעמען, דאָס איז מיין פּרובירן סקל סטאַטעמענט:

    SELECT DISTINCT area_id, (
    (
    (
    acos( sin( ( 13.65 * pi( ) /180 ) ) * sin( (
    `lat_dec` * pi( ) /180 ) ) + cos( ( 13.65 * pi( ) /180 ) ) * cos( (
    `lat_dec` * pi( ) /180 )
    ) * cos( (
    ( 51.02 - `lon_dec` ) * pi( ) /180 )
    )
    )
    ) *180 / pi( )
    ) *60 * 1.1515 * 1.609344
    ) AS distance
    FROM `post_codes` WHERE distance <= 50

    און מיסקל זאגט מיר אַז דיסטאַנסע איז נישט ווי אַ זייַל, איך קען נוצן סדר דורך, איך קענען טאָן עס אָן וואו, און עס אַרבעט, אָבער נישט מיט אים ...

    • 25
  17. 26

    דאָס איז גרויס, אָבער פּונקט ווי די פייגל פליען. עס וואָלט זיין גרויס צו פּרובירן צו ינקאָרפּערייט די Google מאַפּס אַפּי צו דעם עפעס (אפֿשר ניצן ראָודז, אאז"ו ו) נאָר צו געבן אַ געדאַנק מיט אַ אַנדערש פאָרעם פון טראַנספּערטיישאַן. איך נאָך האָבן צו מאַכן אַ סימיאַלייטיד אַנילינג פונקציע אין פפּ אַז קען פאָרשלאָגן אַ עפעקטיוו לייזונג צו דער טראַוואַלינג פאַרקויפער פּראָבלעם. אָבער איך טראַכטן איך קען זיין ביכולת צו רייוז עטלעכע פון ​​דיין קאָד צו טאָן דאָס.

  18. 27

    הי דאָוגלאַס,
    דאַנקען דיר אַזוי פיל פֿאַר דעם אַרטיקל - איר נאָר געראטעוועט מיר אַ פּלאַץ פון צייט.
    נעמען קעיר,
    nimrod @ ישראל

  19. 28

    גוטע אַרטיקל! איך געפֿונען אַ פּלאַץ פון אַרטיקלען וואָס דיסקרייבינג ווי צו רעכענען די ווייַטקייט צווישן צוויי פונקטן, אָבער איך איז טאַקע קוקן פֿאַר די סקל סניפּאַט.

  20. 29
  21. 30
  22. 31
  23. 32
  24. 36

    2 טעג פון פאָרשונג צו לעסאָף געפֿינען דעם בלאַט וואָס סאַלווז מיין פּראָבלעם. איך קוק בעסער מיין WolframAlpha און ברעכן מיין מאַטאַמאַץ. די ענדערונג פון WHERE צו HAVING האט מיין שריפט אין ארבעטן סדר. אדאנק

  25. 37
    • 38

      דאַנקען געאָרגי. איך קעסיידער באַקומען זייַל 'דיסטאַנסע' ניט געפֿונען אַמאָל איך טוישן די וואו צו האָבן עס געארבעט ווי אַ כיין!

  26. 39

    איך ווינטשן דאָס איז געווען דער ערשטער בלאַט איך געפֿונען אויף דעם. נאָך טריינג פילע פאַרשידענע קאַמאַנדז, דאָס איז געווען דער בלויז אַרבעט רעכט און מיט מינימאַל ענדערונגען צו זיין פּאַסיק פֿאַר מיין אייגענע דאַטאַבאַסע.
    דאַנק אַ פּלאַץ!

  27. 40

    איך ווינטשן דאָס איז געווען דער ערשטער בלאַט איך געפֿונען אויף דעם. נאָך טריינג פילע פאַרשידענע קאַמאַנדז, דאָס איז געווען דער בלויז אַרבעט רעכט און מיט מינימאַל ענדערונגען צו זיין פּאַסיק פֿאַר מיין אייגענע דאַטאַבאַסע.
    דאַנק אַ פּלאַץ!

  28. 41
  29. 42
  30. 43
  31. 45
  32. 46
  33. 47
  34. 49
  35. 50

    גרויס שטאָפּן דאָוגלאַס. האָבן איר געפרוווט צו באַקומען די ינטערסעקשאַן פונט געגעבן די לאנג / לאַט / בערינג פון צוויי פונקטן?

  36. 52

    דאַנקען דיר דאָוגלאַס, די SQL Query איז פּונקט וואָס איך דארף און איך געדאַנק איך וואָלט האָבן צו שרייַבן עס זיך. איר'ווע געראטעוועט מיר פון עפשער שעה פון ברייט לאַנדזשאַטוד לערנען ויסבייג!

  37. 53

    איך פאָרזעצן צו באַקומען ערראָרמעססאַגע: אומבאַקאַנט זייַל 'דיסטאַנסע' אין 'ווו פּונקט' אויף די מיסקל אָנפֿרעג.

    • 54

      פעטרוס, ביטע לייענען דורך די אנדערע באַמערקונגען. עס מיינט אַז עטלעכע מענטשן האָבן צו נוצן אַ אַנדערש סינטאַקס פֿאַר WHERE / HAVING.

  38. 55

    דאנק איר פֿאַר דעם גרויס אַרטיקל! פּונקט טעסטעד די קאָד אויף מיין דב און געארבעט גרויס! 

  39. 56
  40. 58

    דאַנקען פֿאַר פּאָסטינג דעם נוציק אַרטיקל,  
    אָבער פֿאַר עטלעכע סיבה איך'ד ווי צו פרעגן
    ווי אַזוי צו באַקומען די ווייַטקייט צווישן קאָאָרדס ין מיסקל דב און קאָואָרדז ינסערטאַד צו PHP דורך באַניצער?
    פֿאַר מער קלאר באַשליסן:
    1. באַניצער דאַרף אַרייַן [יד] פֿאַר סאַלעקטינג די דאַטן פֿון די דב און די קאָאָרדס פון די באַניצער זיך
    2. די PHP טעקע באַקומען די ציל דאַטן (קאָאָרדס) ניצן [יד] און דעמאָלט רעכענען די ווייַטקייט צווישן באַניצער און ציל פונט

    אָדער קענען נאָר באַקומען דיסטאַנסע פֿון די קאָד ונטער?

    $ qry = “SELECT *, (((acos (sin ((“. $ latitude. ”* pi () / 180)) * sin ((` Latitude` * pi () / 180)) + cos ((“. $ ברייט. ”* pi () / 180)) * cos ((` ברייט` * pi () / 180)) * cos ((((. $ Longitude. - Longitude`) pi () / 180) ))) * 180 / pi ()) * 60 * 1.1515 * 1.609344) ווי ווייַטקייט פֿון `MyTable` WHERE distance> =“. $ Distance. ” >>>> קען איך "נעמען" די ווייַטקייט פון דאָ?
    א דאנק, נאכאמאהל,
    טימי ז

  41. 60

    גוט, אַלץ וואָס איך געפרוווט איז נישט ארבעטן. איך מיינען, וואָס איך האָבן אַרבעט, אָבער די דיסטאַנסאַז זענען אַוועק.

    קען ווער עס יז זען וואָס איז פאַלש מיט דעם קאָד?

    אויב (יסעט ($ _ פּאָסט ['דערלאנגט'])) {$ ז = $ _ פּאָסט ['פּאָסטקאָדע']; $ ר = $ _ פּאָסט ['ראַדיוס']; ווידערקאָל “רעזולטאַטן פֿאַר“. $ ז; $ sql = mysql_query (“SELECT DISTINCT m.zipcode, m.MktName, m.LocAddSt, m.LocAddCity, m.LocAddState, m.x1, m.y1, m.verified, z1.lat, z2.lon, z1. שטאָט, z1.state פֿון mrk m, פאַרשלעסלען z1, פאַרשלעסלען z2 וואו m.zip קאָדע = z1. זיפּקאָדע און Z2. זיפּקאָדע = $ z AND (3963 * acos (truncate (sin (z2.lat / 57.2958) * sin (m. y1 / 57.2958) + cos (z2.lat / 57.2958) * cos (m.y1 / 57.2958) * cos (m.x1 / 57.2958 - z2.lon / 57.2958), 8))) <= $ r ") אָדער שטאַרבן (mysql_error ()); while ($ row = mysql_fetch_array ($ sql)) {$ store1 = $ row ['MktName']. "”; $ קראָם = $ רודערן ['LocAddSt']. ””; $ store. = $ row ['LocAddCity']. ”,“. $ row ['LocAddState']. ” “. $ רודערן ['פּאָסטקאָדע']; $ לאַטיטוד 1 = $ רודערן ['לאַט']; $ לאָנגיטוד 1 = $ רודערן ['לאָן']; $ לאַטאַטוד 2 = $ רודערן ['y1']; $ לאָנגיטוד 2 = $ רודערן ['קס 1']; $ שטאָט = $ רודע ['שטאָט']; $ שטאַט = $ רודערן ['שטאַט']; $ דיס = getnew ($ לאַטיטוד 1, $ לאָנגיטוד 1, $ לאַטיטוד 2, $ לאָנגיטוד 2, $ אַפּאַראַט = 'מי'); // $ דיס = ווייַטקייט ($ לאַט 1, $ לאָנ 1, $ לאַט 2, $ לאָנ 2); $ וועראַפייד = $ רודערן ['וועראַפייד']; if ($ verified == '1') {echo “”; ווידערקאָל "". $ קראָם. ""; echo $ דיס. ”מייל (s) אַוועק”; ווידערקאָל “”; } אַנדערש {ווידערקאָל “”. $ קראָם. ””; echo $ דיס. ”מייל (s) אַוועק”; ווידערקאָל “”; }}}

    מיין פונקטיאָנס.פפּ קאָד
    פֿונקציע getnew ($ latitude1, $ longitude1, $ latitude2, $ longitude2, $ unit = 'Mi') {$ theta = $ longitude1 - $ longitude2; $ ווייַטקייט = (sin (deg2rad ($ latitude1)) * sin (deg2rad ($ latitude2))) + (cos (deg2rad ($ latitude1)) * cos (deg2rad ($ latitude2)) * cos (deg2rad ($ theta)) ); $ ווייַטקייט = אַקאָס ($ ווייַטקייט); $ ווייַטקייט = rad2deg ($ ווייַטקייט); $ ווייַטקייט = $ ווייַטקייט * 60 * 1.1515; באַשטימען ($ אַפּאַראַט) {פאַל 'מי': ברעכן; קאַסע 'Km': $ distance = $ distance * 1.609344; } צוריקקומען (קייַלעכיק ($ ווייַטקייט, 2)); }

    דאנק איר אין שטייַגן

  42. 61
  43. 62

    היי דאָוגלאַס, גרויס אַרטיקל. איך האָב געפֿונען דיין דערקלערונג פון די דזשיאַגראַפיקאַל קאַנסעפּס און די קאָד טאַקע טשיקאַווע. מייַן בלויז פאָרשלאָג איז צו אָרט און ינדענט די קאָד פֿאַר אַרויסווייַזן (פֿאַר בייַשפּיל סטאַקקאָווערפלאָוו). איך פֿאַרשטיין אַז איר ווילן צו קאַנסערוו פּלאַץ, אָבער קאַנווענשאַנאַל קאָד ספּייסינג / ינדענטיישאַן וואָלט מאַכן עס פיל גרינגער פֿאַר מיר, ווי אַ פּראָגראַמיסט, צו לייענען און דייסעקט. סייַ ווי סייַ, דאָס איז אַ קליין זאַך. האַלטן די גרויס אַרבעט.

    • 63

      דאַנקען! איך'ווע מאַדאַפייד דעם פּאָסטן אַ ביסל ... אָבער די יקווייזשאַנז נעמען אַזוי פיל פּלאַץ און זענען אַזוי לאַנג אַז איך בין נישט זיכער אַז עס העלפּס צו פיל.

  44. 64
  45. 65

    דאָ בשעת ניצן מיט פונקציע, מיר באַקומען איין טיפּ פון דיסטאַנסע .. בשעת ניצן די אָנפֿרעג, עס קומט אַן אנדערע טיפּ פון דיסטאַנסע

  46. 66
  47. 67
  48. 68
  49. 69
  50. 70

    עס מיינט פאַסטער (מיסקל 5.9) צו נוצן צוויי מאָל די פאָרמולע אין די סעלעקטירן און ווו:
    $ פאָרמולע = “((((acos (sin ((“. $ latitude. ”* pi () / 180)) * sin ((` Latitude` * pi () / 180)) + cos ((“. $ latitude. ”* Pi () / 180)) * cos ((` Latitude` * pi () / 180)) * cos (((“. $ Longitude.” - `Longitude`) * pi () / 180)))) * 180 / פּי ()) * 60 * 1.1515 * 1.609344) ”;
    $ sql = 'SELECT *,'. $ פאָרמולע. ' ווי ווייַטקייט פֿון טיש וואו '.. $ פאָרמולע.' <= '. $ ווייַטקייט;

  51. 71
  52. 72

    א גרויסן דאַנק פֿאַר שערן דעם אַרטיקל. עס איז זייער נוציק.
    ערשטער, PHP איז באשאפן ווי אַ פּשוט סקריפּטינג פּלאַטפאָרמע גערופֿן "פערזענלעכע היים בלאַט". נאָוואַדייַס PHP (דער קורץ פֿאַר Hypertext Preprocessor) איז אַן אָלטערנאַטיוו פון די Microsoft ASP אַקטיווע סערווירער בלעטער (ASP) טעכנאָלאָגיע.

    פפּ איז אַן אָפֿן מקור סערווערס זייַט שפּראַך וואָס איז גענוצט פֿאַר שאפן דינאַמיש וועב זייַטלעך. עס קענען זיין עמבעדיד אין HTML. פפּ איז יוזשאַוואַלי געניצט אין קאַנדזשאַנגקשאַן מיט אַ MySQL דייטאַבייס אויף Linux / UNIX וועב סערווערס. עס איז מיסטאָמע די מערסט פאָלקס סקריפּטינג שפּראַך.

  53. 73

    איך געפונען אויבן לייזונג איז נישט ארבעטן רעכט.
    איך דאַרפֿן צו טוישן צו:

    $ qqq = “SELECT *, (((acos (sin ((“. $ latitude. ”* pi () / 180)) * sin ((` latt` * pi () / 180)) + cos ((”. $ ברייט. "* pi () / 180)) * cos ((` latt` * pi () / 180)) * cos (((". $ longitude." - `longt`) * pi () / 180) ))) * 180 / פּי ()) * 60 * 1.1515) ווי ווייַטקייט פֿון `רעגיסטרירן`“;

  54. 75

    דאַנקען דיר האר ווראָקינג בישליימעס .. אָבער איך האָבן איין קשיא אויב איך ווילן צו רעזולטאַט אָן דעצימאַל פונט, וואָס קען איך טאָן ..?

    דאַנק אין שטייַגן.

  55. 76

    העלא, ביטע איך טאַקע דאַרפֿן דיין הילף אין דעם.

    איך האָב באַקומען אַ בעטן צו מיין וועב סערווער http://localhost:8000/users/findusers/53.47792/-2.23389/20/
    53.47792 = $ ברייט
    -2.23389 = $ לאַנדזשאַטוד
    און 20 = די ווייַטקייט איך ווילן צו צוריקקריגן

    אָבער מיט איר פאָרמולע, עס ריטריווז אַלע ראָוז אין מיין דב

    $ רעזולטאַטן = DB :: סעלעקטירן (DB :: רוי (“SELECT *, (((acos (sin ((“. $ latitude. ”* pi () / 180)) * sin ((lat * pi () / 180 )) + cos ((“. $ latitude.” * pi () / 180)) * cos ((lat * pi () / 180)) * cos (((“. $ longitude.” - lng) * pi ( ) / 180)))) * 180 / pi ()) * 60 * 1.1515 * 1.609344) ווי ווייַטקייט פֿון מאַרקערס HAVING distance> = “. $ Distance));

    [{"Id": 1, "name": "Frankie Johnnie & Luigo Too", "address": "939 W El Camino Real, Mountain View, CA", "lat": 37.386337280273, "lng": - 122.08582305908, ”Distance”: 16079.294719663}, {“id”: 2, ”name”: “Amici's East Coast Pizzeria”, ”address”: ”790 Castro St, Mountain View, CA”, ”lat”: 37.387138366699, ”lng”: -122.08323669434, ”distance”: 16079.175940152}, {“id”: 3, ”name”: ”Kapp's Pizza Bar & Grill”, ”address”: ”191 Castro St, Mountain View, CA”, ”lat”: 37.393886566162, "לנג": - 122.07891845703, "דיסטאַנסע": 16078.381373826}, {"יד": 4, "נאָמען": "קייַלעכיק טיש פּיצאַ: Mountain View", "אַדרעס": "570 N שאָרליין בלווד, Mountain View, CA", "Lat": 37.402652740479, "lng": - 122.07935333252, "distance": 16077.420540582}, {"id": 5, "name": "Tony & Alba's Pizza & Pasta", "address": "619 Escuela Ave, Mountain View, CA "," lat ": 37.394012451172," lng ": - 122.09552764893," distance ": 16078.563225154}, {" id ": 6," name ":" Oregano's Wood-Fired Pizza "," address ":" 4546 El Camino Real, Los Altos, CA ”,” lat ”: 37.401725769043,” lng ”: - 122.11464691162,” distance ”: 16077.937560795}, {“ id ": 7," name ":" The bars and grills "," address ":" 24 Whiteley Street, Manchester "," lat ": 53.485118865967," lng ": - 2.1828699111938," distance ": 8038.7620112314}]

    איך ווילן צו באַקומען נאָר ראָוז מיט 20 מייל, אָבער עס ברענגט אַלע ראָוז. ביטע וואָס טאָן איך טאָן פאַלש?

  56. 77

    איך בין איר זוכט פֿאַר אַ ענלעך אָנפֿרעג אָבער סטעפּט אַ ביסל - אין קורץ, דאָס איז צו גרופּע אַלע קאָואָרדאַנאַץ ין 2 מייל פון יעדער קאָואָרדאַנאַט און דאַן ציילן ווי פילע קאָואָרדאַנאַץ אין יעדער גרופּע און אַרויסגעבן בלויז איין גרופּע מיט די מערסט קאָואָרדאַנאַץ - אפילו אויב איר האָבן מער ווי איין גרופּע צווישן גרופּעס וואָס האָבן די מערסט נומער פון קאָואָרדאַנאַץ - פשוט אַרויספירן די טראַפ גרופּע פֿון די גרופּעס מיט דער זעלביקער גרעסטן נומער -

וואָס טאָן איר טראַכטן?

דעם פּלאַץ ניצט אַקיסמעט צו רעדוצירן ספּאַם. לערן ווי דיין קאָמענטאַר דאַטע איז פּראַסעסט.