diff --git a/404.html b/404.html index d02a0ba..2b8115d 100644 --- a/404.html +++ b/404.html @@ -4,7 +4,7 @@ - + @@ -28,11 +28,11 @@ - + - + - +
diff --git a/git/index.html b/git/index.html index a6c39e6..20aee37 100644 --- a/git/index.html +++ b/git/index.html @@ -4,7 +4,7 @@ - + @@ -28,11 +28,11 @@ - + - + - +
diff --git a/index.html b/index.html index 4cc062a..cfa2b65 100644 --- a/index.html +++ b/index.html @@ -4,7 +4,7 @@ - + @@ -31,11 +31,11 @@ - + - + - +
diff --git a/java/apis/index.html b/java/apis/index.html index 1fb4e6e..a5fdaf8 100644 --- a/java/apis/index.html +++ b/java/apis/index.html @@ -4,7 +4,7 @@ - + @@ -28,11 +28,11 @@ - + - + - +
diff --git a/java/classes/index.html b/java/classes/index.html index 7297cba..329e90e 100644 --- a/java/classes/index.html +++ b/java/classes/index.html @@ -4,7 +4,7 @@ - + @@ -31,12 +31,12 @@ - + - + - - + +
@@ -184,12 +184,79 @@

this.isRobotOn = true; } + public void turnRobotOff() { + this.isRobotOn = false; + } + }

-

There is a lot going on here, but lets break it down.
-First, lets focus on modifiers. public and private before the variables, classes, and functions are modifiers. Modifiers allow us to give or restrict access to something. In this example, the variable robotAge is private, so that means only the class itself has access to it, and nothing else can read or write it. The variable isrobotOn however, is public, meaning any piece of code can read and write to it.

-

One important clairification to make is that these are not technically variables, they are members, that means they act slightly differently than variables. We will touch more on it later.

-

Next, lets talk about the constructor. The constructor is run when ever a new instance is created. This is our init function, and we usally initialize our member variables here. It looks sort of like a Function, but it doesn't have a return type, and the name of the function is capitalized and is the same as the class.

+ +

+ # + Modifiers +

+
+

There is a lot going on here, but let's break it down.
+First, let's focus on modifiers. public and private before the variables, classes, and functions are modifiers. Modifiers allow us to give or restrict access to something. In this example, the variable robotAge is private, so that means only the class itself has access to it, and nothing else can read or write it. The variable isrobotOn however, is public, meaning any piece of code can read and write to it.

+

One important clarification to make is that these are not technically variables, they are members, that means they act slightly differently than variables. We will touch more on it later.

+ +

+ # + Constructor +

+
+

Next, let's talk about the constructor. The constructor is run whenever a new instance is created. This is our init "function". It looks sort of like a Function, but it doesn't have a return type, and the name of the function is capitalized and is the same name as the class. You should put anything that needs to be initialized when a new instance is created here, such as setting up members and calling functions.

+
+
+ +
+ +

+ # + Dot Operator +

+
+

You may have noticed that the member initialization inside the constructor looks different than a normal variable declaration. The two things in front of the variable are the this keyword and the member operator, or "dot" as many people call it. Let's break it down:

+
+
this.robotAge = 3;
+
+

The this keyword refers to the parent class that the code is running in, so in this case, this means the Robot class object. Next, let's talk about the member operator, or "dot" as almost everyone calls it. It allows you to reference a member, method, or subclass that is declared within the class. On the left of the dot operator, you put the name of the object you want to reference from, and on the right, you put the name of the member, method, or subclass you want to reference. In this case, we reference the Robot class, and then we reference the robotAge member. This may seem redundant, but we use this to clarify which variables are arguments and which are members, allowing us to have the same named arguments as members. However, if you differently named arguments and members or no arguments at all, it is not necessary, but it is a best practice.

+ +

+ # + Methods +

+
+

Another piece of classes we have yet to talk about are methods. Methods are special functions inside of classes, and they work basically the same way. however, you need to include a modifier for them to function properly. to call methods, you simply use the dot operator, such as:

+
+
this.turnRobotOff();
+
+

As you can see, you call a method the same as a function, just with the dot operator and reference to a class.

+ +

+ # + Instantiation +

+
+

We have a class, now how do we use it? Classes on their own do not run their code unless they are instantiated, which means making a live, working copy of the "blueprint" that is the class. It's kind of like a house, the instance is the actual house and the blueprint is the class. Each instance is its own "ecosystem" of members and methods, which means that each instance can have different values for each of the different members. Such as 2 Robot instances having different values for isRobotOn. So how do we create a new instance of a class?

