Hello friends and welcome to Obsidian Soft,
Recently, I embedded my YouTube mental maths videos in my mental maths app so this gave me the idea of teaching something similar in MIT App Inventor.
As you can see this screen is showing a mental math trick and in the lower part of the screen, we have the associated mental math video.
You can do the same thing in your MIT App inventor apps. For example, if you have a recipe app, you can embed the associated recipe video within your app or if you have an educational app like my mental maths app, you can embed or integrate the associated tutorial video. Embedding or integrating youtube videos in your apps is great way to extend the reach of your videos. By the way, if you are wondering, this mental maths app has been created using Solar2D SDK particularly great for making 2D games. My Countville app has also been developed in this. Solar2D is based on Lua; the programming language that is also used by Roblox. You can check out both these apps by downloading them from the Google Play Store.
Coming back to the tutorial, embedding YouTube videos requires a special HTML code that is actually provided by YouTube itself and we can customize it according to our needs.
So, let’s begin…
Open up MIT App Inventor and create a new project. Name it YouTubeVideoApp.
For screen1, make align horizontal and align vertical both center and make screen orientation portrait.
Drag and drop a vertical arrangement from the Layout.
For this vertical arrangement, make align horizontal and align vertical both center. Make width fill parent and height 30%.
Duplicate the vertical arrangement by selecting it first and pressing Ctrl + C and Ctrl + V for Windows and Command + C and Command + V for MacOS. In the topmost arrangement, I will add a label that can contain our recipe or other information.
Now, our second vertical arrangement will contain our video but we need a web view for this. However, we can’t embed using the built-in webviewer of MIT App Inventor as that requires a url link but we want to provide HTML code. So, we need to download an extension. Hence, go to this link:
https://github.com/vknow360/CustomWebView
Click on the aix folder. Then, click on the aix file and then, click on the arrow button to download it.
Now, go back to MIT App Inventor, go to extensions, and click on import extension to import the aix file.
Drag and drop the customwebview from the 3 components onto the viewer. This component can be used to create multiple web views.
Now, go to the blocks section.
We want the video to start showing when the screen is initialized so get the screen1’s initialize event.
First, we want to create a webview within our vertical arrangement2. We need to provide the container and also give an ID to this webview.
Next, we tell the custom webview component that our current webview is the one with ID = 1.
Last, we need to provide the HTML code for the current webview using a text block.
We can get the code for what comes inside the text block from YouTube itself. Open up the video you want to embed in the browser.
Click on share button.
Click on the embed button in the small window that opens up:
You can also choose a particular starting point for your video. You can also turn off player controls if you don’t want the user to forward or rewind the video or go to full-screen mode.
Click on the copy button under the code.
And paste this copied code inside the text block.
If you want to add more than one video on the same screen, you can use the same component.
Just go back to the designer view and duplicate the second vertical arrangement.
Come back to the blocks section.
And add those 3 procedures calls again for another webview with id: 2 within container vertical arrangement 3 and with html code for another video.
We are done with the basic embedding but you might have noticed that our video is showing in a pretty small frame.
Yes, we have the option of watching it in full screen but only if we have turned on player controls. So, if you want to know how to fit your video nicely without going into full screen, please keep reading this tutorial to the very end.
We need to download another extension that will give us the size of the screen in pixels. The height and width that we get from Screen1’s properties give us the size in dp i.e. density-independent pixels and we need the actual pixels for the embedded YouTube video’s frame.
So, download this extension:
https://community.appinventor.mit.edu/t/how-do-i-determine-the-screen-size/56414/2
In MIT App Inventor, go to designer view and import the extension in your project. Drag and drop the Getmetrics component onto the viewer.
In the blocks section, make a global variable for height and width and initialize them to 0.
And use displaymetrics component to get the actual width of the screen in pixels.
Now, use this width to calculate the height for the YouTube video frame so that the aspect ratio stays 16:9.
The formula is height = (width/16)x9
At the end, we have to break down our HTML code and split the height and width elements so that we can provide custom width and height. So, add a join with five slots and plug in the global height and width accordingly.
So, you can see the difference:
The top video shows the YouTube-provided frame width and height and the bottom video uses the actual width of the phone’s screen to show the video without distorting the aspect ratio of the video.
If you like my tutorials, consider supporting me:
Your support will encourage me to make more interesting and creative videos for you.
You can also have a look at the video here:
[youtube https://www.youtube.com/watch?v=TfwdViMQZ98]
Please like my videos and share them with your friends and family. Also, subscribe to my channel and press the bell icon so you don’t miss any of the great projects I have planned for you.
https://www.youtube.com/c/obsidiansofteducation
Please like my social media pages for more educational resources and tips.
Facebook: https://www.facebook.com/ObsidianSoft/
Instagram: https://www.instagram.com/obsidiansoftapps/
Pinterest:
For links to free educational apps, have a look at the educational apps page