Important changes to repositories hosted on mbed.com
Mbed hosted mercurial repositories are deprecated and are due to be permanently deleted in July 2026.
To keep a copy of this software download the repository Zip archive or clone locally using Mercurial.
It is also possible to export all your personal repositories from the account settings page.
Dependencies: mbed
Rasturizer/Rasturizer.cpp@15:8fbbdefbe720, 2019-03-31 (annotated)
- Committer:
- el17cd
- Date:
- Sun Mar 31 14:56:55 2019 +0000
- Revision:
- 15:8fbbdefbe720
- Parent:
- 14:885915260e25
- Child:
- 16:64cd7bc094f9
Created game class
Who changed what in which revision?
| User | Revision | Line number | New contents of line |
|---|---|---|---|
| el17cd | 1:044238f7bdda | 1 | #include "mbed.h" |
| el17cd | 1:044238f7bdda | 2 | #include "Rasturizer.h" |
| el17cd | 2:a5bc7b3779f7 | 3 | |
| el17cd | 4:759a5c34e239 | 4 | N5110 lcd(PTC9,PTC0,PTC7,PTD2,PTD1,PTC11); |
| el17cd | 3:2e31dfcb712a | 5 | |
| el17cd | 4:759a5c34e239 | 6 | Rasturizer::Rasturizer(){ |
| el17cd | 15:8fbbdefbe720 | 7 | |
| el17cd | 14:885915260e25 | 8 | /*double tempPoints[4][3] = {{43, 2.5, 30}, {43, 2.5, 200}, {43, -2.5, 200}, {43, -2.5, 30}}; |
| el17cd | 14:885915260e25 | 9 | for(int vertex = 0; vertex < 8; vertex++){ |
| el17cd | 14:885915260e25 | 10 | for(int axis = 0; axis < 3; axis++){ |
| el17cd | 14:885915260e25 | 11 | edgePoints[vertex][axis] = tempPoints[vertex][axis]; |
| el17cd | 14:885915260e25 | 12 | } |
| el17cd | 14:885915260e25 | 13 | } |
| el17cd | 14:885915260e25 | 14 | edge.setVerticies(edgePoints); |
| el17cd | 14:885915260e25 | 15 | edge.setVisible(true);*/ |
| el17cd | 14:885915260e25 | 16 | } |
| el17cd | 14:885915260e25 | 17 | |
| el17cd | 15:8fbbdefbe720 | 18 | void Rasturizer::init(){ |
| el17cd | 15:8fbbdefbe720 | 19 | lcd.init(); |
| el17cd | 15:8fbbdefbe720 | 20 | fov = 50; |
| el17cd | 15:8fbbdefbe720 | 21 | } |
| el17cd | 15:8fbbdefbe720 | 22 | |
| el17cd | 14:885915260e25 | 23 | double Rasturizer::xTo2D(double x, double z){ |
| el17cd | 14:885915260e25 | 24 | return x * (fov/z) + 42; |
| el17cd | 14:885915260e25 | 25 | } |
| el17cd | 14:885915260e25 | 26 | |
| el17cd | 14:885915260e25 | 27 | double Rasturizer::yTo2D(double y, double z){ |
| el17cd | 14:885915260e25 | 28 | return y * (fov/z) + 21; |
| el17cd | 4:759a5c34e239 | 29 | } |
| el17cd | 1:044238f7bdda | 30 | |
| el17cd | 11:2cd6341136ca | 31 | void Rasturizer::drawHorizon(double angle){ |
| el17cd | 11:2cd6341136ca | 32 | lcd.drawLine(0, |
| el17cd | 12:b69657862610 | 33 | 21-rint(angle*50), |
| el17cd | 11:2cd6341136ca | 34 | 84, |
| el17cd | 12:b69657862610 | 35 | 21+rint(angle*50), |
| el17cd | 11:2cd6341136ca | 36 | 1);/* |
| el17cd | 14:885915260e25 | 37 | for( int i = 0; i<4; i++){ |
| el17cd | 14:885915260e25 | 38 | edgePoints[i][0] -= angle*50; |
| el17cd | 14:885915260e25 | 39 | } |
| el17cd | 14:885915260e25 | 40 | edge.setVerticies(edgePoints); |
| el17cd | 14:885915260e25 | 41 | drawFace(edge, angle);*/ |
| el17cd | 11:2cd6341136ca | 42 | } |
| el17cd | 11:2cd6341136ca | 43 | |
| el17cd | 11:2cd6341136ca | 44 | void Rasturizer::drawFace(Face face, double angle){ |
| el17cd | 7:15543cb10a14 | 45 | double points[4][3]; |
| el17cd | 4:759a5c34e239 | 46 | for(int vertex = 0; vertex < 4; vertex++){ |
| el17cd | 4:759a5c34e239 | 47 | for(int axis = 0; axis < 3; axis++){ |
| el17cd | 4:759a5c34e239 | 48 | points[vertex][axis] = face.getVertexValue(vertex, axis); |
| el17cd | 4:759a5c34e239 | 49 | } |
| el17cd | 11:2cd6341136ca | 50 | double y = points[vertex][1]; |
| el17cd | 11:2cd6341136ca | 51 | double x = points[vertex][0]; |
| el17cd | 11:2cd6341136ca | 52 | |
| el17cd | 11:2cd6341136ca | 53 | points[vertex][0] = x*cos(angle)-y*sin(angle); |
| el17cd | 11:2cd6341136ca | 54 | points[vertex][1] = y*cos(angle)+x*sin(angle); |
| el17cd | 4:759a5c34e239 | 55 | } |
| el17cd | 6:75031d14fc0d | 56 | |
| el17cd | 14:885915260e25 | 57 | if ((points[0][2] > 12 || points[1][2] > 12 || points[2][2] > 12|| points[3][2] > 12) && face.getVisible()){ |
| el17cd | 14:885915260e25 | 58 | int diffX1 = xTo2D(points[0][0], points[0][2])-xTo2D(points[1][0], points[1][2]); |
| el17cd | 14:885915260e25 | 59 | int diffY1 = yTo2D(points[0][1], points[0][2])-yTo2D(points[1][1], points[1][2]); |
| el17cd | 14:885915260e25 | 60 | int diffX2 = xTo2D(points[2][0], points[2][2])-xTo2D(points[3][0], points[3][2]); |
| el17cd | 14:885915260e25 | 61 | int diffY2 = yTo2D(points[2][1], points[2][2])-yTo2D(points[3][1], points[3][2]); |
| el17cd | 8:a667bc5050c1 | 62 | |
| el17cd | 9:5915fc800824 | 63 | double step = (double)diffY2/(double)diffX2; |
| el17cd | 9:5915fc800824 | 64 | double stepSmall1 = (double)diffX1/(double)diffX2; |
| el17cd | 9:5915fc800824 | 65 | double stepSmall2 = (double)diffY1/(double)diffX2; |
| el17cd | 9:5915fc800824 | 66 | |
| el17cd | 12:b69657862610 | 67 | for(int s = 0; s< abs(diffX2); s++){ |
| el17cd | 14:885915260e25 | 68 | if(diffX2 > 0){ |
| el17cd | 14:885915260e25 | 69 | lcd.drawLine(rint(xTo2D(points[0][0], points[0][2])-stepSmall1*s),//rint((points[0][0])*(40/points[0][2])-stepSmall1*s)+42, |
| el17cd | 14:885915260e25 | 70 | rint(yTo2D(points[0][1], points[0][2])-stepSmall2*s), |
| el17cd | 14:885915260e25 | 71 | rint(xTo2D(points[3][0], points[3][2])+s), |
| el17cd | 14:885915260e25 | 72 | rint(yTo2D(points[3][1], points[3][2])+step*s), |
| el17cd | 14:885915260e25 | 73 | 0); |
| el17cd | 14:885915260e25 | 74 | } |
| el17cd | 14:885915260e25 | 75 | else{ |
| el17cd | 14:885915260e25 | 76 | lcd.drawLine(rint(xTo2D(points[0][0], points[0][2])+stepSmall1*s),//rint((points[0][0])*(40/points[0][2])-stepSmall1*s)+42, |
| el17cd | 14:885915260e25 | 77 | rint(yTo2D(points[0][1], points[0][2])+stepSmall2*s), |
| el17cd | 14:885915260e25 | 78 | rint(xTo2D(points[3][0], points[3][2])-s), |
| el17cd | 14:885915260e25 | 79 | rint(yTo2D(points[3][1], points[3][2])-step*s), |
| el17cd | 14:885915260e25 | 80 | 0); |
| el17cd | 14:885915260e25 | 81 | } |
| el17cd | 7:15543cb10a14 | 82 | } |
| el17cd | 13:f4de03202477 | 83 | } |
| el17cd | 13:f4de03202477 | 84 | if((points[0][2] > 10 || points[1][2] > 10 || points[2][2] > 10|| points[3][2] > 10)){ |
| el17cd | 14:885915260e25 | 85 | for (int i = 0; i < 3; i++){ |
| el17cd | 14:885915260e25 | 86 | lcd.drawLine(rint(xTo2D(points[i][0], points[i][2])), |
| el17cd | 14:885915260e25 | 87 | rint(yTo2D(points[i][1], points[i][2])), |
| el17cd | 14:885915260e25 | 88 | rint(xTo2D(points[i+1][0], points[i+1][2])), |
| el17cd | 14:885915260e25 | 89 | rint(yTo2D(points[i+1][1], points[i+1][2])), |
| el17cd | 14:885915260e25 | 90 | 1); |
| el17cd | 1:044238f7bdda | 91 | } |
| el17cd | 14:885915260e25 | 92 | lcd.drawLine(rint(xTo2D(points[0][0], points[0][2])), |
| el17cd | 14:885915260e25 | 93 | rint(yTo2D(points[0][1], points[0][2])), |
| el17cd | 14:885915260e25 | 94 | rint(xTo2D(points[3][0], points[3][2])), |
| el17cd | 14:885915260e25 | 95 | rint(yTo2D(points[3][1], points[3][2])), |
| el17cd | 14:885915260e25 | 96 | 1); |
| el17cd | 1:044238f7bdda | 97 | } |
| el17cd | 4:759a5c34e239 | 98 | } |
| el17cd | 9:5915fc800824 | 99 | |
| el17cd | 11:2cd6341136ca | 100 | void Rasturizer::print(const char *text){ |
| el17cd | 11:2cd6341136ca | 101 | lcd.printString(text, 0, 0); |
| el17cd | 11:2cd6341136ca | 102 | } |
| el17cd | 11:2cd6341136ca | 103 | |
| el17cd | 4:759a5c34e239 | 104 | void Rasturizer::clear(){ |
| el17cd | 4:759a5c34e239 | 105 | lcd.clear(); |
| el17cd | 4:759a5c34e239 | 106 | } |
| el17cd | 4:759a5c34e239 | 107 | |
| el17cd | 4:759a5c34e239 | 108 | void Rasturizer::refresh(){ |
| el17cd | 4:759a5c34e239 | 109 | lcd.refresh(); |
| el17cd | 14:885915260e25 | 110 | } |
| el17cd | 14:885915260e25 | 111 | |
| el17cd | 14:885915260e25 | 112 | void Rasturizer::invertMode(){ |
| el17cd | 14:885915260e25 | 113 | lcd.inverseMode(); |
| el17cd | 14:885915260e25 | 114 | } |
| el17cd | 14:885915260e25 | 115 | |
| el17cd | 14:885915260e25 | 116 | void Rasturizer::normalMode(){ |
| el17cd | 14:885915260e25 | 117 | lcd.normalMode(); |
| el17cd | 1:044238f7bdda | 118 | } |