Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/valkryst/vmvc
An implementation of the Model-View-Controller pattern for my personal Swing projects.
https://github.com/valkryst/vmvc
gui-framework java model-view-controller mvc swing
Last synced: 8 days ago
JSON representation
An implementation of the Model-View-Controller pattern for my personal Swing projects.
- Host: GitHub
- URL: https://github.com/valkryst/vmvc
- Owner: Valkryst
- License: apache-2.0
- Created: 2017-12-11T17:26:59.000Z (about 7 years ago)
- Default Branch: master
- Last Pushed: 2024-12-09T17:27:43.000Z (24 days ago)
- Last Synced: 2024-12-09T18:33:12.906Z (24 days ago)
- Topics: gui-framework, java, model-view-controller, mvc, swing
- Language: Java
- Homepage:
- Size: 72.3 KB
- Stars: 0
- Watchers: 3
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- Funding: .github/FUNDING.yml
- License: LICENSE.md
Awesome Lists containing this project
README
[![Java CI with Maven](https://github.com/Valkryst/VMVC/actions/workflows/maven.yml/badge.svg)](https://github.com/Valkryst/VMVC/actions/workflows/maven.yml)
[![CodeQL](https://github.com/Valkryst/VMVC/actions/workflows/codeql.yml/badge.svg)](https://github.com/Valkryst/VMVC/actions/workflows/codeql.yml)This project is a Java implementation of the MVC design pattern. It is designed to be used with Swing UIs and for my
personal use. It is not intended to be a general purpose MVC framework, but you are free to use it as such if you wish.The design goals are as follows:
1. Separate the _View_ from the _Model_. This not only makes the code cleaner, easier to read and maintain, but it also
allows for easier testing of "business" logic in the _Model_ by having it separate from the UI.
2. Separate some of the Listener logic from the _View_ to the _Controller_. This allows for easier testing, without the
need for something to click through a UI to trigger a Listener.
3. Provide methods to perform get, set, or compound operations on the _Model_ VIA the _Controller_. Again, this allows
for cleaner code in the _View_ and less methods in the _Model_.The classes can be described as follows:
* `Model` - Contains data and "business" logic for manipulating the data. It has no knowledge of the _View_ or _Controller_.
* `View` - A Swing UI. It has no knowledge of the _Model_ and can only get/set data VIA the _Controller_.
* `Controller` - Provides methods for getting/setting data in its _Model_. It may also implement various Listener
interfaces (e.g. `ActionListener`, `ChangeListener`, etc.) if it needs to communicate with the _Model_ when the
_View_ changes.## Links
* Projects Using this Pattern
* [Schillsaver](https://github.com/Valkryst/Schillsaver)
* [Valerie](https://github.com/Valkryst/Valerie)
* [Installation](https://github.com/Valkryst/VMVC#installation)
* [Gradle](https://github.com/Valkryst/VMVC#-gradle)
* [Maven](https://github.com/Valkryst/VMVC#-maven)
* [sbt](https://github.com/Valkryst/VMVC#-scala-sbt)
* [Example](https://github.com/Valkryst/VMVC#example)
* [Controller](https://github.com/Valkryst/VMVC#controller)
* [Model](https://github.com/Valkryst/VMVC#model)
* [View](https://github.com/Valkryst/VMVC#view)
* [Credits & Inspiration](https://github.com/Valkryst/VMVC#credits--inspiration)## Installation
VMVC is hosted on the [JitPack package repository](https://jitpack.io/#Valkryst/VMVC)
which supports Gradle, Maven, and sbt.### ![Gradle](https://i.imgur.com/qtc6bXq.png?1) Gradle
Add JitPack to your `build.gradle` at the end of repositories.
```
allprojects {
repositories {
...
maven { url 'https://jitpack.io' }
}
}
```Add VMVC as a dependency.
```
dependencies {
implementation 'com.github.Valkryst:VMVC:0d3561d613db3f790f1639a04fb22a7a63ad44f0'
}
```### ![Maven](https://i.imgur.com/2TZzobp.png?1) Maven
Add JitPack as a repository.
``` xml
jitpack.io
https://jitpack.io
```
Add VMVC as a dependency.```xml
com.github.Valkryst
VMVC
0d3561d613db3f790f1639a04fb22a7a63ad44f0```
### ![Scala SBT](https://i.imgur.com/Nqv3mVd.png?1) Scala SBT
Add JitPack as a resolver.
```
resolvers += "jitpack" at "https://jitpack.io"
```Add VMVC as a dependency.
```
libraryDependencies += "com.github.Valkryst" % "VMVC" % "0d3561d613db3f790f1639a04fb22a7a63ad44f0"
```## Example
Using the _Controller_, _Model_, and _View_ classes below, we can display the _View_ in a Swing UI as follows:
```java
import javax.swing.*;
import java.awt.*;public class Example {
public static void main(final String[] args) {
SwingUtilities.invokeLater(() -> {
final var frame = new JFrame("Example");
frame.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
frame.setPreferredSize(new Dimension(640, 480));
// createView() will call the overridden methods in ExampleModel.
frame.add(new ExampleModel().createView());
frame.setVisible(true);
frame.pack();
frame.setLocationRelativeTo(null);
});
}
}
```### Controller
```java
// This can implement various Listener interfaces, if the View requires it.
public class ExampleController extends Controller {
public ExampleController(final ExampleModel model) {
super(model);
}
// Add methods to perform get, set, or compound actions on the Model.
// Add overridden methods from Listener interfaces, if the View requires it.
}
```### Model
```java
public class ExampleModel extends Model {
// Add instance variables to store data used by the View.
@Override
protected ExampleController createController() {
return new ExampleController(this);
}
@Override
protected ExampleView createView(final ExampleController controller) {
return new ExampleView(controller);
}
// Add methods to perform "business" logic on the data.
}
```### View
```java
public class ExampleView extends View {
public ExampleView(final ExampleController controller) {
super(controller);
// Create a Swing UI within ExampleView.
}
}
```## Credits & Inspiration
* Architecture
* Robert Eckstein's ["Java SE Application Design With MVC"](https://www.oracle.com/technical-resources/articles/javase/application-design-with-mvc.html).
* Juri Strumpflohner's ["Logical separation with MVC"](https://juristr.com/blog/2008/03/logical-separation-with-mvc/), a follow-up to Eckstein's article.
* [Filthy Rich Clients: Developing Animated and Graphical Effects for Desktop Java™ Applications](https://www.amazon.ca/Filthy-Rich-Clients-Developing-Applications/dp/0132413930/)