From 2c8e14a514f5aa76ecd8972a6189fbf1e0215e06 Mon Sep 17 00:00:00 2001 From: MohiniMehta Date: Fri, 24 May 2024 11:36:43 +0530 Subject: [PATCH 1/4] added the operation for 2d vectors --- .vscode/settings.json | 3 ++ Calculators/Vector-Calculator/index.html | 9 ++++++ Calculators/Vector-Calculator/script.js | 40 ++++++++++++++++++------ Calculators/Vector-Calculator/style.css | 12 +++++++ 4 files changed, 54 insertions(+), 10 deletions(-) create mode 100644 .vscode/settings.json diff --git a/.vscode/settings.json b/.vscode/settings.json new file mode 100644 index 000000000..6f3a2913e --- /dev/null +++ b/.vscode/settings.json @@ -0,0 +1,3 @@ +{ + "liveServer.settings.port": 5501 +} \ No newline at end of file diff --git a/Calculators/Vector-Calculator/index.html b/Calculators/Vector-Calculator/index.html index 9d6222038..a4c389d88 100644 --- a/Calculators/Vector-Calculator/index.html +++ b/Calculators/Vector-Calculator/index.html @@ -23,6 +23,15 @@

Vector Calculator

X: Y: +
+ + + +
diff --git a/Calculators/Vector-Calculator/script.js b/Calculators/Vector-Calculator/script.js index d1f6e57e1..5dadf4210 100644 --- a/Calculators/Vector-Calculator/script.js +++ b/Calculators/Vector-Calculator/script.js @@ -9,18 +9,38 @@ function calc() { ay = parseInt(document.getElementById("ay").value); bx = parseInt(document.getElementById("bx").value); by = parseInt(document.getElementById("by").value); + + const operation = document.getElementById("operation").value; + if (isNaN(ay) || isNaN(bx) || isNaN(by)) { alert("Please enter proper values for x and y"); return; } - var cx = ax + bx; - var cy = ay + by; - var cxdot = ax * bx; - var cydot = ay * by; - var angle = radToDeg(Math.atan(cy / cx)); - // A + B, angel = tan^-1(y/x) - var easyAnswerHighlight = '
\
\ Vector C = \
\ <' + cx + ", " + cy + '>

\ -
\
\ Vector C Dot = \
\ <' + cxdot + ", " + cydot + '>

\ -
\
\ Angle = \
\ ' + angle + '
'; - document.getElementById("results").innerHTML = easyAnswerHighlight; + let result, angleResult; + switch (operation) { + case "add": + const cx_add = ax + bx; + const cy_add = ay + by; + result = `Vector C Add = <${cx_add}, ${cy_add}>`; + break; + case "subtract": + const cx_subtract = ax - bx; + const cy_subtract = ay - by; + result = `Vector C Subtract = <${cx_subtract}, ${cy_subtract}>`; + break; + case "dot": + const dotProduct = ax * bx + ay * by; + const magnitudeA = Math.sqrt(ax * ax + ay * ay); + const magnitudeB = Math.sqrt(bx * bx + by * by); + const cosineTheta = dotProduct / (magnitudeA * magnitudeB); + const angleRadians = Math.acos(cosineTheta); + const angleDegrees = radToDeg(angleRadians); + result = `Vector C Dot = ${dotProduct}`; + angleResult = `Angle between vectors = ${angleDegrees} degrees`; + break; + default: + result = "Invalid operation"; + } + document.getElementById("results").innerHTML = result + "
" + (angleResult ? angleResult : ""); + } \ No newline at end of file diff --git a/Calculators/Vector-Calculator/style.css b/Calculators/Vector-Calculator/style.css index 6ee653dd3..3038f390e 100644 --- a/Calculators/Vector-Calculator/style.css +++ b/Calculators/Vector-Calculator/style.css @@ -65,4 +65,16 @@ input { .vect>p { font-weight: bold; +} +/*Added Css Property*/ +.operation{ + margin: 10px; +} +.operation label{ + color: #C5EBFE; + font-size: 20px; +} +.operation select{ + color: #1d0a4c; + font-size: 20px; } \ No newline at end of file From bd82b932e912afdd32a19d1cb64747658b72361d Mon Sep 17 00:00:00 2001 From: MohiniMehta Date: Tue, 28 May 2024 09:54:58 +0530 Subject: [PATCH 2/4] gave some space below and above the Operation box, and also styled that box same as that of X or Y --- Calculators/Vector-Calculator/style.css | 13 ++++++++----- 1 file changed, 8 insertions(+), 5 deletions(-) diff --git a/Calculators/Vector-Calculator/style.css b/Calculators/Vector-Calculator/style.css index 3038f390e..0e5e15bbe 100644 --- a/Calculators/Vector-Calculator/style.css +++ b/Calculators/Vector-Calculator/style.css @@ -68,13 +68,16 @@ input { } /*Added Css Property*/ .operation{ - margin: 10px; + margin: 35px 0; /* Increased margin for space above and below */ } -.operation label{ +.operation label{ color: #C5EBFE; - font-size: 20px; + font-size: 24px; } .operation select{ - color: #1d0a4c; - font-size: 20px; + border: 0; + border-radius: 5px; /*added same border radius as x & y input*/ + font-size: 16px; /*added same font size as x & y input*/ + padding: 10px; /*added same padding as x & y input*/ + margin: 10px; /*added same margin as x & y input*/ } \ No newline at end of file From eac1140f581420371e6fe489912814fda11a426c Mon Sep 17 00:00:00 2001 From: Rakesh Roshan Date: Fri, 31 May 2024 14:18:39 +0530 Subject: [PATCH 3/4] Delete .vscode directory --- .vscode/settings.json | 3 --- 1 file changed, 3 deletions(-) delete mode 100644 .vscode/settings.json diff --git a/.vscode/settings.json b/.vscode/settings.json deleted file mode 100644 index 6f3a2913e..000000000 --- a/.vscode/settings.json +++ /dev/null @@ -1,3 +0,0 @@ -{ - "liveServer.settings.port": 5501 -} \ No newline at end of file From bf5e26f404ecd90c1b8bb5d0eebc0bd185a985bf Mon Sep 17 00:00:00 2001 From: Rakesh Roshan Date: Fri, 31 May 2024 14:21:12 +0530 Subject: [PATCH 4/4] Update style.css --- Calculators/Vector-Calculator/style.css | 32 +++++++++++-------------- 1 file changed, 14 insertions(+), 18 deletions(-) diff --git a/Calculators/Vector-Calculator/style.css b/Calculators/Vector-Calculator/style.css index 0e5e15bbe..306163b33 100644 --- a/Calculators/Vector-Calculator/style.css +++ b/Calculators/Vector-Calculator/style.css @@ -50,12 +50,6 @@ input { line-height: 25px; } -/*#results:hover{ - -webkit-transform: scale(1.2); - -moz-transform: scale(1.2); - -o-transform: scale(1.2); - transform: scale(1.2); -}*/ .vect { display: block; font-size: 24px; @@ -66,18 +60,20 @@ input { .vect>p { font-weight: bold; } -/*Added Css Property*/ -.operation{ - margin: 35px 0; /* Increased margin for space above and below */ + +.operation { + margin: 35px 0; } -.operation label{ - color: #C5EBFE; - font-size: 24px; + +.operation label { + color: #C5EBFE; + font-size: 24px; } -.operation select{ + +.operation select { border: 0; - border-radius: 5px; /*added same border radius as x & y input*/ - font-size: 16px; /*added same font size as x & y input*/ - padding: 10px; /*added same padding as x & y input*/ - margin: 10px; /*added same margin as x & y input*/ -} \ No newline at end of file + border-radius: 5px; + font-size: 16px; + padding: 10px; + margin: 10px; +}