Tour of the IDE: Difference between revisions

From NSB App Studio
Jump to navigation Jump to search
 
(29 intermediate revisions by 2 users not shown)
Line 12: Line 12:
** Find, Go to line, Block Comment/Uncomment
** Find, Go to line, Block Comment/Uncomment


<div class="page-break"></div>
== View ==
== View ==
* Show and hide various parts of the IDE
* Show and hide various parts of the IDE
Line 29: Line 30:
* Start in Desktop Browser
* Start in Desktop Browser
* Deploy to a server
* Deploy to a server
* Build using PhoneGap
* Build native app using VoltBuilder
* Build Chrome Native App
* Build Chrome Native App
* Debugger
* Debugger
Line 45: Line 46:
* Updates
* Updates


== Toolbar ==
<div class="page-break"></div>
[[file:3.2.jpg|center]] <br />
 
The ToolBar gives you shortcuts to many of the menu items. They are, from left to right
* New Project
* Open Project…
* Save Project
* Print
* Undo
* Redo
* Cut
* Copy
* Paste
* Delete
* Find
* Add Form
* Start in Desktop Browser


<div class="page-break"></div>
<div class="page-break"></div>
Line 87: Line 74:
* To view the code, right click and select View Code.
* To view the code, right click and select View Code.


<div class="page-break"></div>
= ToolBox =
= ToolBox =
[[file:3.3.jpg|center]]
[[file:3.3.png|right]]


Controls are the building blocks for the visual elements of the form. When the Design Screen has the focus, the list of controls is displayed.  
Controls are the building blocks for the visual elements of the form. When the Design Screen has the focus, the list of controls is displayed.  
Line 99: Line 87:


* Controls can be added to the Design Screen by drag & drop or by double clicking on the control in the Toolbox.
* Controls can be added to the Design Screen by drag & drop or by double clicking on the control in the Toolbox.
<br clear="all">


<div class="page-break"></div>
<div class="page-break"></div>
== Libraries ==


== Libraries ==
[[file:3.3.2.png|right]]  
[[file:3.3.2.jpg|center]]  
The list of Libraries displays when the Project Explorer is set to Project Properties and Global Code.  
The list of Libraries displays when the Project Explorer is set to Project Properties and Global Code.  
* Libraries are “canned” code which can be added to your project, then used in your app. You will need to consult the documentation for these libraries to see what functions they add to your program.  
* Libraries are “canned” code which can be added to your project, then used in your app. You will need to consult the documentation for these libraries to see what functions they add to your program.  
*Samples using Libraries can be found in the Libraries folder in Samples.
*Samples using Libraries can be found in the Libraries folder in Samples.
 
<br clear="all">


<div class="page-break"></div>
<div class="page-break"></div>
Line 113: Line 102:
= Project Explorer =
= Project Explorer =


[[file:3.5.jpg|center]] <br />
[[file:3.5.png|center]] <br />
The Project Explorer gives a layout of the project and lets you navigate through its parts.  
The Project Explorer gives a layout of the project and lets you navigate through its parts.  


Line 122: Line 111:
* Clicking on a control within a form will bring up the Design Screen with the control selected on it. The properties of the control will show in the Property Window.  
* Clicking on a control within a form will bring up the Design Screen with the control selected on it. The properties of the control will show in the Property Window.  


* Use the down arrow to move the currently selected item down the list, and use up arrow to move it up. Controls higher on the list will go behind lower items if they overlap.  
* Use the icon with the down arrow to move the currently selected item down the list, and use up arrow to move it up. Controls higher on the list will go behind lower items if they overlap.  


* Use the X to delete the currently selected item. There is no undo.
* Use the trash icon to delete the currently selected item. There is no undo.


* To change the name of a control or form, double click on its name in the Project Explorer, or edit the id in the [[Properties Window]]. Windows XP does not allow the editing of the name in the Project Explorer.
* To change the name of a control or form, double click on its name in the Project Explorer, or edit the id in the [[Properties Window]].  


* To add an external file or [[Code Modules|Code Module]] to your project, drag and drop it into the Project Explorer.
* To add an external file or [[Code Modules|Code Module]] to your project, drag and drop it into the Project Explorer.
<div class="page-break"></div>
<div class="page-break"></div>
<div class="page-break"></div>


