Click here to close now.


Java IoT Authors: Elizabeth White, Liz McMillan, Pat Romanski, AppDynamics Blog, Ed Featherston

Related Topics: Java IoT

Java IoT: Article

Application Foundation Classes

Application Foundation Classes

What Is The AFC?
I know that football season is right around the corner, but you're not going to find an in-depth analysis of football's weaker conference here. The Application Foundation Classes, or AFC, are Microsoft's answer to the Abstract Windowing Toolkit (AWT). The AFC builds on the AWT foundation to provide more user-friendly controls for your applications. The AFC is currently available only as a preview release and requires a Java 1.02 or 1.1 compatible compiler and Virtual Machine.

Last month, I showed you how to obtain, install and use the latest Java SDK 2.0 from Visual J++. You'll need to get the Java SDK 2.0 to begin using the Application Foundations Classes. The Java SDK 2.0 currently is available in a preview release. Check out the Microsoft Java SDK Web site at for the latest information.

AFC Packages
The Application Foundation Classes are provided in three packages:

  • The User Interface package, which provides the primary framework for applets, applications and user interface controls. The User Interface package is what most people will be referring to when they speak of the AFC. It includes menus, buttons, canvases, edit controls, frames, lists, marquees, panels, radio buttons, scrollers and tree view controls.
  • The FX package provides advanced graphic controls in your applications including control over colors, fonts, curves, text and textures. The FX package provides more flexibility than AWT because it is not limited only to system-defined standards. Especially when developing Intranet applications, you can use the FX classes to use all of the fonts and colors available to your system.
  • The Resource package provides access to Win-32 resources, including dialog boxes and string tables, from your Java applications.

    The User Interface package is the heart of the AFC. The focus here will be on how to begin to integrate the User Interface package into your own applications. I'll take a closer look at the FX and Resource packages in the near future.

    AFC Hierarchy
    The Application Foundation Classes are built on the foundation laid by the AWT. If you're already familiar with using the AWT, much of what you already know will remain familiar. Figure 1 illustrates the Application Foundation Class Hierarchy. The class names preceded by an asterisk (*) are AWT classes. As you can see, all of the Application Foundation Classes are extended from these base AWT classes. Figure 2 illustrates the class hierarchy of the user interface elements provided by the Application Foundation Classes. Many of these elements will be familiar to those familiar with AWT (i.e., button, check boxes, radio button) while others were not previously available (i.e., tree control, marquee).

    AWT and AFC Compared
    Before you think, "Here goes Microsoft again, trying to usurp yet another piece of the Java world", let's take a closer look. The Application Foundation Classes are built upon and extend the AWT, making it possible to mix both user interface models in your applications, which helps to preserve your user interface investment in your current applications and ease the transition over to a new programming model. Other user interface class models usually force a developer to choose between the AWT and another library.

    Like the AWT, the Application Foundation Classes are written completely in Java, making them completely cross platform-independent. They provide new and better scroll bars and sliders, a tree control, a tab display, the ability to move through the user interface using just the keyboard and a file system explorer. The Application Foundation Classes permit the development of applications with user interfaces that are familiar to users of traditional Windows-based applications.

    How To Use The AFC
    Building Java applications with the Application Foundation Classes is no different from building your applications using the AWT. Instead of using the Applet and Frame classes, the UIApplet and UIFrame classes are substituted instead. Since the UIApplet and UIFrame classes are extended from the AWT Applet and Frame classes, it is possible to mix both AWT and Application Foundation Classes components. Listing 1 demonstrates how to create a shell AFC applet. Listing 2 demonstrates how to call the HTML necessary to call the shell applet. The AFC can also be used to create standalone applications. Listing 3 demonstrates how to create a standalone shell application using the Application Foundation Classes. Remember, you-ll need to have the Microsoft Java SDK 2.0 preview version installed and have your Visual J++ environment configured to use the pre-release version of the compiler. I described how to configure your Visual J++ environment to use the new version of the compiler in detail last month. In its current release, the Application Foundation Classes support both the traditional event handling model as used in these examples and the event delegation model supported by Java 1.1.

    The Application Foundation Classes are available as part of the Microsoft Java SDK 2.0 on the Microsoft Java Web site, If you're looking to use the Application Foundation Classes on non-Windows based platforms, the classes are also provided separately. Since the new compiler and the Application Foundation Classes are still pre-release versions, a few bugs still exist and they aren't optimized yet for full production use. The final version of the Application Foundation Classes is scheduled to ship with Internet Explorer Version 4.0 later this year.

    It's clear that the Application Foundation Classes will play an increasingly important role in the development of Java applications from a Microsoft perspective. It's uncertain if the Application Foundation Classes will win over the hearts and minds of all Java developers - given the current state of relations between Microsoft, Sun and JavaSoft. The Application Foundation Classes do provide a number of user interface elements that allow developers to create applications with familiar user interfaces (at least to Windows users). I'm sure that when the Application Foundation Classes and the Java SDK 2.0 are released in their final form, Microsoft will provide Visual J++ wizards which help to automate the process of creating applications and applets which use the Application Foundation Classes.

    Microsoft currently does not plan on releasing the source code for the Application Foundation Classes. The plan is to make up for the lack of source code with documentation and support. This stance may hurt the Application Foundation Classes- chances of gaining wider acceptance; stay tuned though, this story is just beginning.

    Next Month: Using Application Foundation Class User Interface Controls.

  • More Stories By John Fronckowiak

    John Fronckowiak is the President of IDC Consulting, Inc., providing consulting and technical writing. He is also a Clinical Assistant Professor in Information Systems at the Adult Learning Program of Medaille College and is the author of several books and articles about iPhone development, programming, database design and development and networking. Fronckowiak has previously spoken at the Internet Commerce Expo in Boston, and the Conference on Instructional Technologies. In addition, he has over a decade of experience in the classroom as a college professor and runs dozens of training sessions for application developers.

    Comments (0)

    Share your thoughts on this story.

    Add your comment
    You must be signed in to add a comment. Sign-in | Register

    In accordance with our Comment Policy, we encourage comments that are on topic, relevant and to-the-point. We will remove comments that include profanity, personal attacks, racial slurs, threats of violence, or other inappropriate material that violates our Terms and Conditions, and will block users who make repeated violations. We ask all readers to expect diversity of opinion and to treat one another with dignity and respect.

    @ThingsExpo Stories
    The buzz continues for cloud, data analytics and the Internet of Things (IoT) and their collective impact across all industries. But a new conversation is emerging - how do companies use industry disruption and technology enablers to lead in markets undergoing change, uncertainty and ambiguity? Organizations of all sizes need to evolve and transform, often under massive pressure, as industry lines blur and merge and traditional business models are assaulted and turned upside down. In this new data-driven world, marketplaces reign supreme while interoperability, APIs and applications deliver un...
    The Internet of Things (IoT) is growing rapidly by extending current technologies, products and networks. By 2020, Cisco estimates there will be 50 billion connected devices. Gartner has forecast revenues of over $300 billion, just to IoT suppliers. Now is the time to figure out how you’ll make money – not just create innovative products. With hundreds of new products and companies jumping into the IoT fray every month, there’s no shortage of innovation. Despite this, McKinsey/VisionMobile data shows "less than 10 percent of IoT developers are making enough to support a reasonably sized team....
    Mobile messaging has been a popular communication channel for more than 20 years. Finnish engineer Matti Makkonen invented the idea for SMS (Short Message Service) in 1984, making his vision a reality on December 3, 1992 by sending the first message ("Happy Christmas") from a PC to a cell phone. Since then, the technology has evolved immensely, from both a technology standpoint, and in our everyday uses for it. Originally used for person-to-person (P2P) communication, i.e., Sally sends a text message to Betty – mobile messaging now offers tremendous value to businesses for customer and empl...
    There are so many tools and techniques for data analytics that even for a data scientist the choices, possible systems, and even the types of data can be daunting. In his session at @ThingsExpo, Chris Harrold, Global CTO for Big Data Solutions for EMC Corporation, will show how to perform a simple, but meaningful analysis of social sentiment data using freely available tools that take only minutes to download and install. Participants will get the download information, scripts, and complete end-to-end walkthrough of the analysis from start to finish. Participants will also be given the pract...
    Today’s connected world is moving from devices towards things, what this means is that by using increasingly low cost sensors embedded in devices we can create many new use cases. These span across use cases in cities, vehicles, home, offices, factories, retail environments, worksites, health, logistics, and health. These use cases rely on ubiquitous connectivity and generate massive amounts of data at scale. These technologies enable new business opportunities, ways to optimize and automate, along with new ways to engage with users.
    The IoT market is on track to hit $7.1 trillion in 2020. The reality is that only a handful of companies are ready for this massive demand. There are a lot of barriers, paint points, traps, and hidden roadblocks. How can we deal with these issues and challenges? The paradigm has changed. Old-style ad-hoc trial-and-error ways will certainly lead you to the dead end. What is mandatory is an overarching and adaptive approach to effectively handle the rapid changes and exponential growth.
    Can call centers hang up the phones for good? Intuitive Solutions did. WebRTC enabled this contact center provider to eliminate antiquated telephony and desktop phone infrastructure with a pure web-based solution, allowing them to expand beyond brick-and-mortar confines to a home-based agent model. It also ensured scalability and better service for customers, including MUY! Companies, one of the country's largest franchise restaurant companies with 232 Pizza Hut locations. This is one example of WebRTC adoption today, but the potential is limitless when powered by IoT.
    You have your devices and your data, but what about the rest of your Internet of Things story? Two popular classes of technologies that nicely handle the Big Data analytics for Internet of Things are Apache Hadoop and NoSQL. Hadoop is designed for parallelizing analytical work across many servers and is ideal for the massive data volumes you create with IoT devices. NoSQL databases such as Apache HBase are ideal for storing and retrieving IoT data as “time series data.”
    Clearly the way forward is to move to cloud be it bare metal, VMs or containers. One aspect of the current public clouds that is slowing this cloud migration is cloud lock-in. Every cloud vendor is trying to make it very difficult to move out once a customer has chosen their cloud. In his session at 17th Cloud Expo, Naveen Nimmu, CEO of Clouber, Inc., will advocate that making the inter-cloud migration as simple as changing airlines would help the entire industry to quickly adopt the cloud without worrying about any lock-in fears. In fact by having standard APIs for IaaS would help PaaS expl...
    SYS-CON Events announced today that ProfitBricks, the provider of painless cloud infrastructure, will exhibit at SYS-CON's 17th International Cloud Expo®, which will take place on November 3–5, 2015, at the Santa Clara Convention Center in Santa Clara, CA. ProfitBricks is the IaaS provider that offers a painless cloud experience for all IT users, with no learning curve. ProfitBricks boasts flexible cloud servers and networking, an integrated Data Center Designer tool for visual control over the cloud and the best price/performance value available. ProfitBricks was named one of the coolest Clo...
    Organizations already struggle with the simple collection of data resulting from the proliferation of IoT, lacking the right infrastructure to manage it. They can't only rely on the cloud to collect and utilize this data because many applications still require dedicated infrastructure for security, redundancy, performance, etc. In his session at 17th Cloud Expo, Emil Sayegh, CEO of Codero Hosting, will discuss how in order to resolve the inherent issues, companies need to combine dedicated and cloud solutions through hybrid hosting – a sustainable solution for the data required to manage I...
    NHK, Japan Broadcasting, will feature the upcoming @ThingsExpo Silicon Valley in a special 'Internet of Things' and smart technology documentary that will be filmed on the expo floor between November 3 to 5, 2015, in Santa Clara. NHK is the sole public TV network in Japan equivalent to the BBC in the UK and the largest in Asia with many award-winning science and technology programs. Japanese TV is producing a documentary about IoT and Smart technology and will be covering @ThingsExpo Silicon Valley. The program, to be aired during the peak viewership season of the year, will have a major impac...
    Apps and devices shouldn't stop working when there's limited or no network connectivity. Learn how to bring data stored in a cloud database to the edge of the network (and back again) whenever an Internet connection is available. In his session at 17th Cloud Expo, Bradley Holt, Developer Advocate at IBM Cloud Data Services, will demonstrate techniques for replicating cloud databases with devices in order to build offline-first mobile or Internet of Things (IoT) apps that can provide a better, faster user experience, both offline and online. The focus of this talk will be on IBM Cloudant, Apa...
    As a company adopts a DevOps approach to software development, what are key things that both the Dev and Ops side of the business must keep in mind to ensure effective continuous delivery? In his session at DevOps Summit, Mark Hydar, Head of DevOps, Ericsson TV Platforms, will share best practices and provide helpful tips for Ops teams to adopt an open line of communication with the development side of the house to ensure success between the two sides.
    WebRTC is about the data channel as much as about video and audio conferencing. However, basically all commercial WebRTC applications have been built with a focus on audio and video. The handling of “data” has been limited to text chat and file download – all other data sharing seems to end with screensharing. What is holding back a more intensive use of peer-to-peer data? In her session at @ThingsExpo, Dr Silvia Pfeiffer, WebRTC Applications Team Lead at National ICT Australia, will look at different existing uses of peer-to-peer data sharing and how it can become useful in a live session to...
    SYS-CON Events announced today that IBM Cloud Data Services has been named “Bronze Sponsor” of SYS-CON's 17th Cloud Expo, which will take place on November 3–5, 2015, at the Santa Clara Convention Center in Santa Clara, CA. IBM Cloud Data Services offers a portfolio of integrated, best-of-breed cloud data services for developers focused on mobile computing and analytics use cases.
    "Matrix is an ambitious open standard and implementation that's set up to break down the fragmentation problems that exist in IP messaging and VoIP communication," explained John Woolf, Technical Evangelist at Matrix, in this interview at @ThingsExpo, held Nov 4–6, 2014, at the Santa Clara Convention Center in Santa Clara, CA.
    WebRTC has had a real tough three or four years, and so have those working with it. Only a few short years ago, the development world were excited about WebRTC and proclaiming how awesome it was. You might have played with the technology a couple of years ago, only to find the extra infrastructure requirements were painful to implement and poorly documented. This probably left a bitter taste in your mouth, especially when things went wrong.
    The broad selection of hardware, the rapid evolution of operating systems and the time-to-market for mobile apps has been so rapid that new challenges for developers and engineers arise every day. Security, testing, hosting, and other metrics have to be considered through the process. In his session at Big Data Expo, Walter Maguire, Chief Field Technologist, HP Big Data Group, at Hewlett-Packard, will discuss the challenges faced by developers and a composite Big Data applications builder, focusing on how to help solve the problems that developers are continuously battling.
    Nowadays, a large number of sensors and devices are connected to the network. Leading-edge IoT technologies integrate various types of sensor data to create a new value for several business decision scenarios. The transparent cloud is a model of a new IoT emergence service platform. Many service providers store and access various types of sensor data in order to create and find out new business values by integrating such data.