टकराव का पता लगाने पुराने उन में से एक है बनाता है के लिए इस उत्तर को देखने छिपा हुआ एक गेम कोडिंग की समस्याएं। आम तौर पर लोग अंधेरे पेंगुइन लेते हैं कुछ फैशन में सटीक होने का दृष्टिकोण जहां आपका स्थिर मानचित्र है और जगह योग्य नहीं है। अगला कदम सबसे कुशल टकराव मानचित्र निर्दिष्ट करने के लिए एक तरीका के साथ आना है।
आप नहीं चाहते हैं कि आपका माउस अपने माउस को ले जाने वाले उपयोगकर्ता के जवाब में गणित का एक टन करे - इसे छोटा और तेज़ होना चाहिए - इसलिए कुछ जल्दी से सटीक होना महत्वपूर्ण है।
यदि आपका नक्शा ग्रिड है, तो आपके पास आपका जवाब सही है - टक्कर नक्शा एक सटीक 2 डी सरणी है - मूल रूप से ग्रिड पर प्रत्येक स्थान के लिए पिक्सेल के साथ एक बहुत ही छोटी और सफेद छवि। सफेद पिक्सेल (1) प्ले करने योग्य और काले पिक्सेल (0) नहीं हैं। आप सिर्फ एक लुकअप के रूप में सच/गलत के इस 2 डी सरणी का उपयोग करते हैं। अगर आप स्मृति को सहेजना चाहते हैं तो आप ग्रिड पर 32 रिक्त स्थान की प्रत्येक स्ट्रिप को एक बिट फ्लैग में बंडल कर सकते हैं।
यदि आपका नक्शा ग्रिड नहीं है, तो आप अभी भी चीजों को पूर्वनिर्धारित करना चाहते हैं, लेकिन रणनीति थोड़ा अधिक जटिल है। पहली संभावना है कि थोड़ा उच्च रिज़ॉल्यूशन टकराव मानचित्र बनाने के लिए हितेश की तरह गणित करना है, और फिर शेष ग्रिड रणनीति के समान है - उदाहरण के लिए यदि प्रत्येक 4x4 पिक्सल ब्लॉक एक टक्कर प्रविष्टि था, तो क्या एक टावर हो सकता है यह एक परीक्षण है कि इसके निर्देशांक पर्याप्त 1 के शीर्ष पर होने का परीक्षण करते हैं - आपको 100% परीक्षणों की आवश्यकता हो सकती है, या आप उन्हें थोड़ी सी पहुंचने दे सकते हैं और कह सकते हैं कि 75% परीक्षण 1 है।
यदि यह अभी भी पर्याप्त जानकारी नहीं है, तो आप इन अधिक जटिल बहुभुज परीक्षण कर सकते हैं, लेकिन आप उन्हें जितना संभव हो सके उतना आसान बनाना चाहते हैं। एक सटीक ग्रिड का उपयोग नहीं करते समय, सबसे सरल 2 डी टकराव परीक्षण 2 मंडल होता है - आप बस अपने केंद्रों के बीच की दूरी की गणना करते हैं और जांचते हैं कि यह उनके त्रिज्या के योग से अधिक या कम है या नहीं। यदि आप अपने राक्षस पथ को मंडलियों के निशान में पूर्ववत करते हैं, तो अगला चरण उन मंडलियों को विभाजित करना है ... अनुमान लगाएं कि ... एक ग्रिड। यह प्रत्येक चेक को नक्शे पर हर एक सर्कल का परीक्षण करने से रोकता है। यह टकराव मानचित्र में इन सर्किलों की एक बड़ी संख्या रखने की अनुमति देता है, क्योंकि टकराव परीक्षण सबसे पहले टॉवर प्रविष्टियों में एक गलती प्रविष्टियों में एक लुकअप है, इसके बाद यह जांच कर रहा है कि क्या यह केवल उन मंडलियों के साथ टकरा रहा है, जो इसके निकट हैं पूरा नक्शा यह ध्यान रखना महत्वपूर्ण है कि सर्कल सूचियों के इस पूर्ववर्ती ग्रिड में अक्सर कई पड़ोसी ग्रिड प्रविष्टियों में एक ही सर्कल होता है, क्योंकि प्रत्येक ग्रिड एंट्री जिसमें किसी दिए गए सर्कल के किसी भी हिस्से में उसके कोलाइड चेकलिस्ट में उस सर्कल का होना चाहिए।
पहले 2 ग्रिड दृष्टिकोणों के बारे में अच्छी चीजों में से एक यह है कि यह स्वयं को क्यूए के लिए बहुत आसान है - सचमुच टकराव मानचित्र को एक छवि के रूप में संग्रहीत करें और यह सुनिश्चित करने के लिए दृष्टि से निरीक्षण करें कि यह उस मानचित्र के लिए सही दिखता है। यदि आप उन्हें उत्पन्न करने के लिए कोड लिखना नहीं चाहते हैं तो आप इसे हाथ से भी खींच सकते हैं।
सर्कल दृष्टिकोण आपको वैध वक्र देता है और बेहतर टकराए किनारे के विस्तार का कारण बन सकता है, लेकिन यह जांचना मुश्किल है कि किसी भी मानचित्र में खराब टकराव मानचित्र नहीं हैं। नक्शा पीढ़ी के उपकरण को लिखने के लिए यह और भी काम है।
शुभकामनाएं!
स्रोत
2011-01-27 02:49:23