17 KiB
விண்வெளி விளையாட்டு உருவாக்கம் பகுதி 2: ஹீரோ மற்றும் மான்ஸ்டர்களை கேன்வாஸ் மீது வரையுங்கள்
முன்-வகுப்பு வினாடி வினா
கேன்வாஸ்
கேன்வாஸ் என்பது ஒரு HTML உருப்படி, இது இயல்பாக எந்த உள்ளடக்கமும் இல்லாமல் வெற்று தாளாக இருக்கும். நீங்கள் அதில் வரைய வேண்டும்.
✅ கேன்வாஸ் API பற்றி மேலும் படிக்கவும் MDN-ல்.
இது பொதுவாக பக்கத்தின் உடலின் ஒரு பகுதியாக இவ்வாறு அறிவிக்கப்படுகிறது:
<canvas id="myCanvas" width="200" height="100"></canvas>
மேலே, id, width மற்றும் height அமைக்கப்பட்டுள்ளது.
id: இதை அமைத்தால், நீங்கள் அதில் தொடர்பு கொள்ள தேவையான நேரத்தில் ஒரு குறிப்பை பெறலாம்.width: இது உருப்படியின் அகலம்.height: இது உருப்படியின் உயரம்.
எளிய வடிவங்களை வரையுதல்
கேன்வாஸ் பொருள்களை வரைய கார்டீசியன் கோட்பாட்டை பயன்படுத்துகிறது. எனவே, இது x-அச்சு மற்றும் y-அச்சு மூலம் எதாவது எங்கு உள்ளது என்பதை வெளிப்படுத்துகிறது. 0,0 இடம் மேல் இடது மூலையில் இருக்கும், மற்றும் கீழ் வலது மூலை உங்கள் கேன்வாஸ் அகலம் மற்றும் உயரமாக இருக்கும்.
படம் MDN மூலம்
கேன்வாஸ் உருப்படியில் வரைய நீங்கள் பின்வரும் படிகளை கடந்து செல்ல வேண்டும்:
- கேன்வாஸ் உருப்படிக்கு ஒரு குறிப்பை பெறுங்கள்.
- கேன்வாஸ் உருப்படியில் இருக்கும் Context உருப்படிக்கு ஒரு குறிப்பை பெறுங்கள்.
- Context உருப்படியை பயன்படுத்தி ஒரு வரையல் செயல்பாட்டை செய்யுங்கள்.
மேலே உள்ள படிகளுக்கான குறியீடு பொதுவாக இவ்வாறு இருக்கும்:
// draws a red rectangle
//1. get the canvas reference
canvas = document.getElementById("myCanvas");
//2. set the context to 2D to draw basic shapes
ctx = canvas.getContext("2d");
//3. fill it with the color red
ctx.fillStyle = 'red';
//4. and draw a rectangle with these parameters, setting location and size
ctx.fillRect(0,0, 200, 200) // x,y,width, height
✅ கேன்வாஸ் API பெரும்பாலும் 2D வடிவங்களில் கவனம் செலுத்துகிறது, ஆனால் நீங்கள் 3D உருப்படிகளையும் ஒரு வலைத்தளத்தில் வரையலாம்; இதற்காக நீங்கள் WebGL API பயன்படுத்தலாம்.
கேன்வாஸ் API மூலம் நீங்கள் பலவகையான பொருட்களை வரையலாம்:
- கணித வடிவங்கள், நாம் ஏற்கனவே ஒரு செவ்வகத்தை வரைய எப்படி என்பதை காட்டியுள்ளோம், ஆனால் நீங்கள் மேலும் பலவற்றை வரையலாம்.
- உரைகள், நீங்கள் எந்த எழுத்துரு மற்றும் நிறத்திலும் உரையை வரையலாம்.
- படங்கள், நீங்கள் ஒரு .jpg அல்லது .png போன்ற படக்கோப்பை அடிப்படையாகக் கொண்டு ஒரு படத்தை வரையலாம்.
✅ முயற்சிக்கவும்! நீங்கள் ஒரு செவ்வகத்தை வரைய எப்படி என்பதை அறிந்துள்ளீர்கள், ஒரு வட்டத்தை ஒரு பக்கத்தில் வரைய முடியுமா? CodePen-ல் சில சுவாரஸ்யமான கேன்வாஸ் வரையல்களை பாருங்கள். இதோ ஒரு மிகவும் ஆச்சரியமான உதாரணம்.
ஒரு படக்கோப்பை ஏற்றவும் மற்றும் வரையவும்
நீங்கள் ஒரு படக்கோப்பை ஏற்ற Image பொருளை உருவாக்கி அதன் src பண்பை அமைக்க வேண்டும். பின்னர், அது பயன்படுத்த தயாராக இருக்கும் போது அறிய load நிகழ்வை கேட்க வேண்டும். குறியீடு இவ்வாறு இருக்கும்:
படக்கோப்பு ஏற்றுதல்
const img = new Image();
img.src = 'path/to/my/image.png';
img.onload = () => {
// image loaded and ready to be used
}
படக்கோப்பு ஏற்றல் முறை
மேலே உள்ளதை ஒரு அமைப்பில் இவ்வாறு சுற்றி அமைப்பது பரிந்துரைக்கப்படுகிறது, இதனால் அதை பயன்படுத்த எளிதாக இருக்கும், மேலும் அது முழுமையாக ஏற்றப்பட்ட பிறகே நீங்கள் அதை மாற்ற முயற்சிக்க வேண்டும்:
function loadAsset(path) {
return new Promise((resolve) => {
const img = new Image();
img.src = path;
img.onload = () => {
// image loaded and ready to be used
resolve(img);
}
})
}
// use like so
async function run() {
const heroImg = await loadAsset('hero.png')
const monsterImg = await loadAsset('monster.png')
}
விளையாட்டு பொருட்களை திரையில் வரைய உங்கள் குறியீடு இவ்வாறு இருக்கும்:
async function run() {
const heroImg = await loadAsset('hero.png')
const monsterImg = await loadAsset('monster.png')
canvas = document.getElementById("myCanvas");
ctx = canvas.getContext("2d");
ctx.drawImage(heroImg, canvas.width/2,canvas.height/2);
ctx.drawImage(monsterImg, 0,0);
}
இப்போது உங்கள் விளையாட்டை உருவாக்கத் தொடங்கும் நேரம்
என்ன உருவாக்க வேண்டும்
நீங்கள் ஒரு கேன்வாஸ் உருப்படியுடன் ஒரு வலைப்பக்கத்தை உருவாக்க வேண்டும். இது ஒரு கருப்பு திரை 1024*768 அளவில் காட்ட வேண்டும். நாங்கள் உங்களுக்கு இரண்டு படங்களை வழங்கியுள்ளோம்:
பரிந்துரைக்கப்பட்ட படிகள்
your-work துணை கோப்பகத்தில் உருவாக்கப்பட்ட கோப்புகளை கண்டறியவும். இது பின்வருவனவற்றை கொண்டிருக்க வேண்டும்:
-| assets
-| enemyShip.png
-| player.png
-| index.html
-| app.js
-| package.json
இந்த கோப்பகத்தின் நகலை Visual Studio Code-ல் திறக்கவும். உங்களுக்கு ஒரு உள்ளூர் மேம்பாட்டு சூழல் அமைப்பு தேவை, Visual Studio Code உடன் NPM மற்றும் Node நிறுவப்பட்டிருக்க வேண்டும். உங்கள் கணினியில் npm அமைக்கப்படவில்லை என்றால், அதை எப்படி செய்வது என்பதை பாருங்கள்.
உங்கள் திட்டத்தை your_work கோப்பகத்தில் வழிநடத்துவதன் மூலம் தொடங்குங்கள்:
cd your-work
npm start
மேலே உள்ளது http://localhost:5000 முகவரியில் ஒரு HTTP சர்வரை தொடங்கும். ஒரு உலாவியில் அந்த முகவரியை உள்ளிடவும். இது தற்போது ஒரு வெற்று பக்கம், ஆனால் அது மாறும்.
குறிப்பு: உங்கள் திரையில் மாற்றங்களைப் பார்க்க உலாவியை புதுப்பிக்கவும்.
குறியீடு சேர்க்கவும்
கீழே உள்ளதை தீர்க்க your-work/app.js-ல் தேவையான குறியீட்டை சேர்க்கவும்:
-
கேன்வாஸ் வரைய கருப்பு பின்னணி கொண்டது
குறிப்புரை:
/app.js-ல் சரியான TODO-க்கு கீழே இரண்டு வரிகளைச் சேர்க்கவும்,ctxஉருப்படியை கருப்பாக அமைத்து மேல்/இடது இணைப்பு 0,0 மற்றும் கேன்வாஸ் அகலம் மற்றும் உயரத்துடன் சமமாக அமைக்கவும். -
உருவங்களை ஏற்றவும்
குறிப்புரை:
await loadTextureமற்றும் பட பாதையை வழங்கி வீரர் மற்றும் எதிரி படங்களைச் சேர்க்கவும். நீங்கள் அவற்றை திரையில் இன்னும் காண முடியாது! -
ஹீரோவை திரையின் மையத்தில் கீழ் பாதியில் வரையவும்
குறிப்புரை:
drawImageAPI-யை பயன்படுத்தி heroImg-ஐ திரையில் வரையவும்,canvas.width / 2 - 45மற்றும்canvas.height - canvas.height / 4)அமைக்கவும். -
5*5 மான்ஸ்டர்களை வரையவும்
குறிப்புரை: இப்போது எதிரிகளை திரையில் வரைய குறியீட்டை Uncomment செய்யலாம். பின்னர்,
createEnemiesசெயல்பாட்டிற்கு சென்று அதை உருவாக்கவும்.முதலில், சில மாறிகள் அமைக்கவும்:
const MONSTER_TOTAL = 5; const MONSTER_WIDTH = MONSTER_TOTAL * 98; const START_X = (canvas.width - MONSTER_WIDTH) / 2; const STOP_X = START_X + MONSTER_WIDTH;பின்னர், மான்ஸ்டர்களின் வரிசையை திரையில் வரைய ஒரு மடக்கத்தை உருவாக்கவும்:
for (let x = START_X; x < STOP_X; x += 98) { for (let y = 0; y < 50 * 5; y += 50) { ctx.drawImage(enemyImg, x, y); } }
முடிவு
முடிந்த முடிவு இவ்வாறு இருக்க வேண்டும்:
தீர்வு
முதலில் அதை நீங்கள் முயற்சிக்கவும், ஆனால் நீங்கள் சிக்கலாக இருந்தால், தீர்வு பார்க்கவும்.
🚀 சவால்
நீங்கள் 2D-க்கு மையமாக இருக்கும் கேன்வாஸ் API பற்றி கற்றுக்கொண்டீர்கள்; WebGL API பற்றி பாருங்கள், மற்றும் ஒரு 3D பொருளை வரைய முயற்சிக்கவும்.
வகுப்புக்குப் பின் வினாடி வினா
வகுப்புக்குப் பின் வினாடி வினா
மதிப்பீடு மற்றும் சுயபயிற்சி
கேன்வாஸ் API பற்றி மேலும் படித்து அறியவும்.
பணிக்கட்டளை
கேன்வாஸ் API-யுடன் விளையாடுங்கள்
அறிவிப்பு:
இந்த ஆவணம் Co-op Translator என்ற AI மொழிபெயர்ப்பு சேவையை பயன்படுத்தி மொழிபெயர்க்கப்பட்டுள்ளது. நாங்கள் துல்லியத்திற்காக முயற்சிக்கிறோம், ஆனால் தானியங்கி மொழிபெயர்ப்புகளில் பிழைகள் அல்லது தவறுகள் இருக்கக்கூடும் என்பதை கவனத்தில் கொள்ளவும். அதன் சொந்த மொழியில் உள்ள மூல ஆவணம் அதிகாரப்பூர்வ ஆதாரமாக கருதப்பட வேண்டும். முக்கியமான தகவல்களுக்கு, தொழில்முறை மனித மொழிபெயர்ப்பு பரிந்துரைக்கப்படுகிறது. இந்த மொழிபெயர்ப்பைப் பயன்படுத்துவதால் ஏற்படும் எந்த தவறான புரிதல்களுக்கும் அல்லது தவறான விளக்கங்களுக்கும் நாங்கள் பொறுப்பல்ல.



