private void addButtons() GridBagConstraints gbc = new GridBagConstraints(); gbc.fill = GridBagConstraints.BOTH; gbc.weightx = 1; gbc.weighty = 1; gbc.insets = new Insets(2, 2, 2, 2); String[][] buttons = "sin", "cos", "tan", "asin", "acos", "atan", "sinh", "cosh", "tanh", "log", "ln", "√", "x²", "x³", "xʸ", "eˣ", "10ˣ", "∛", "1/x", ", "π", "e", "(", ")", "C", "CE", "7", "8", "9", "/", "mod", "rand", "4", "5", "6", "*", "xʸ", "xʸ", "1", "2", "3", "-", "xʸ", "xʸ", "0", ".", "+/-", "+", "=", "xʸ" ; int row = 0; for (String[] buttonRow : buttons) int col = 0; for (String btnText : buttonRow) gbc.gridx = col; gbc.gridy = row; JButton button = createStyledButton(btnText); // Special sizing for equals button if (btnText.equals("=")) gbc.gridheight = 2; button.setBackground(new Color(76, 175, 80)); button.setForeground(Color.WHITE); else gbc.gridheight = 1; button.addActionListener(new ButtonClickListener(btnText)); buttonPanel.add(button, gbc); col++; row++; gbc.gridheight = 1; // Reset
public static void main(String[] args) SwingUtilities.invokeLater(() -> try UIManager.setLookAndFeel(UIManager.getSystemLookAndFeelClassName()); catch (Exception e) e.printStackTrace(); new ScientificCalculator().setVisible(true); );
@echo off echo Compiling Scientific Calculator... javac -d bin src/*.java if %errorlevel%==0 ( echo Compilation successful! echo Running Calculator... java -cp bin ScientificCalculator ) else ( echo Compilation failed! ) pause scientific calculator source code in java free download
public CalculatorEngine() this.memory = 0;
public void clear() memory = 0;
(Logic Engine) import java.math.BigDecimal; import java.math.RoundingMode; import java.util.Stack; public class CalculatorEngine private double memory; private boolean degreeMode = true;
📋 Overview A scientific calculator built in Java Swing with support for basic arithmetic, trigonometric functions, logarithms, exponents, and more. This is a complete, ready-to-run project. 📁 Project Structure ScientificCalculator/ ├── src/ │ ├── ScientificCalculator.java │ ├── CalculatorEngine.java │ └── CalculatorUI.java ├── README.md └── build.bat (Windows) / build.sh (Linux/Mac) 💻 Complete Source Code 1. ScientificCalculator.java (Main Class) import javax.swing.*; import javax.swing.border.*; import java.awt.*; import java.awt.event.*; import java.math.BigDecimal; import java.math.RoundingMode; public class ScientificCalculator extends JFrame private JTextField displayField; private JPanel buttonPanel; private CalculatorEngine engine; private boolean isDegree = true; // true = DEG, false = RAD java -cp bin ScientificCalculator ) else ( echo
private double factorial(int n)
public void clearEntry() // Implementation for clear entry private JPanel buttonPanel
// Inner class for expression evaluation using Shunting-yard algorithm private class ExpressionEvaluator public double evaluate(String expression) return evaluateExpression(expression); private double evaluateExpression(String expr) Stack<Double> values = new Stack<>(); Stack<Character> operators = new Stack<>(); for (int i = 0; i < expr.length(); i++) c == '.') StringBuilder sb = new StringBuilder(); while (i < expr.length() && (Character.isDigit(expr.charAt(i)) else if (c == '(') operators.push(c); else if (c == ')') while (operators.peek() != '(') values.push(applyOperation(operators.pop(), values.pop(), values.pop())); operators.pop(); else if (isOperator(c)) while (!operators.isEmpty() && hasPrecedence(c, operators.peek())) values.push(applyOperation(operators.pop(), values.pop(), values.pop())); operators.push(c); while (!operators.isEmpty()) values.push(applyOperation(operators.pop(), values.pop(), values.pop())); return values.pop(); private boolean isOperator(char c) c == '-' private boolean hasPrecedence(char op1, char op2) private double applyOperation(char op, double b, double a) switch (op) case '+': return a + b; case '-': return a - b; case '*': return a * b; case '/': if (b == 0) throw new ArithmeticException("Division by zero"); return a / b; case '%': return a % b; default: return 0;