I have no idea why I am getting a null pointer exception. This is my first time posting, it would mean the world to get any feedback. I have been researching on the internet for a while but cant point out whats wrong. I'm fairly new to object orientated programming so I would really appreciate any help with this. Thanks in advance.
Here is the full color grid class
    package au.edu.holmesglen.mswemmer.gridviewdemo;
import android.os.Bundle;
import android.support.v7.app.AppCompatActivity;
import android.support.v7.widget.Toolbar;
import android.util.Log;
import android.view.View;
import android.view.Menu;
import android.view.MenuItem;
import android.widget.AdapterView;
import android.widget.Button;
import android.widget.GridView;
import android.widget.ImageView;
import android.widget.Toast;
import java.util.Random;
public class ColorGrid extends AppCompatActivity {
    GridView gridview;
    Item[] gridArray = new Item[16];
    ImageAdapter iAdapter;
    int columncount = 4;
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_color_grid);
        Toolbar toolbar = (Toolbar) findViewById(R.id.toolbar);
        setSupportActionBar(toolbar);
        // generate 4x4 array with all items in the grid set to the grey image
        for(int i = 0; i< 16; i++){
            gridArray[i] = new Item(R.drawable.grey, "grey");
            Log.v("MyApp","GRID CREATED!!!!!");
        }
        //use the ImageAdapter to pass the array to the GridView object
        GridView grid = (GridView) findViewById(R.id.gridview);
        iAdapter = new ImageAdapter(this, gridArray);
        grid.setAdapter(iAdapter);
        //everytime an Item is clicked call the nextColor method to change to a different image
        grid.setOnItemClickListener(new AdapterView.OnItemClickListener() {
            public void onItemClick(AdapterView<?> parent, View v, int position, long id) {
                int x = position / columncount;
                int y = position % columncount;
                int c = gridArray[position].nextColor();
                checkForWin();
                ((ImageView)v).setImageResource(c);
                Toast.makeText(getApplicationContext(), x + " " + y,
                        Toast.LENGTH_SHORT).show();
            }
        });
    }
    private void checkForWin() {
        Log.d("MyApp","HELLO!!!!!");
        for (int i = 0; i < 16; i += 4) {
            // Check for blue
            if ((gridArray[i].getColor() == R.drawable.blue
                    && gridArray[i + 1].getColor() == R.drawable.blue
                    && gridArray[i + 2].getColor() == R.drawable.blue)
                    || (gridArray[i + 1].getColor() == R.drawable.blue
                    && gridArray[i + 2].getColor() == R.drawable.blue
                    && gridArray[i + 3].getColor() == R.drawable.blue))
            {
                Toast.makeText(getApplicationContext(),
                        "THREE WHITE IN A ROW HORIZONTALLY", Toast.LENGTH_SHORT)
                        .show();
                Log.d("MyApp", "3 in row horizontally BLUE");
            }
            // Check for green
            if ((gridArray[i].getColor() == R.drawable.green
                    && gridArray[i + 1].getColor() == R.drawable.green
                    && gridArray[i + 2].getColor() == R.drawable.green)
                    || (gridArray[i + 1].getColor() == R.drawable.green
                    && gridArray[i + 2].getColor() == R.drawable.green
                    && gridArray[i + 3].getColor() == R.drawable.green))
            {
                Toast.makeText(getApplicationContext(),
                        "THREE RED IN A ROW HORIZONTALLY", Toast.LENGTH_SHORT)
                        .show();
                Log.d("MyApp", "3 in row horizontally GREEN");
            }
        }
        // Check for vertical loss
        for (int i = 0; i <= 7; i++) {
            /*
             * This for loop is looping through each column and checking if 3 drawables are in a row
             */
            //Check for blue loss
            if (gridArray[i].getColor() == R.drawable.blue
                    && gridArray[i + 4].getColor() == R.drawable.blue
                    && gridArray[i + 8].getColor() == R.drawable.blue)
            {
                Toast.makeText(getApplicationContext(),
                        "THREE WHITE IN A ROW VERTICALLY", Toast.LENGTH_SHORT).show();
                Log.d("MyApp", "3 in row vertically BLUE");
            }
            //Check for green loss
            if (gridArray[i].getColor() == R.drawable.green
                    && gridArray[i + 4].getColor() == R.drawable.green
                    && gridArray[i + 8].getColor() == R.drawable.green) {
                Toast.makeText(getApplicationContext(),
                        "THREE RED IN A ROW VERTICALLY", Toast.LENGTH_SHORT).show();
                Log.d("MyApp", "3 in row vertically GREEN");
            }
        }
    }
    @Override
    public boolean onCreateOptionsMenu(Menu menu) {
        // Inflate the menu; this adds items to the action bar if it is present.
        getMenuInflater().inflate(R.menu.menu_color_grid, menu);
        return true;
    }
    @Override
    public boolean onOptionsItemSelected(MenuItem item) {
        // Handle action bar item clicks here. The action bar will
        // automatically handle clicks on the Home/Up button, so long
        // as you specify a parent activity in AndroidManifest.xml.
        int id = item.getItemId();
        //noinspection SimplifiableIfStatement
        if (id == R.id.action_settings) {
            return true;
        }
        return super.onOptionsItemSelected(item);
    }
}
And here is my log
08-23 18:00:46.219 7772-7772/au.edu.holmesglen.mswemmer.gridviewdemo E/AndroidRuntime: FATAL EXCEPTION: main
    Process: au.edu.holmesglen.mswemmer.gridviewdemo, PID: 7772
    java.lang.RuntimeException: Unable to start activity ComponentInfo{au.edu.holmesglen.mswemmer.gridviewdemo/au.edu.holmesglen.mswemmer.gridviewdemo.ColorGrid}: java.lang.NullPointerException
        at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2439)
        at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2495)
        at android.app.ActivityThread.access$800(ActivityThread.java:153)
        at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1349)
        at android.os.Handler.dispatchMessage(Handler.java:102)
        at android.os.Looper.loop(Looper.java:157)
        at android.app.ActivityThread.main(ActivityThread.java:5633)
        at java.lang.reflect.Method.invokeNative(Native Method)
        at java.lang.reflect.Method.invoke(Method.java:515)
        at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:896)
        at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:712)
        at dalvik.system.NativeStart.main(Native Method)
    Caused by: java.lang.NullPointerException
        at au.edu.holmesglen.mswemmer.gridviewdemo.ColorGrid.onCreate(ColorGrid.java:45)
        at android.app.Activity.performCreate(Activity.java:5312)
        at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1111)
        at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2395)
        at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2495) 
        at android.app.ActivityThread.access$800(ActivityThread.java:153) 
        at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1349) 
        at android.os.Handler.dispatchMessage(Handler.java:102) 
        at android.os.Looper.loop(Looper.java:157) 
        at android.app.ActivityThread.main(ActivityThread.java:5633) 
        at java.lang.reflect.Method.invokeNative(Native Method) 
        at java.lang.reflect.Method.invoke(Method.java:515) 
        at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:896) 
        at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:712) 
        at dalvik.system.NativeStart.main(Native Method) 
 
     
    