# Compass Heading

Find which direction on a compass the micro:bit is facing.

The micro:bit measures the **compass heading** from `0` to `360`
degrees with its **magnetometer** chip. Different numbers mean north,
east, south, and west.

```sig
input.compassHeading();
```

### Returns

* a [number](/reference/types/number) from `0` to `360` degrees, which means the compass heading. If the compass isn't ready, it returns `-1003`.

### Example

This program finds the compass heading and stores it in the
`degrees` variable.

```blocks
let degrees = input.compassHeading()
```

### ~hint 

When you run a program that uses this function in a browser, click and drag
the compass needle on the screen to change the compass heading.

### ~

### Example: compass

This program finds the compass heading and then shows a letter
that means whether the micro:bit is facing north (N), south (S),
east (E), or west (W).

```blocks
basic.forever(() => {
    let degrees = input.compassHeading()
    if (degrees < 45)
        basic.showString("N")
    else if (degrees < 135)
        basic.showString("E")
    else if (degrees < 225)
        basic.showString("S")
    else basic.showString("W")
})
```

### Calibration

Every time you start to use the compass (for example, if you have just
turned the micro:bit on), the micro:bit will start to **calibrate**
(adjust itself).  It will ask you to draw a circle by tilting the
micro:bit.

If you are calibrating or using the compass near metal, it might
confuse the micro:bit.

### See also

[acceleration](/reference/input/acceleration)