+
+
Robot robotInstance = new Robot();
+
+

Whenever we make a new instance, we need to set it to a variable so that we can reference it later. You probably have also noticed that the type of the variable is Robot! Because we need a type for our instance, and its not one of the primitives, we need to use the class as the type, which is as simple as typing the name of the class you are instantiating. Next, let's look at the new keyword, this tells java we want a new instance of whatever class comes after the new keyword. Then we add two parentheses to call the constructor and voila! You have your very own instance.

diff --git a/java/functions/index.html b/java/functions/index.html index aeb1e6d..adac4b2 100644 --- a/java/functions/index.html +++ b/java/functions/index.html @@ -4,7 +4,7 @@ - + @@ -31,12 +31,12 @@ - + - + - - + +
diff --git a/java/index.html b/java/index.html index ddb0292..0980962 100644 --- a/java/index.html +++ b/java/index.html @@ -4,7 +4,7 @@ - + @@ -31,11 +31,11 @@ - + - + - +
diff --git a/java/types/index.html b/java/types/index.html index 6006492..b476599 100644 --- a/java/types/index.html +++ b/java/types/index.html @@ -4,7 +4,7 @@ - + @@ -31,12 +31,12 @@ - + - + - - + +
diff --git a/java/variables/index.html b/java/variables/index.html index cd16fb4..7901e14 100644 --- a/java/variables/index.html +++ b/java/variables/index.html @@ -4,7 +4,7 @@ - + @@ -31,12 +31,12 @@ - + - + - - + +
diff --git a/projectstructure/index.html b/projectstructure/index.html index 0351937..1f912a6 100644 --- a/projectstructure/index.html +++ b/projectstructure/index.html @@ -4,7 +4,7 @@ - + @@ -31,11 +31,11 @@ - + - + - +
diff --git a/projectstructure/main/deploy/index.html b/projectstructure/main/deploy/index.html index 051c214..c1073cc 100644 --- a/projectstructure/main/deploy/index.html +++ b/projectstructure/main/deploy/index.html @@ -4,7 +4,7 @@ - + @@ -31,11 +31,11 @@ - + - + - +
diff --git a/projectstructure/main/index.html b/projectstructure/main/index.html index ed9a00d..81bf6a5 100644 --- a/projectstructure/main/index.html +++ b/projectstructure/main/index.html @@ -4,7 +4,7 @@ - + @@ -31,11 +31,11 @@ - + - + - +
diff --git a/projectstructure/main/java/frc/robot/commands/index.html b/projectstructure/main/java/frc/robot/commands/index.html index fa938ac..910053d 100644 --- a/projectstructure/main/java/frc/robot/commands/index.html +++ b/projectstructure/main/java/frc/robot/commands/index.html @@ -4,7 +4,7 @@ - + @@ -31,11 +31,11 @@ - + - + - +
diff --git a/projectstructure/main/java/frc/robot/constants.java/index.html b/projectstructure/main/java/frc/robot/constants.java/index.html index b7ab8d1..3971d57 100644 --- a/projectstructure/main/java/frc/robot/constants.java/index.html +++ b/projectstructure/main/java/frc/robot/constants.java/index.html @@ -4,7 +4,7 @@ - + @@ -31,11 +31,11 @@ - + - + - +
diff --git a/projectstructure/main/java/frc/robot/index.html b/projectstructure/main/java/frc/robot/index.html index dd62b9a..9beb97a 100644 --- a/projectstructure/main/java/frc/robot/index.html +++ b/projectstructure/main/java/frc/robot/index.html @@ -4,7 +4,7 @@ - + @@ -31,11 +31,11 @@ - + - + - +
diff --git a/projectstructure/main/java/frc/robot/main.java/index.html b/projectstructure/main/java/frc/robot/main.java/index.html index 327292e..d904170 100644 --- a/projectstructure/main/java/frc/robot/main.java/index.html +++ b/projectstructure/main/java/frc/robot/main.java/index.html @@ -4,7 +4,7 @@ - + @@ -31,11 +31,11 @@ - + - + - +
diff --git a/projectstructure/main/java/frc/robot/robot.java/index.html b/projectstructure/main/java/frc/robot/robot.java/index.html index 495f54f..9aa6b36 100644 --- a/projectstructure/main/java/frc/robot/robot.java/index.html +++ b/projectstructure/main/java/frc/robot/robot.java/index.html @@ -4,7 +4,7 @@ - + @@ -31,11 +31,11 @@ - + - + - +
diff --git a/projectstructure/main/java/frc/robot/robotcontainer.java/index.html b/projectstructure/main/java/frc/robot/robotcontainer.java/index.html index feff73a..872fa35 100644 --- a/projectstructure/main/java/frc/robot/robotcontainer.java/index.html +++ b/projectstructure/main/java/frc/robot/robotcontainer.java/index.html @@ -4,7 +4,7 @@ - + @@ -31,11 +31,11 @@ - + - + - +
diff --git a/projectstructure/main/java/frc/robot/subsystems/index.html b/projectstructure/main/java/frc/robot/subsystems/index.html index 275710c..63578b0 100644 --- a/projectstructure/main/java/frc/robot/subsystems/index.html +++ b/projectstructure/main/java/frc/robot/subsystems/index.html @@ -4,7 +4,7 @@ - + @@ -31,11 +31,11 @@ - + - + - +
diff --git a/projectstructure/main/java/index.html b/projectstructure/main/java/index.html index d55a7ca..2aa0c38 100644 --- a/projectstructure/main/java/index.html +++ b/projectstructure/main/java/index.html @@ -4,7 +4,7 @@ - + @@ -31,11 +31,11 @@ - + - + - +
diff --git a/projectstructure/main/java/util/index.html b/projectstructure/main/java/util/index.html index 87a9daf..7227a99 100644 --- a/projectstructure/main/java/util/index.html +++ b/projectstructure/main/java/util/index.html @@ -4,7 +4,7 @@ - + @@ -31,11 +31,11 @@ - + - + - +
diff --git a/projectstructure/test/index.html b/projectstructure/test/index.html index b7b45ee..385bc7b 100644 --- a/projectstructure/test/index.html +++ b/projectstructure/test/index.html @@ -4,7 +4,7 @@ - + @@ -31,11 +31,11 @@ - + - + - +
diff --git a/resources/js/config.js b/resources/js/config.js index f10755e..0a3fd14 100644 --- a/resources/js/config.js +++ b/resources/js/config.js @@ -1 +1 @@ -var __DOCS_CONFIG__ = {"id":"194eHk4KLBQY4CsjNu4J4QlzkTZiFcnycIH","key":"ZhYyVwi16vWX1axkHksVx77vbBoslJFHh7H75tu8HnE.hwiT1v/Vp4GAOIuLLnTpeg3XiogcJc/dVegUrdX+B1mY1lpaKv6mfjfNe947iFTlq6PcrGFEid4oNPCtxTbWqQ.8295","base":"/DreadDocs/","host":"dreadbot.github.io","version":"1.0.0","useRelativePaths":true,"documentName":"index.html","appendDocumentName":false,"trailingSlash":true,"preloadSearch":false,"cacheBustingToken":"3.5.0.750904585791","cacheBustingStrategy":"query","sidebarFilterPlaceholder":"Filter","toolbarFilterPlaceholder":"Filter","showSidebarFilter":true,"filterNotFoundMsg":"No member names found containing the query \"{query}\"","maxHistoryItems":15,"homeIcon":"","access":[{"value":"public","label":"Public"},{"value":"protected","label":"Protected"}],"toolbarLinks":[{"id":"fields","label":"Fields"},{"id":"properties","label":"Properties"},{"id":"methods","label":"Methods"},{"id":"events","label":"Events"}],"sidebar":[{"n":"/","l":"Welcome to the Dread​Docs!"},{"n":"java","l":"Java","i":[{"n":"variables","l":"Variables"},{"n":"functions","l":"Functions"},{"n":"classes","l":"Classes"},{"n":"apis","l":"AP​Is"},{"n":"types","l":"Types"}],"s":""},{"n":"projectstructure","l":"Project Structure","i":[{"n":"main","i":[{"n":"java","i":[{"n":"frc","c":false,"i":[{"n":"robot","i":[{"n":"commands","s":""},{"n":"subsystems","s":""},{"n":"constants.java","l":"Constants.​java","s":""},{"n":"main.java","l":"Main.​java","s":""},{"n":"robot.java","l":"Robot.​java","s":""},{"n":"robotcontainer.java","l":"Robot​Container.​java","s":""}],"s":""}],"s":""},{"n":"util","s":""}],"s":""},{"n":"deploy","s":""}],"s":""},{"n":"test","s":""}],"s":""},{"n":"git","l":"Git","s":""},{"n":"robotprogramming","l":"Robot Programming","s":""}],"search":{"mode":0,"minChars":2,"maxResults":20,"placeholder":"Search","hotkeys":["k"],"noResultsFoundMsg":"Sorry, no results found.","recognizeLanguages":true,"languages":[0],"preload":false},"resources":{"History_Title_Label":"History","History_ClearLink_Label":"Clear","History_NoHistory_Label":"No history items","API_AccessFilter_Label":"Access","API_ParameterSection_Label":"PARAMETERS","API_SignatureSection_Label":"SIGNATURE","API_CopyHint_Label":"Copy","API_CopyNameHint_Label":"Copy name","API_CopyLinkHint_Label":"Copy link","API_CopiedAckHint_Label":"Copied!","API_MoreOverloads_Label":"more","API_MoreDropdownItems_Label":"More","API_OptionalParameter_Label":"optional","API_DefaultParameterValue_Label":"Default value","API_InheritedFilter_Label":"Inherited","Search_Input_Placeholder":"Search","Toc_Contents_Label":"Contents","Toc_RelatedClasses_Label":"Related Classes","History_JustNowTime_Label":"just now","History_AgoTime_Label":"ago","History_YearTime_Label":"y","History_MonthTime_Label":"mo","History_DayTime_Label":"d","History_HourTime_Label":"h","History_MinuteTime_Label":"m","History_SecondTime_Label":"s"}}; +var __DOCS_CONFIG__ = {"id":"l2dK194GM9fKbfWO8UqFgj+uTQQD5V2HG8n","key":"hAbGKN+dwcGy2seXnLnxxx0cPm627kIPKX1l2D2MoVo.lXc2GKu4j64pOnvx6GnlkXk7Ums8Eb3G/G6nIh6qqJ/E0bHCAC/pA/12tSBWNuH1t2Vqt8ST2iHVXfWd2d2uWg.8289","base":"/DreadDocs/","host":"dreadbot.github.io","version":"1.0.0","useRelativePaths":true,"documentName":"index.html","appendDocumentName":false,"trailingSlash":true,"preloadSearch":false,"cacheBustingToken":"3.5.0.753317129284","cacheBustingStrategy":"query","sidebarFilterPlaceholder":"Filter","toolbarFilterPlaceholder":"Filter","showSidebarFilter":true,"filterNotFoundMsg":"No member names found containing the query \"{query}\"","maxHistoryItems":15,"homeIcon":"","access":[{"value":"public","label":"Public"},{"value":"protected","label":"Protected"}],"toolbarLinks":[{"id":"fields","label":"Fields"},{"id":"properties","label":"Properties"},{"id":"methods","label":"Methods"},{"id":"events","label":"Events"}],"sidebar":[{"n":"/","l":"Welcome to the Dread​Docs!"},{"n":"java","l":"Java","i":[{"n":"variables","l":"Variables"},{"n":"functions","l":"Functions"},{"n":"classes","l":"Classes"},{"n":"apis","l":"AP​Is"},{"n":"types","l":"Types"}],"s":""},{"n":"projectstructure","l":"Project Structure","i":[{"n":"main","i":[{"n":"java","i":[{"n":"frc","c":false,"i":[{"n":"robot","i":[{"n":"commands","s":""},{"n":"subsystems","s":""},{"n":"constants.java","l":"Constants.​java","s":""},{"n":"main.java","l":"Main.​java","s":""},{"n":"robot.java","l":"Robot.​java","s":""},{"n":"robotcontainer.java","l":"Robot​Container.​java","s":""}],"s":""}],"s":""},{"n":"util","s":""}],"s":""},{"n":"deploy","s":""}],"s":""},{"n":"test","s":""}],"s":""},{"n":"git","l":"Git","s":""},{"n":"robotprogramming","l":"Robot Programming","s":""}],"search":{"mode":0,"minChars":2,"maxResults":20,"placeholder":"Search","hotkeys":["k"],"noResultsFoundMsg":"Sorry, no results found.","recognizeLanguages":true,"languages":[0],"preload":false},"resources":{"History_Title_Label":"History","History_ClearLink_Label":"Clear","History_NoHistory_Label":"No history items","API_AccessFilter_Label":"Access","API_ParameterSection_Label":"PARAMETERS","API_SignatureSection_Label":"SIGNATURE","API_CopyHint_Label":"Copy","API_CopyNameHint_Label":"Copy name","API_CopyLinkHint_Label":"Copy link","API_CopiedAckHint_Label":"Copied!","API_MoreOverloads_Label":"more","API_MoreDropdownItems_Label":"More","API_OptionalParameter_Label":"optional","API_DefaultParameterValue_Label":"Default value","API_InheritedFilter_Label":"Inherited","Search_Input_Placeholder":"Search","Toc_Contents_Label":"Contents","Toc_RelatedClasses_Label":"Related Classes","History_JustNowTime_Label":"just now","History_AgoTime_Label":"ago","History_YearTime_Label":"y","History_MonthTime_Label":"mo","History_DayTime_Label":"d","History_HourTime_Label":"h","History_MinuteTime_Label":"m","History_SecondTime_Label":"s"}}; diff --git a/resources/js/search.json b/resources/js/search.json index 1f0293e..b50c0e3 100644 --- a/resources/js/search.json +++ b/resources/js/search.json @@ -1 +1 @@ -[[{"i":"welcome-to-the-dreaddocs","l":"Welcome to the DreadDocs!","p":["Work in Progress!","Welcome to our Docs! Here you will find Information about WPILib, robot programming, and Java."]},{"i":"where-to-start","l":"Where to Start?","p":["Consider starting in Java, or if you know about Java and OOP, maybe start in Project Structure."]},{"l":"Getting Started","p":["If you are using a robotics computer, everything will be set up for you already!","This tutorial is focused on a Windows installation, if you need help with installation on a different OS, reach out on the Discord server","To get started, head to the WPILib Installation Guide and click the blue download button (It should be platform specific).","Once that has finished installing, right click on the .iso file and click mount.","After mounting the file, open the WPILibInstaller.exe executable.","Follow all of the prompts.","After that, WPILib should be installed"]}],[{"l":"Java"},{"i":"what-is-java","l":"What is Java?","p":["Java is a programming language that turns source code into 1s and 0s that the computer can understand. We use Java to tell our robot what to do by using variables, functions, classes, and APIs."]}],[{"l":"Variables","p":["A variable is kind of like a named box that holds something.","Here is a quick example in Java:","To create a variable, you need 4 things:","You need a type, a type tells us what that \"something\" is. In this case our type is a boolean which stores either a true or false.","You need a name, which in this case is isRobotOn, you will use this name to refrence the variable later.","You need an equals sign, this is how we tell Java that we want to assign a variable to a value.","And lastly, you need a value, which in this case is false."]},{"l":"Common Types in Robot Programming and Their Values","p":["Type","Value","int","Whole numbers (such as 1, 2, -3, etc.)","double","Numbers with a decimal (such as 1.234)","boolean","Can be true or false","More information on booleans is available at Control Flow. More information on types is available at Types. For more information of variables, consider checking out the W3 Schools Java Tutorial."]}],[{"l":"Functions","p":["A Function is a way of packaging code so that we can reuse it. A function can have inputs and outputs, so they can be quite a useful tool in Java programming.","Here is a simple example:","There is a lot going on here but we will focus on the function declaration. to declare a function, we simply need a type and a name. The type tells us what the function will return, in this case that is void, which is nothing. The name of the function is how we reference it. After the name comes the parentheses, which hold the paramters of the function, we will go into depth about parameters later. In this case there are no parameters, so it's just the parentheses. Lastly, we have the curly brackets. These tell Java where the code for the function starts and ends."]},{"l":"Parameters and Returns","p":["Sometimes, we want a function to do something based on an input, and give an output. Thats where parameters and returns come in. Here is an example of parameters and returns","To add parameters to a function, simply give the parameter a type and a name and add a comma in between each parameter. you can user parameters as a kind of local variable that only exists inside the function declaration. To return something from a function, use the return keyword. You can pass either a variable or an expression (as we have in this case). Notice how we changed the functions type to reflect what we are returning. To call any function, just write the name with a pair of parentheses in which you add any parameters the function has. For more information on types when working with functions, check out Types"]}],[{"l":"Classes","p":["Classes are one of the most important features of Java. They allow us to represent and package code in a way that is easy and convient to reuse. Lets look at an example:","There is a lot going on here, but lets break it down. First, lets focus on modifiers. public and private before the variables, classes, and functions are modifiers. Modifiers allow us to give or restrict access to something. In this example, the variable robotAge is private, so that means only the class itself has access to it, and nothing else can read or write it. The variable isrobotOn however, is public, meaning any piece of code can read and write to it.","One important clairification to make is that these are not technically variables, they are members, that means they act slightly differently than variables. We will touch more on it later.","Next, lets talk about the constructor. The constructor is run when ever a new instance is created. This is our init function, and we usally initialize our member variables here. It looks sort of like a Function, but it doesn't have a return type, and the name of the function is capitalized and is the same as the class."]}],[{"l":"APIs"}],[{"l":"Types"},{"i":"what-are-types","l":"What Are types?","p":["Java is a statically typed langauge. This means that we have to work with types. Types are how we tell Java what something is or returns. In variables, we looked at this example:","Here, we tell java what the data that the variable contains is. In this case, the variable isRobotOn is of type boolean.","In functions, we looked at this example:","In this example, we tell Java what this function will return, this allows us to guarantee* that we will get a return value of type int. This allows has the side effect of being able to use Code Completion on a lot more objects and variables that we would be able to otherwise.* This is true for about 99% of cases"]},{"l":"Primitives","p":["A fracional number that goes up to 15 decimal places","A fracional number that goes up to 7 decimal places (1.234, etc.)","A number from -2147483648 to 2147483647","A number from -32768 to 32767","A number from 0 to 255","A single character","A true or false value","boolean","byte","char","double","float","int","Integers (1, 2, 3, etc.)","long","Meaning","Name","short","So far, all the types we have been looking at have been primitives. A primitive is a type that Java supplies us by default. You can tell which types are primitives as primitives always start with a lowercase. Here are some primitives:"]},{"l":"Other Types","p":["So far, we have only looked at primitives, but Java has more to offer then that! We are going to look at non-primitive data types. You can tell if a type is not a primitive if it starts with an uppercase.","For example:","How do we create types? Its super simple! We simply use the class name of the class we are instantiating as the type. For more information about instantiating classes, check out classes."]}],[{"l":"Project Structure","p":["Knowing project structure is very important to being able to collaboratively program effectively. It allows us to stay organized and find things easily and efficiently. However, to someone who is new to the project and programming in general it can be very daunting to figure out where everything is and what it does. The different folders inside this section will be laid out similarly to how our code is usally organized.","This layout assumes you are in src/"]}],[{"l":"main","p":["This is where the main portion of our code is kept."]}],[{"l":"java","p":["This is where we keep all of our Java source code."]}],[{"l":"robot","p":["This is where you will find all of our core robot code."]}],[{"l":"commands","p":["This is where we keep all of our commands. This are specific actions that we can run on events. They will usally be in a subsystem specific folder."]}],[{"l":"subsystems","p":["This is where we keep all of our subsystems. You can think of a subsystem as a specific part of the robot. For example, a grabber would be considered a subsystem."]}],[{"i":"constantsjava","l":"Constants.java","p":["Here you will find all of our constant values, anything like a gear ratio, wheel circumference, or controller port will be found here."]}],[{"i":"mainjava","l":"Main.java","p":["This is the entry point to the robot code. This is the first thing that is run when the robot turns on. We rarely if ever have to edit this."]}],[{"i":"robotjava","l":"Robot.java","p":["This contains the initalization of the command based system that we use, as well as some low level robot things such as path loading and generation."]}],[{"i":"robotcontainerjava","l":"RobotContainer.java","p":["This is were we instanciate our subsystems, bind our buttons, and setup default commands. This is the file that you will come back to the most."]}],[{"l":"util","p":["This is where we keep all of our utilities, or things that we reuse season after season. You see a lot of files reference the utils folder so its good to familiarize yourself with them."]}],[{"l":"deploy","p":["Anything that needs to be deployed onto the roborio is put in this folder. The most common thing we need to deploy are paths."]}],[{"l":"test","p":["We write all of our unit tests in this folder. The rest of the path is /Java/frc/Robot"]}],[{"l":"Git"}],[{"l":"Robot Programming"}]] \ No newline at end of file +[[{"i":"welcome-to-the-dreaddocs","l":"Welcome to the DreadDocs!","p":["Work in Progress!","Welcome to our Docs! Here you will find Information about WPILib, robot programming, and Java."]},{"i":"where-to-start","l":"Where to Start?","p":["Consider starting in Java, or if you know about Java and OOP, maybe start in Project Structure."]},{"l":"Getting Started","p":["If you are using a robotics computer, everything will be set up for you already!","This tutorial is focused on a Windows installation, if you need help with installation on a different OS, reach out on the Discord server","To get started, head to the WPILib Installation Guide and click the blue download button (It should be platform specific).","Once that has finished installing, right click on the .iso file and click mount.","After mounting the file, open the WPILibInstaller.exe executable.","Follow all of the prompts.","After that, WPILib should be installed"]}],[{"l":"Java"},{"i":"what-is-java","l":"What is Java?","p":["Java is a programming language that turns source code into 1s and 0s that the computer can understand. We use Java to tell our robot what to do by using variables, functions, classes, and APIs."]}],[{"l":"Variables","p":["A variable is kind of like a named box that holds something.","Here is a quick example in Java:","To create a variable, you need 4 things:","You need a type, a type tells us what that \"something\" is. In this case our type is a boolean which stores either a true or false.","You need a name, which in this case is isRobotOn, you will use this name to refrence the variable later.","You need an equals sign, this is how we tell Java that we want to assign a variable to a value.","And lastly, you need a value, which in this case is false."]},{"l":"Common Types in Robot Programming and Their Values","p":["Type","Value","int","Whole numbers (such as 1, 2, -3, etc.)","double","Numbers with a decimal (such as 1.234)","boolean","Can be true or false","More information on booleans is available at Control Flow. More information on types is available at Types. For more information of variables, consider checking out the W3 Schools Java Tutorial."]}],[{"l":"Functions","p":["A Function is a way of packaging code so that we can reuse it. A function can have inputs and outputs, so they can be quite a useful tool in Java programming.","Here is a simple example:","There is a lot going on here but we will focus on the function declaration. to declare a function, we simply need a type and a name. The type tells us what the function will return, in this case that is void, which is nothing. The name of the function is how we reference it. After the name comes the parentheses, which hold the paramters of the function, we will go into depth about parameters later. In this case there are no parameters, so it's just the parentheses. Lastly, we have the curly brackets. These tell Java where the code for the function starts and ends."]},{"l":"Parameters and Returns","p":["Sometimes, we want a function to do something based on an input, and give an output. Thats where parameters and returns come in. Here is an example of parameters and returns","To add parameters to a function, simply give the parameter a type and a name and add a comma in between each parameter. you can user parameters as a kind of local variable that only exists inside the function declaration. To return something from a function, use the return keyword. You can pass either a variable or an expression (as we have in this case). Notice how we changed the functions type to reflect what we are returning. To call any function, just write the name with a pair of parentheses in which you add any parameters the function has. For more information on types when working with functions, check out Types"]}],[{"l":"Classes","p":["Classes are one of the most important features of Java. They allow us to represent and package code in a way that is easy and convient to reuse. Lets look at an example:"]},{"l":"Modifiers","p":["There is a lot going on here, but let's break it down. First, let's focus on modifiers. public and private before the variables, classes, and functions are modifiers. Modifiers allow us to give or restrict access to something. In this example, the variable robotAge is private, so that means only the class itself has access to it, and nothing else can read or write it. The variable isrobotOn however, is public, meaning any piece of code can read and write to it.","One important clarification to make is that these are not technically variables, they are members, that means they act slightly differently than variables. We will touch more on it later."]},{"l":"Constructor","p":["Next, let's talk about the constructor. The constructor is run whenever a new instance is created. This is our init \"function\". It looks sort of like a Function, but it doesn't have a return type, and the name of the function is capitalized and is the same name as the class. You should put anything that needs to be initialized when a new instance is created here, such as setting up members and calling functions.","Even though the constructor is not a function, you can still pass in input arguments! See Functions for more information."]},{"l":"Dot Operator","p":["You may have noticed that the member initialization inside the constructor looks different than a normal variable declaration. The two things in front of the variable are the this keyword and the member operator, or \"dot\" as many people call it. Let's break it down:","The this keyword refers to the parent class that the code is running in, so in this case, this means the Robot class object. Next, let's talk about the member operator, or \"dot\" as almost everyone calls it. It allows you to reference a member, method, or subclass that is declared within the class. On the left of the dot operator, you put the name of the object you want to reference from, and on the right, you put the name of the member, method, or subclass you want to reference. In this case, we reference the Robot class, and then we reference the robotAge member. This may seem redundant, but we use this to clarify which variables are arguments and which are members, allowing us to have the same named arguments as members. However, if you differently named arguments and members or no arguments at all, it is not necessary, but it is a best practice."]},{"l":"Methods","p":["Another piece of classes we have yet to talk about are methods. Methods are special functions inside of classes, and they work basically the same way. however, you need to include a modifier for them to function properly. to call methods, you simply use the dot operator, such as:","As you can see, you call a method the same as a function, just with the dot operator and reference to a class."]},{"l":"Instantiation","p":["We have a class, now how do we use it? Classes on their own do not run their code unless they are instantiated, which means making a live, working copy of the \"blueprint\" that is the class. It's kind of like a house, the instance is the actual house and the blueprint is the class. Each instance is its own \"ecosystem\" of members and methods, which means that each instance can have different values for each of the different members. Such as 2 Robot instances having different values for isRobotOn. So how do we create a new instance of a class?","Whenever we make a new instance, we need to set it to a variable so that we can reference it later. You probably have also noticed that the type of the variable is Robot! Because we need a type for our instance, and its not one of the primitives, we need to use the class as the type, which is as simple as typing the name of the class you are instantiating. Next, let's look at the new keyword, this tells java we want a new instance of whatever class comes after the new keyword. Then we add two parentheses to call the constructor and voila! You have your very own instance."]}],[{"l":"APIs"}],[{"l":"Types"},{"i":"what-are-types","l":"What Are types?","p":["Java is a statically typed langauge. This means that we have to work with types. Types are how we tell Java what something is or returns. In variables, we looked at this example:","Here, we tell java what the data that the variable contains is. In this case, the variable isRobotOn is of type boolean.","In functions, we looked at this example:","In this example, we tell Java what this function will return, this allows us to guarantee* that we will get a return value of type int. This allows has the side effect of being able to use Code Completion on a lot more objects and variables that we would be able to otherwise.* This is true for about 99% of cases"]},{"l":"Primitives","p":["A fracional number that goes up to 15 decimal places","A fracional number that goes up to 7 decimal places (1.234, etc.)","A number from -2147483648 to 2147483647","A number from -32768 to 32767","A number from 0 to 255","A single character","A true or false value","boolean","byte","char","double","float","int","Integers (1, 2, 3, etc.)","long","Meaning","Name","short","So far, all the types we have been looking at have been primitives. A primitive is a type that Java supplies us by default. You can tell which types are primitives as primitives always start with a lowercase. Here are some primitives:"]},{"l":"Other Types","p":["So far, we have only looked at primitives, but Java has more to offer then that! We are going to look at non-primitive data types. You can tell if a type is not a primitive if it starts with an uppercase.","For example:","How do we create types? Its super simple! We simply use the class name of the class we are instantiating as the type. For more information about instantiating classes, check out classes."]}],[{"l":"Project Structure","p":["Knowing project structure is very important to being able to collaboratively program effectively. It allows us to stay organized and find things easily and efficiently. However, to someone who is new to the project and programming in general it can be very daunting to figure out where everything is and what it does. The different folders inside this section will be laid out similarly to how our code is usally organized.","This layout assumes you are in src/"]}],[{"l":"main","p":["This is where the main portion of our code is kept."]}],[{"l":"java","p":["This is where we keep all of our Java source code."]}],[{"l":"robot","p":["This is where you will find all of our core robot code."]}],[{"l":"commands","p":["This is where we keep all of our commands. This are specific actions that we can run on events. They will usally be in a subsystem specific folder."]}],[{"l":"subsystems","p":["This is where we keep all of our subsystems. You can think of a subsystem as a specific part of the robot. For example, a grabber would be considered a subsystem."]}],[{"i":"constantsjava","l":"Constants.java","p":["Here you will find all of our constant values, anything like a gear ratio, wheel circumference, or controller port will be found here."]}],[{"i":"mainjava","l":"Main.java","p":["This is the entry point to the robot code. This is the first thing that is run when the robot turns on. We rarely if ever have to edit this."]}],[{"i":"robotjava","l":"Robot.java","p":["This contains the initalization of the command based system that we use, as well as some low level robot things such as path loading and generation."]}],[{"i":"robotcontainerjava","l":"RobotContainer.java","p":["This is were we instanciate our subsystems, bind our buttons, and setup default commands. This is the file that you will come back to the most."]}],[{"l":"util","p":["This is where we keep all of our utilities, or things that we reuse season after season. You see a lot of files reference the utils folder so its good to familiarize yourself with them."]}],[{"l":"deploy","p":["Anything that needs to be deployed onto the roborio is put in this folder. The most common thing we need to deploy are paths."]}],[{"l":"test","p":["We write all of our unit tests in this folder. The rest of the path is /Java/frc/Robot"]}],[{"l":"Git"}],[{"l":"Robot Programming"}]] \ No newline at end of file diff --git a/robotprogramming/index.html b/robotprogramming/index.html index 216628e..d5ff6d1 100644 --- a/robotprogramming/index.html +++ b/robotprogramming/index.html @@ -4,7 +4,7 @@ - + @@ -28,11 +28,11 @@ - + - + - +
diff --git a/sitemap.xml.gz b/sitemap.xml.gz index 4c2e916..126f426 100644 Binary files a/sitemap.xml.gz and b/sitemap.xml.gz differ