= Properties Window =
= Properties Window =


<div class="page-break"></div>
[[file:3.6.png]] <br />
[[file:3.6.jpg]] <br />
The project, its forms and the controls on those forms have information about them that can be edited in the Properties Window.  
The project, its forms and the controls on those forms have information about them that can be edited in the Properties Window. Where such a change would affect the appearance of a form or control, the Design Screen will be updated.  
 
* If a change would affect the appearance of a form or control, the Design Screen will be updated.  
 
* A short description of the property appears in the Help window below the Properties Window.
 
== Some Project Properties ==


== Project Properties ==
* A project has a large number of properties which control the app's appearance and operation.
* Here are some of the important ones for now:


{| class = "wikitable"
{| class = "wikitable"
|-
|-
| backgroundimage || The background image on the screen. Default is a gray pattern with vertical lines.
| backgroundimage || The background image on the screen.  
|-
| browserwarnmsg || Message which appears is app is run on an unsupported browser. If blank, the warning does not appear. See also [[Projects,_Forms,_and_Controls#Browser_Warning_Message|browserWarningMessageAfterScript]].
|-
| ChromeIcon || A 192x192 png file to use as an icon when running as an Android Chrome fullscreen app.
|-
| ChromeManifest || Configuration information for [[Making Desktop Apps with App Studio|Chrome Packaged Apps]].
|-
|-
| copyright || The copyright message. This will be placed in the generated code.
| copyright || The copyright message. This will be placed in the generated code.
Line 154: Line 145:
|-
|-
| description || Description of the project. Used in config.xml.
| description || Description of the project. Used in config.xml.
|-
| EULA || The text of the End User License Agreement that the user has to agree to before the app will run.
|-
| extraheaders || Additional lines to the header. This is a good place to include extra JavaScript libraries.
|-
|-
| firstform || The name of the initial form to display. If left blank, the first form is used. If the form specified no longer exists, it will be changed to the first form on the next deploy.
| firstform || The name of the initial form to display. If left blank, the first form is used. If the form specified no longer exists, it will be changed to the first form on the next deploy.
Line 163: Line 150:
| fontfamily || The default font for all controls. Default value is Helvetica.
| fontfamily || The default font for all controls. Default value is Helvetica.
|-
|-
| HomescreenTitle || The title to be used for the app when saved to the Home Screen on the device. iOS only.
| icon || The icon to be used when saved to the Home Screen.
|-
| icon || The icon to be used when the app is saved to the launcher. For iOS, it should be 114x114.
|-
|-
| id || The saved name of the project. The app is deployed under this name.
| id || The saved name of the project. The app is deployed under this name.
|-
|-
| language || BASIC or JavaScript. If BASIC, code is converted to JavaScript before running.  
| language || BASIC or JavaScript. If BASIC, code is converted to JavaScript before running.  
|-
| manifest || A list of files to be saved with the project. See “[[Distributing your App]]”.
|-
| manifestFile || “appcache” or “manifest”. “appcache” is recommended for all new projects.
|-
|-
| obfuscation || Name of the external routine to obfucsate the runtime code.
| obfuscation || Name of the external routine to obfucsate the runtime code.
|-
| PhoneGap configxml || Configuration information for [https://build.phonegap.com/docs/config-xml PhoneGap Build]. Includes things like icons, splash screens, autorotation (orientation) and more.
|-
| phonegapBuildID || Build number returned by PhoneGap Build.
|-
| phoneGapLanguages || Languages supported if PhoneGap project.
|-
| script || Opens a Code Window with the Global Code for the project.
|-
|-
| splashscreen || An image to display as the app is loading. Do not put the file in nsb or nsb/images.
| splashscreen || An image to display as the app is loading. Do not put the file in nsb or nsb/images.
|-
| splashscreen-iPad ||An image to display as the app is loading on an iPad. Do not put the file in nsb or nsb/images.
|-
| statusbar || The appearance of the status bar at the very top of the screen. Choices are default, black or black-translucent.
|-
|-
| style || The style used by the body of the app.
| style || The style used by the body of the app.
Line 199: Line 168:
| version || Version number of app. User specified.  
| version || Version number of app. User specified.  
|}
|}
<div class="page-break"></div>


= Code Window =
= Code Window =
[[File:codewindow.png|frame|An autocomplete box appears if needed.]][[File:codewindow1.png|frame|Right click to see these options.]]
The Code Window is used the edit the code in your program.
*You can put all your code in a single block, or have a separate code block for each form as well as a global section. At runtime, they are treated as a single block, so be careful not to redefine functions or variables.
*Code can be in JavaScript, BASIC or PHP, depending on the setting in [[New Project Dialog|New Project,]] [[Properties Window|Form or Code Module]] properties.
== Features ==
=== Editing ===
* In BASIC, statements can be made longer than one line by using a space and a “_” character at the end of a line.
* Syntax checking is done as each BASIC line is completed.  If there is a syntax error, the line gets a red underline. If you hover over it, you can see the full error message.
* Cut, Paste, Delete and other similar functions can be used from the Menu, the Toolbar or the keyboard.
* Line numbers may be up to 99999.
=== Moving Around ===
* The dropdown bar at the top of the screen can be used to go directly to a Sub, Function or line number.
* Code Folding makes it easier to look at just the code you are interested in. Click on the minus sign to the left of a code block to collapse it.
* To go directly to a function in your program, select the name of the function elsewhere in your code, right click and select "Go to function definition."
=== Translation ===
* If you are working in a language other than JavaScript, you may view the translation of the code. Do a right click and select "View JavaScript". You can do this for the whole module or just a selection.
=== Inserting Code ===
* To insert code from an external file, drag and drop the file from the Finder into the Code Window.
* The code will be inserted into your app at the current position, just as if you had typed it in.
* You can insert code from .txt, .cod, .bas or .js files.
=== Customization ===
* To use your own settings for font, font size and tabs, select Settings.
=== Help ===
* To bring up the Wiki page for a keyword, select the word, right click and select "Open Wiki Page".


<div class="page-break"></div>
<div class="page-break"></div>
= Wiki =
= Wiki =
All documentation about AppStudio is contained in a [http://wiki.nsbasic.com Wiki file].
* A wiki is a user editable set of documentation.
* AppStudio uses the same wiki software as Wikipedia.
* Documentation in the Wiki is easy to keep up to date.
* Text is fully searchable.
* Documentation can have links to related topics embedded in the text.
* Available in offline version.

Latest revision as of 14:27, 13 November 2020

Menus

File Menu

  • New, Open and Save Projects
  • Open Samples
  • Export Form/Code...

Edit Menu

  • Undo/Redo
  • Cut, Copy, Paste, Delete
  • Code Window:
    • Find, Go to line, Block Comment/Uncomment

View

  • Show and hide various parts of the IDE
  • Reset IDE panels

Project

  • Add Forms
  • Add Code Files

Format

  • Useful for the Design Screen
  • Align to grid
  • Centering controls
  • Nudging controls

Run

  • Start in Desktop Browser
  • Deploy to a server
  • Build native app using VoltBuilder
  • Build Chrome Native App
  • Debugger

Tools

  • Preferences
  • ThemeRoller

Help

  • Wiki
  • Offline Wiki
  • Blog
  • TechNotes
  • Tutorials
  • Updates


Design Screen

The Design Screen shows the layout of the form. A control that is outlined in blue is the control being edited. It can be moved or resized using the grab handles on the edges.

  • When you mouse down on a control, lines extend to the edges to help with positioning.
  • If Size to Grid is selected in the Format menu, edges of controls will be positioned to the nearest multiple of 4. This also makes it much easier to position controls so they look attractive.
  • Certain controls have a fixed size, or have their size determined by their properties. These controls will not be able to be resized.
  • Controls can be added to the Design Screen by drag & drop or by double clicking on the control in the Toolbox. They can also be added by right clicking on the form and selecting “Add Component”.
  • Multiple controls can be selected and moved together.

Right click Options

  • To go to the event code for a control, right click on it and select “Go to Event”.
  • To view the code, right click and select View Code.

ToolBox

Controls are the building blocks for the visual elements of the form. When the Design Screen has the focus, the list of controls is displayed.

  • Controls are arranged by group.
  • Groups can be opened and closed by clicking on the triangle to the left of the group’s name.
  • A control may appear in more than one group.
  • Controls can be added to the Design Screen by drag & drop or by double clicking on the control in the Toolbox.


Libraries

The list of Libraries displays when the Project Explorer is set to Project Properties and Global Code.

  • Libraries are “canned” code which can be added to your project, then used in your app. You will need to consult the documentation for these libraries to see what functions they add to your program.
  • Samples using Libraries can be found in the Libraries folder in Samples.


Project Explorer


The Project Explorer gives a layout of the project and lets you navigate through its parts.

  • The top line brings up the global Code and properties for the project. A Code Window tab will open, and the project’s properties will show in the Properties Window.
  • Clicking on a line that has a form will open the layout of the form in the Design Screen and the form’s properties will show in the Property Window.
  • Clicking on a control within a form will bring up the Design Screen with the control selected on it. The properties of the control will show in the Property Window.
  • Use the icon with the down arrow to move the currently selected item down the list, and use up arrow to move it up. Controls higher on the list will go behind lower items if they overlap.
  • Use the trash icon to delete the currently selected item. There is no undo.
  • To change the name of a control or form, double click on its name in the Project Explorer, or edit the id in the Properties Window.
  • To add an external file or Code Module to your project, drag and drop it into the Project Explorer.

Properties Window


The project, its forms and the controls on those forms have information about them that can be edited in the Properties Window.

  • If a change would affect the appearance of a form or control, the Design Screen will be updated.
  • A short description of the property appears in the Help window below the Properties Window.

Some Project Properties

  • A project has a large number of properties which control the app's appearance and operation.
  • Here are some of the important ones for now:
backgroundimage The background image on the screen.
copyright The copyright message. This will be placed in the generated code.
defaultformsize Standard form size for most devices. If you want a size not on the list, set the height and width for each form in Form Properties.
description Description of the project. Used in config.xml.
firstform The name of the initial form to display. If left blank, the first form is used. If the form specified no longer exists, it will be changed to the first form on the next deploy.
fontfamily The default font for all controls. Default value is Helvetica.
icon The icon to be used when saved to the Home Screen.
id The saved name of the project. The app is deployed under this name.
language BASIC or JavaScript. If BASIC, code is converted to JavaScript before running.
obfuscation Name of the external routine to obfucsate the runtime code.
splashscreen An image to display as the app is loading. Do not put the file in nsb or nsb/images.
style The style used by the body of the app.
theme If jQuery Mobile is used, the default theme.
title The public title of the program.
version Version number of app. User specified.

Code Window

An autocomplete box appears if needed.
Right click to see these options.

The Code Window is used the edit the code in your program.

  • You can put all your code in a single block, or have a separate code block for each form as well as a global section. At runtime, they are treated as a single block, so be careful not to redefine functions or variables.

Features

Editing

  • In BASIC, statements can be made longer than one line by using a space and a “_” character at the end of a line.
  • Syntax checking is done as each BASIC line is completed. If there is a syntax error, the line gets a red underline. If you hover over it, you can see the full error message.
  • Cut, Paste, Delete and other similar functions can be used from the Menu, the Toolbar or the keyboard.
  • Line numbers may be up to 99999.

Moving Around

  • The dropdown bar at the top of the screen can be used to go directly to a Sub, Function or line number.
  • Code Folding makes it easier to look at just the code you are interested in. Click on the minus sign to the left of a code block to collapse it.
  • To go directly to a function in your program, select the name of the function elsewhere in your code, right click and select "Go to function definition."

Translation

  • If you are working in a language other than JavaScript, you may view the translation of the code. Do a right click and select "View JavaScript". You can do this for the whole module or just a selection.

Inserting Code

  • To insert code from an external file, drag and drop the file from the Finder into the Code Window.
  • The code will be inserted into your app at the current position, just as if you had typed it in.
  • You can insert code from .txt, .cod, .bas or .js files.

Customization

  • To use your own settings for font, font size and tabs, select Settings.

Help

  • To bring up the Wiki page for a keyword, select the word, right click and select "Open Wiki Page".

Wiki

All documentation about AppStudio is contained in a Wiki file.

  • A wiki is a user editable set of documentation.
  • AppStudio uses the same wiki software as Wikipedia.
  • Documentation in the Wiki is easy to keep up to date.
  • Text is fully searchable.
  • Documentation can have links to related topics embedded in the text.
  • Available in offline version.