Compare commits
3 Commits
| Author | SHA1 | Date | |
|---|---|---|---|
| e7a0a32fd9 | |||
| 8ee8e93ec6 | |||
| 2940b7d7da |
29
ProjectMonorail/.gitignore
vendored
Normal file
29
ProjectMonorail/.gitignore
vendored
Normal file
@@ -0,0 +1,29 @@
|
||||
### IntelliJ IDEA ###
|
||||
out/
|
||||
!**/src/main/**/out/
|
||||
!**/src/test/**/out/
|
||||
|
||||
### Eclipse ###
|
||||
.apt_generated
|
||||
.classpath
|
||||
.factorypath
|
||||
.project
|
||||
.settings
|
||||
.springBeans
|
||||
.sts4-cache
|
||||
bin/
|
||||
!**/src/main/**/bin/
|
||||
!**/src/test/**/bin/
|
||||
|
||||
### NetBeans ###
|
||||
/nbproject/private/
|
||||
/nbbuild/
|
||||
/dist/
|
||||
/nbdist/
|
||||
/.nb-gradle/
|
||||
|
||||
### VS Code ###
|
||||
.vscode/
|
||||
|
||||
### Mac OS ###
|
||||
.DS_Store
|
||||
8
ProjectMonorail/.idea/.gitignore
generated
vendored
Normal file
8
ProjectMonorail/.idea/.gitignore
generated
vendored
Normal file
@@ -0,0 +1,8 @@
|
||||
# Default ignored files
|
||||
/shelf/
|
||||
/workspace.xml
|
||||
# Editor-based HTTP Client requests
|
||||
/httpRequests/
|
||||
# Datasource local storage ignored files
|
||||
/dataSources/
|
||||
/dataSources.local.xml
|
||||
6
ProjectMonorail/.idea/misc.xml
generated
Normal file
6
ProjectMonorail/.idea/misc.xml
generated
Normal file
@@ -0,0 +1,6 @@
|
||||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<project version="4">
|
||||
<component name="ProjectRootManager" version="2" languageLevel="JDK_21" default="true" project-jdk-name="openjdk-21" project-jdk-type="JavaSDK">
|
||||
<output url="file://$PROJECT_DIR$/out" />
|
||||
</component>
|
||||
</project>
|
||||
8
ProjectMonorail/.idea/modules.xml
generated
Normal file
8
ProjectMonorail/.idea/modules.xml
generated
Normal file
@@ -0,0 +1,8 @@
|
||||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<project version="4">
|
||||
<component name="ProjectModuleManager">
|
||||
<modules>
|
||||
<module fileurl="file://$PROJECT_DIR$/ProjectMonorail.iml" filepath="$PROJECT_DIR$/ProjectMonorail.iml" />
|
||||
</modules>
|
||||
</component>
|
||||
</project>
|
||||
124
ProjectMonorail/.idea/uiDesigner.xml
generated
Normal file
124
ProjectMonorail/.idea/uiDesigner.xml
generated
Normal file
@@ -0,0 +1,124 @@
|
||||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<project version="4">
|
||||
<component name="Palette2">
|
||||
<group name="Swing">
|
||||
<item class="com.intellij.uiDesigner.HSpacer" tooltip-text="Horizontal Spacer" icon="/com/intellij/uiDesigner/icons/hspacer.svg" removable="false" auto-create-binding="false" can-attach-label="false">
|
||||
<default-constraints vsize-policy="1" hsize-policy="6" anchor="0" fill="1" />
|
||||
</item>
|
||||
<item class="com.intellij.uiDesigner.VSpacer" tooltip-text="Vertical Spacer" icon="/com/intellij/uiDesigner/icons/vspacer.svg" removable="false" auto-create-binding="false" can-attach-label="false">
|
||||
<default-constraints vsize-policy="6" hsize-policy="1" anchor="0" fill="2" />
|
||||
</item>
|
||||
<item class="javax.swing.JPanel" icon="/com/intellij/uiDesigner/icons/panel.svg" removable="false" auto-create-binding="false" can-attach-label="false">
|
||||
<default-constraints vsize-policy="3" hsize-policy="3" anchor="0" fill="3" />
|
||||
</item>
|
||||
<item class="javax.swing.JScrollPane" icon="/com/intellij/uiDesigner/icons/scrollPane.svg" removable="false" auto-create-binding="false" can-attach-label="true">
|
||||
<default-constraints vsize-policy="7" hsize-policy="7" anchor="0" fill="3" />
|
||||
</item>
|
||||
<item class="javax.swing.JButton" icon="/com/intellij/uiDesigner/icons/button.svg" removable="false" auto-create-binding="true" can-attach-label="false">
|
||||
<default-constraints vsize-policy="0" hsize-policy="3" anchor="0" fill="1" />
|
||||
<initial-values>
|
||||
<property name="text" value="Button" />
|
||||
</initial-values>
|
||||
</item>
|
||||
<item class="javax.swing.JRadioButton" icon="/com/intellij/uiDesigner/icons/radioButton.svg" removable="false" auto-create-binding="true" can-attach-label="false">
|
||||
<default-constraints vsize-policy="0" hsize-policy="3" anchor="8" fill="0" />
|
||||
<initial-values>
|
||||
<property name="text" value="RadioButton" />
|
||||
</initial-values>
|
||||
</item>
|
||||
<item class="javax.swing.JCheckBox" icon="/com/intellij/uiDesigner/icons/checkBox.svg" removable="false" auto-create-binding="true" can-attach-label="false">
|
||||
<default-constraints vsize-policy="0" hsize-policy="3" anchor="8" fill="0" />
|
||||
<initial-values>
|
||||
<property name="text" value="CheckBox" />
|
||||
</initial-values>
|
||||
</item>
|
||||
<item class="javax.swing.JLabel" icon="/com/intellij/uiDesigner/icons/label.svg" removable="false" auto-create-binding="false" can-attach-label="false">
|
||||
<default-constraints vsize-policy="0" hsize-policy="0" anchor="8" fill="0" />
|
||||
<initial-values>
|
||||
<property name="text" value="Label" />
|
||||
</initial-values>
|
||||
</item>
|
||||
<item class="javax.swing.JTextField" icon="/com/intellij/uiDesigner/icons/textField.svg" removable="false" auto-create-binding="true" can-attach-label="true">
|
||||
<default-constraints vsize-policy="0" hsize-policy="6" anchor="8" fill="1">
|
||||
<preferred-size width="150" height="-1" />
|
||||
</default-constraints>
|
||||
</item>
|
||||
<item class="javax.swing.JPasswordField" icon="/com/intellij/uiDesigner/icons/passwordField.svg" removable="false" auto-create-binding="true" can-attach-label="true">
|
||||
<default-constraints vsize-policy="0" hsize-policy="6" anchor="8" fill="1">
|
||||
<preferred-size width="150" height="-1" />
|
||||
</default-constraints>
|
||||
</item>
|
||||
<item class="javax.swing.JFormattedTextField" icon="/com/intellij/uiDesigner/icons/formattedTextField.svg" removable="false" auto-create-binding="true" can-attach-label="true">
|
||||
<default-constraints vsize-policy="0" hsize-policy="6" anchor="8" fill="1">
|
||||
<preferred-size width="150" height="-1" />
|
||||
</default-constraints>
|
||||
</item>
|
||||
<item class="javax.swing.JTextArea" icon="/com/intellij/uiDesigner/icons/textArea.svg" removable="false" auto-create-binding="true" can-attach-label="true">
|
||||
<default-constraints vsize-policy="6" hsize-policy="6" anchor="0" fill="3">
|
||||
<preferred-size width="150" height="50" />
|
||||
</default-constraints>
|
||||
</item>
|
||||
<item class="javax.swing.JTextPane" icon="/com/intellij/uiDesigner/icons/textPane.svg" removable="false" auto-create-binding="true" can-attach-label="true">
|
||||
<default-constraints vsize-policy="6" hsize-policy="6" anchor="0" fill="3">
|
||||
<preferred-size width="150" height="50" />
|
||||
</default-constraints>
|
||||
</item>
|
||||
<item class="javax.swing.JEditorPane" icon="/com/intellij/uiDesigner/icons/editorPane.svg" removable="false" auto-create-binding="true" can-attach-label="true">
|
||||
<default-constraints vsize-policy="6" hsize-policy="6" anchor="0" fill="3">
|
||||
<preferred-size width="150" height="50" />
|
||||
</default-constraints>
|
||||
</item>
|
||||
<item class="javax.swing.JComboBox" icon="/com/intellij/uiDesigner/icons/comboBox.svg" removable="false" auto-create-binding="true" can-attach-label="true">
|
||||
<default-constraints vsize-policy="0" hsize-policy="2" anchor="8" fill="1" />
|
||||
</item>
|
||||
<item class="javax.swing.JTable" icon="/com/intellij/uiDesigner/icons/table.svg" removable="false" auto-create-binding="true" can-attach-label="false">
|
||||
<default-constraints vsize-policy="6" hsize-policy="6" anchor="0" fill="3">
|
||||
<preferred-size width="150" height="50" />
|
||||
</default-constraints>
|
||||
</item>
|
||||
<item class="javax.swing.JList" icon="/com/intellij/uiDesigner/icons/list.svg" removable="false" auto-create-binding="true" can-attach-label="false">
|
||||
<default-constraints vsize-policy="6" hsize-policy="2" anchor="0" fill="3">
|
||||
<preferred-size width="150" height="50" />
|
||||
</default-constraints>
|
||||
</item>
|
||||
<item class="javax.swing.JTree" icon="/com/intellij/uiDesigner/icons/tree.svg" removable="false" auto-create-binding="true" can-attach-label="false">
|
||||
<default-constraints vsize-policy="6" hsize-policy="6" anchor="0" fill="3">
|
||||
<preferred-size width="150" height="50" />
|
||||
</default-constraints>
|
||||
</item>
|
||||
<item class="javax.swing.JTabbedPane" icon="/com/intellij/uiDesigner/icons/tabbedPane.svg" removable="false" auto-create-binding="true" can-attach-label="false">
|
||||
<default-constraints vsize-policy="3" hsize-policy="3" anchor="0" fill="3">
|
||||
<preferred-size width="200" height="200" />
|
||||
</default-constraints>
|
||||
</item>
|
||||
<item class="javax.swing.JSplitPane" icon="/com/intellij/uiDesigner/icons/splitPane.svg" removable="false" auto-create-binding="false" can-attach-label="false">
|
||||
<default-constraints vsize-policy="3" hsize-policy="3" anchor="0" fill="3">
|
||||
<preferred-size width="200" height="200" />
|
||||
</default-constraints>
|
||||
</item>
|
||||
<item class="javax.swing.JSpinner" icon="/com/intellij/uiDesigner/icons/spinner.svg" removable="false" auto-create-binding="true" can-attach-label="true">
|
||||
<default-constraints vsize-policy="0" hsize-policy="6" anchor="8" fill="1" />
|
||||
</item>
|
||||
<item class="javax.swing.JSlider" icon="/com/intellij/uiDesigner/icons/slider.svg" removable="false" auto-create-binding="true" can-attach-label="false">
|
||||
<default-constraints vsize-policy="0" hsize-policy="6" anchor="8" fill="1" />
|
||||
</item>
|
||||
<item class="javax.swing.JSeparator" icon="/com/intellij/uiDesigner/icons/separator.svg" removable="false" auto-create-binding="false" can-attach-label="false">
|
||||
<default-constraints vsize-policy="6" hsize-policy="6" anchor="0" fill="3" />
|
||||
</item>
|
||||
<item class="javax.swing.JProgressBar" icon="/com/intellij/uiDesigner/icons/progressbar.svg" removable="false" auto-create-binding="true" can-attach-label="false">
|
||||
<default-constraints vsize-policy="0" hsize-policy="6" anchor="0" fill="1" />
|
||||
</item>
|
||||
<item class="javax.swing.JToolBar" icon="/com/intellij/uiDesigner/icons/toolbar.svg" removable="false" auto-create-binding="false" can-attach-label="false">
|
||||
<default-constraints vsize-policy="0" hsize-policy="6" anchor="0" fill="1">
|
||||
<preferred-size width="-1" height="20" />
|
||||
</default-constraints>
|
||||
</item>
|
||||
<item class="javax.swing.JToolBar$Separator" icon="/com/intellij/uiDesigner/icons/toolbarSeparator.svg" removable="false" auto-create-binding="false" can-attach-label="false">
|
||||
<default-constraints vsize-policy="0" hsize-policy="0" anchor="0" fill="1" />
|
||||
</item>
|
||||
<item class="javax.swing.JScrollBar" icon="/com/intellij/uiDesigner/icons/scrollbar.svg" removable="false" auto-create-binding="true" can-attach-label="false">
|
||||
<default-constraints vsize-policy="6" hsize-policy="0" anchor="0" fill="2" />
|
||||
</item>
|
||||
</group>
|
||||
</component>
|
||||
</project>
|
||||
6
ProjectMonorail/.idea/vcs.xml
generated
Normal file
6
ProjectMonorail/.idea/vcs.xml
generated
Normal file
@@ -0,0 +1,6 @@
|
||||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<project version="4">
|
||||
<component name="VcsDirectoryMappings">
|
||||
<mapping directory="$PROJECT_DIR$/.." vcs="Git" />
|
||||
</component>
|
||||
</project>
|
||||
20
ProjectMonorail/.idea/workspace.xml
generated
20
ProjectMonorail/.idea/workspace.xml
generated
@@ -5,14 +5,15 @@
|
||||
</component>
|
||||
<component name="ChangeListManager">
|
||||
<list default="true" id="39e7c520-e505-4e53-a269-c949d7c9f5d1" name="Changes" comment="">
|
||||
<change afterPath="$PROJECT_DIR$/src/Scripts/Wheels/DrawOrnament.java" afterDir="false" />
|
||||
<change afterPath="$PROJECT_DIR$/src/Scripts/Wheels/DrawOrnamentOval.java" afterDir="false" />
|
||||
<change afterPath="$PROJECT_DIR$/src/Scripts/Wheels/DrawOrnamentTriangle.java" afterDir="false" />
|
||||
<change afterPath="$PROJECT_DIR$/src/Scripts/Wheels/IOrnament.java" afterDir="false" />
|
||||
<change beforePath="$PROJECT_DIR$/src/Scripts/CountWheels.java" beforeDir="false" afterPath="$PROJECT_DIR$/src/Scripts/Wheels/CountWheels.java" afterDir="false" />
|
||||
<change beforePath="$PROJECT_DIR$/src/Scripts/DrawingModernMonorail.java" beforeDir="false" afterPath="$PROJECT_DIR$/src/Scripts/DrawingModernMonorail.java" afterDir="false" />
|
||||
<change beforePath="$PROJECT_DIR$/src/Scripts/DrawingMonorail.java" beforeDir="false" afterPath="$PROJECT_DIR$/src/Scripts/DrawingMonorail.java" afterDir="false" />
|
||||
<change beforePath="$PROJECT_DIR$/src/Scripts/DrawingWheels.java" beforeDir="false" afterPath="$PROJECT_DIR$/src/Scripts/Wheels/DrawingWheels.java" afterDir="false" />
|
||||
<change beforePath="$PROJECT_DIR$/.idea/workspace.xml" beforeDir="false" afterPath="$PROJECT_DIR$/.idea/workspace.xml" afterDir="false" />
|
||||
<change beforePath="$PROJECT_DIR$/src/CountWheels.java" beforeDir="false" />
|
||||
<change beforePath="$PROJECT_DIR$/src/DirectionType.java" beforeDir="false" />
|
||||
<change beforePath="$PROJECT_DIR$/src/DrawingField.java" beforeDir="false" />
|
||||
<change beforePath="$PROJECT_DIR$/src/DrawingModernMonorail.java" beforeDir="false" />
|
||||
<change beforePath="$PROJECT_DIR$/src/DrawingWheels.java" beforeDir="false" />
|
||||
<change beforePath="$PROJECT_DIR$/src/EntityModernMonorail.java" beforeDir="false" />
|
||||
<change beforePath="$PROJECT_DIR$/src/FormModernMonorail.java" beforeDir="false" />
|
||||
<change beforePath="$PROJECT_DIR$/src/Program.java" beforeDir="false" />
|
||||
</list>
|
||||
<option name="SHOW_DIALOG" value="false" />
|
||||
<option name="HIGHLIGHT_CONFLICTS" value="true" />
|
||||
@@ -43,7 +44,7 @@
|
||||
"Application.Program.executor": "Run",
|
||||
"RunOnceActivity.OpenProjectViewOnStart": "true",
|
||||
"RunOnceActivity.ShowReadmeOnStart": "true",
|
||||
"git-widget-placeholder": "LabWork__2",
|
||||
"git-widget-placeholder": "LabWorking__2",
|
||||
"kotlin-language-version-configured": "true"
|
||||
}
|
||||
}]]></component>
|
||||
@@ -60,6 +61,7 @@
|
||||
<attachedChunks>
|
||||
<set>
|
||||
<option value="jdk-21.0.2-openjdk-21.0.2-4caba194b151-4f524021" />
|
||||
<option value="jdk-22-openjdk-22-3183f394aec4-bad0321e" />
|
||||
</set>
|
||||
</attachedChunks>
|
||||
</component>
|
||||
|
||||
11
ProjectMonorail/ProjectMonorail.iml
Normal file
11
ProjectMonorail/ProjectMonorail.iml
Normal file
@@ -0,0 +1,11 @@
|
||||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<module type="JAVA_MODULE" version="4">
|
||||
<component name="NewModuleRootManager" inherit-compiler-output="true">
|
||||
<exclude-output />
|
||||
<content url="file://$MODULE_DIR$">
|
||||
<sourceFolder url="file://$MODULE_DIR$/src" isTestSource="false" />
|
||||
</content>
|
||||
<orderEntry type="inheritedJdk" />
|
||||
<orderEntry type="sourceFolder" forTests="false" />
|
||||
</component>
|
||||
</module>
|
||||
BIN
ProjectMonorail/Resource/Arrows/ArrowDown.png
Normal file
BIN
ProjectMonorail/Resource/Arrows/ArrowDown.png
Normal file
Binary file not shown.
|
After Width: | Height: | Size: 2.0 KiB |
BIN
ProjectMonorail/Resource/Arrows/ArrowLeft.png
Normal file
BIN
ProjectMonorail/Resource/Arrows/ArrowLeft.png
Normal file
Binary file not shown.
|
After Width: | Height: | Size: 1.9 KiB |
BIN
ProjectMonorail/Resource/Arrows/ArrowRight.png
Normal file
BIN
ProjectMonorail/Resource/Arrows/ArrowRight.png
Normal file
Binary file not shown.
|
After Width: | Height: | Size: 1.9 KiB |
BIN
ProjectMonorail/Resource/Arrows/ArrowUp.png
Normal file
BIN
ProjectMonorail/Resource/Arrows/ArrowUp.png
Normal file
Binary file not shown.
|
After Width: | Height: | Size: 1.9 KiB |
@@ -0,0 +1,36 @@
|
||||
package Scripts.CollectionGenericObjects;
|
||||
|
||||
import Scripts.Drawing.DrawingMonorail;
|
||||
|
||||
import java.awt.*;
|
||||
|
||||
public abstract class AbstractCompany {
|
||||
protected int _placeSizeWidth = 220;
|
||||
protected int _placeSizeHeight = 155;
|
||||
protected int _pictureWidth;
|
||||
protected int _pictureHeight;
|
||||
public ICollectionGenericObjects<DrawingMonorail> _collection = null;
|
||||
private int GetMaxCount() {
|
||||
return _pictureWidth * _pictureHeight / (_placeSizeWidth * _placeSizeHeight);
|
||||
|
||||
}
|
||||
public AbstractCompany(int picWidth, int picHeight, ICollectionGenericObjects<DrawingMonorail> collection)
|
||||
{
|
||||
_pictureWidth = picWidth;
|
||||
_pictureHeight = picHeight;
|
||||
_collection = collection;
|
||||
System.out.println(_pictureHeight+" "+_pictureWidth+" "+_placeSizeHeight+" "+_placeSizeWidth);
|
||||
_collection.SetMaxCount(GetMaxCount(), (Class) DrawingMonorail.class);
|
||||
}
|
||||
//Перегрузок нет
|
||||
public DrawingMonorail GetRandomObject()
|
||||
{
|
||||
return _collection.Get((int)(Math.random()*GetMaxCount() + 0));
|
||||
}
|
||||
public void SetPosition()
|
||||
{
|
||||
SetObjectsPosition();
|
||||
}
|
||||
public abstract void DrawBackgound(Graphics graphics);
|
||||
protected abstract void SetObjectsPosition();
|
||||
}
|
||||
@@ -0,0 +1,61 @@
|
||||
package Scripts.CollectionGenericObjects;
|
||||
|
||||
import Scripts.Drawing.DrawingModernMonorail;
|
||||
import Scripts.Drawing.DrawingMonorail;
|
||||
import Scripts.Entities.EntityModernMonorail;
|
||||
import Scripts.Entities.EntityMonorail;
|
||||
import Scripts.Wheels.IDrawingWheels;
|
||||
|
||||
import java.lang.reflect.Array;
|
||||
import java.util.Random;
|
||||
|
||||
public class AdditionalCollection <T extends EntityMonorail, U extends IDrawingWheels>{
|
||||
public T[] _collectionEntity;
|
||||
public U[] _collectionWheels;
|
||||
public AdditionalCollection(int size, Class<T> type1, Class<T> type2) {
|
||||
_collectionEntity = (T[]) Array.newInstance(type1, size);
|
||||
_collectionWheels = (U[]) Array.newInstance(type2, size);
|
||||
CountEntities = size;
|
||||
CountWheels = size;
|
||||
}
|
||||
public int CountEntities;
|
||||
public int CountWheels;
|
||||
public int Insert(T entity) {
|
||||
int index = 0;
|
||||
while (index < CountEntities) {
|
||||
if (_collectionEntity[index] == null)
|
||||
{
|
||||
_collectionEntity[index] = entity;
|
||||
return index;
|
||||
}
|
||||
++index;
|
||||
}
|
||||
return -1;
|
||||
}
|
||||
public int Insert(U decks) {
|
||||
int index = 0;
|
||||
while (index < CountWheels) {
|
||||
if (_collectionWheels[index] == null)
|
||||
{
|
||||
_collectionWheels[index] = decks;
|
||||
return index;
|
||||
}
|
||||
++index;
|
||||
}
|
||||
return -1;
|
||||
}
|
||||
public DrawingMonorail CreateAdditionalCollectionMonorail() {
|
||||
Random random = new Random();
|
||||
if (_collectionEntity == null || _collectionWheels == null) return null;
|
||||
T entity = _collectionEntity[random.nextInt(CountEntities)];
|
||||
U wheels = _collectionWheels[random.nextInt(CountWheels)];
|
||||
DrawingMonorail drawingBaseStormtrooper = null;
|
||||
if (entity instanceof EntityModernMonorail) {
|
||||
drawingBaseStormtrooper = new DrawingModernMonorail((EntityModernMonorail)entity, wheels);
|
||||
}
|
||||
else {
|
||||
drawingBaseStormtrooper = new DrawingMonorail(entity, wheels);
|
||||
}
|
||||
return drawingBaseStormtrooper;
|
||||
}
|
||||
}
|
||||
@@ -0,0 +1,48 @@
|
||||
package Scripts.CollectionGenericObjects;
|
||||
|
||||
import Scripts.Drawing.DrawingMonorail;
|
||||
|
||||
import java.awt.*;
|
||||
|
||||
public class DepotSharingService extends AbstractCompany {
|
||||
public DepotSharingService (int picWidth, int picHeight, ICollectionGenericObjects<DrawingMonorail> collection) {
|
||||
super(picWidth, picHeight, collection);
|
||||
}
|
||||
|
||||
private int _offsetX = 30;
|
||||
|
||||
@Override
|
||||
public void DrawBackgound(Graphics graphics) {
|
||||
int width = _pictureWidth / _placeSizeWidth;
|
||||
int height = _pictureHeight / _placeSizeHeight;
|
||||
graphics.setColor(Color.BLACK);
|
||||
for (int i = 0; i < width; i++)
|
||||
{
|
||||
for (int j = 0; j < height + 1; ++j)
|
||||
{
|
||||
graphics.drawLine(i * _offsetX + i * _placeSizeWidth, j * _placeSizeHeight, _placeSizeWidth + i * _offsetX + i * _placeSizeWidth, j * _placeSizeHeight);
|
||||
graphics.drawLine(i * _offsetX + i * _placeSizeWidth, j * _placeSizeHeight, i * _offsetX + i * _placeSizeWidth, _placeSizeHeight + j * _placeSizeHeight);
|
||||
graphics.drawLine(i * _offsetX + i * _placeSizeWidth, _placeSizeHeight + j * _placeSizeHeight, _placeSizeWidth + i * _offsetX + i * _placeSizeWidth, _placeSizeHeight + j * _placeSizeHeight);
|
||||
}
|
||||
}
|
||||
}
|
||||
@Override
|
||||
protected void SetObjectsPosition() {
|
||||
int width = _pictureWidth / _placeSizeWidth;
|
||||
int height = _pictureHeight / _placeSizeHeight;
|
||||
|
||||
int boarderOffsetX = 20;
|
||||
int boarderOffsetY = 20;
|
||||
|
||||
int currnetIndex = 0;
|
||||
|
||||
for (int j = height; j >= 0; j--) {
|
||||
for (int i = 0; i < width; i++, currnetIndex++) {
|
||||
if (_collection.Get(currnetIndex) == null) continue;
|
||||
|
||||
_collection.Get(currnetIndex).SetPictureSize(_pictureWidth, _pictureHeight);
|
||||
_collection.Get(currnetIndex).SetPosition(boarderOffsetX + i * _placeSizeWidth + i * _offsetX, boarderOffsetY + j * _placeSizeHeight);
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
@@ -0,0 +1,11 @@
|
||||
package Scripts.CollectionGenericObjects;
|
||||
|
||||
public interface ICollectionGenericObjects<T>
|
||||
{
|
||||
int getCount();
|
||||
void SetMaxCount(int count, Class<T> type);
|
||||
int Insert(T obj);
|
||||
int Insert(T obj, int position);
|
||||
T Remove(int position);
|
||||
T Get(int position);
|
||||
}
|
||||
@@ -0,0 +1,76 @@
|
||||
package Scripts.CollectionGenericObjects;
|
||||
|
||||
import java.lang.reflect.Array;
|
||||
|
||||
public class MassiveGenericObjects<T> implements ICollectionGenericObjects<T>
|
||||
{
|
||||
private T[] _collection;
|
||||
private int Count;
|
||||
public void SetMaxCount(int size, Class<T> type) {
|
||||
if (size > 0) {
|
||||
_collection = (T[]) Array.newInstance(type, size);
|
||||
Count = size;
|
||||
}
|
||||
}
|
||||
@Override
|
||||
public int getCount() {
|
||||
return Count;
|
||||
}
|
||||
@Override
|
||||
public int Insert(T obj) {
|
||||
int index = 0;
|
||||
while (index < getCount())
|
||||
{
|
||||
if (_collection[index] == null)
|
||||
{
|
||||
_collection[index] = obj;
|
||||
return index;
|
||||
}
|
||||
++index;
|
||||
}
|
||||
return -1;
|
||||
}
|
||||
@Override
|
||||
public int Insert(T obj, int position) {
|
||||
if (position >= getCount() || position < 0)
|
||||
return -1;
|
||||
if (_collection[position] == null) {
|
||||
_collection[position] = obj;
|
||||
return position;
|
||||
}
|
||||
int index = position + 1;
|
||||
while (index < getCount())
|
||||
{
|
||||
if (_collection[index] == null)
|
||||
{
|
||||
_collection[index] = obj;
|
||||
return index;
|
||||
}
|
||||
++index;
|
||||
}
|
||||
index = position - 1;
|
||||
while (index >= 0)
|
||||
{
|
||||
if (_collection[index] == null)
|
||||
{
|
||||
_collection[index] = obj;
|
||||
return index;
|
||||
}
|
||||
--index;
|
||||
}
|
||||
return -1;
|
||||
}
|
||||
@Override
|
||||
public T Remove(int position) {
|
||||
if (position >= getCount() || position < 0)
|
||||
return null;
|
||||
T obj = (T) _collection[position];
|
||||
_collection[position] = null;
|
||||
return obj;
|
||||
}
|
||||
@Override
|
||||
public T Get(int position) {
|
||||
if (position >= getCount() || position < 0) return null;
|
||||
return (T) _collection[position];
|
||||
}
|
||||
}
|
||||
8
ProjectMonorail/src/Scripts/Drawing/DirectionType.java
Normal file
8
ProjectMonorail/src/Scripts/Drawing/DirectionType.java
Normal file
@@ -0,0 +1,8 @@
|
||||
package Scripts.Drawing;
|
||||
|
||||
public enum DirectionType {
|
||||
Up,
|
||||
Down,
|
||||
Left,
|
||||
Right;
|
||||
}
|
||||
71
ProjectMonorail/src/Scripts/Drawing/DrawingField.java
Normal file
71
ProjectMonorail/src/Scripts/Drawing/DrawingField.java
Normal file
@@ -0,0 +1,71 @@
|
||||
package Scripts.Drawing;
|
||||
|
||||
import Scripts.Forms.FormModernMonorail;
|
||||
|
||||
import javax.swing.*;
|
||||
import java.awt.*;
|
||||
import java.util.Random;
|
||||
|
||||
public class DrawingField extends JPanel {
|
||||
private final FormModernMonorail field;
|
||||
private DrawingMonorail _drawingMonorail;
|
||||
public DrawingField(FormModernMonorail field) {
|
||||
this.field = field;
|
||||
}
|
||||
|
||||
public DrawingMonorail getDrawingMonorail() {return _drawingMonorail;}
|
||||
public void setDrawingMonorail(DrawingMonorail drawingMonorail) {_drawingMonorail = drawingMonorail;}
|
||||
|
||||
@Override
|
||||
protected void paintComponent(Graphics g) {
|
||||
super.paintComponent(g);
|
||||
Graphics2D g2 =(Graphics2D)g;
|
||||
if (_drawingMonorail !=null)
|
||||
_drawingMonorail.DrawTransport(g2);
|
||||
else return;
|
||||
}
|
||||
|
||||
public void UpButtonAction(){
|
||||
if (_drawingMonorail !=null)
|
||||
_drawingMonorail.MoveTransport(DirectionType.Up);
|
||||
return;
|
||||
}
|
||||
|
||||
public void DownButtonAction(){
|
||||
if (_drawingMonorail !=null)
|
||||
_drawingMonorail.MoveTransport(DirectionType.Down);
|
||||
return;
|
||||
}
|
||||
|
||||
public void RightButtonAction(){
|
||||
if (_drawingMonorail !=null)
|
||||
_drawingMonorail.MoveTransport(DirectionType.Right);
|
||||
return;
|
||||
}
|
||||
|
||||
public void LeftButtonAction(){
|
||||
if (_drawingMonorail !=null)
|
||||
_drawingMonorail.MoveTransport(DirectionType.Left);
|
||||
return;
|
||||
}
|
||||
|
||||
public void CreateButtonAction_Monorail(){
|
||||
Random rnd=new Random();
|
||||
_drawingMonorail = new DrawingMonorail(rnd.nextInt(50)+10,rnd.nextInt(100)+500,new Color(rnd.nextInt(256),rnd.nextInt(256),rnd.nextInt(256)), null, null);
|
||||
_drawingMonorail.SetPictureSize(getWidth(),getHeight());
|
||||
_drawingMonorail.SetPosition(rnd.nextInt(100)+10,rnd.nextInt(100)+10);
|
||||
}
|
||||
|
||||
public void CreateButtonAction_ModernMonorail(){
|
||||
Random rnd=new Random();
|
||||
_drawingMonorail = new DrawingModernMonorail(rnd.nextInt(50)+10,rnd.nextInt(100)+500,new Color(rnd.nextInt(256),rnd.nextInt(256),rnd.nextInt(256)), new Color(rnd.nextInt(256),rnd.nextInt(256),rnd.nextInt(256)), rnd.nextBoolean(), true);
|
||||
_drawingMonorail.SetPictureSize(getWidth(),getHeight());
|
||||
_drawingMonorail.SetPosition(rnd.nextInt(100)+10,rnd.nextInt(100)+10);
|
||||
}
|
||||
|
||||
public void ResizeField(){
|
||||
if (_drawingMonorail !=null)
|
||||
_drawingMonorail.SetPictureSize(getWidth(),getHeight());
|
||||
else return;
|
||||
}
|
||||
}
|
||||
140
ProjectMonorail/src/Scripts/Drawing/DrawingModernMonorail.java
Normal file
140
ProjectMonorail/src/Scripts/Drawing/DrawingModernMonorail.java
Normal file
@@ -0,0 +1,140 @@
|
||||
package Scripts.Drawing;
|
||||
|
||||
import Scripts.Entities.EntityModernMonorail;
|
||||
import Scripts.Entities.EntityMonorail;
|
||||
import Scripts.Wheels.DrawingWheels;
|
||||
import Scripts.Wheels.IDrawingWheels;
|
||||
|
||||
import java.awt.*;
|
||||
import java.util.Random;
|
||||
|
||||
public class DrawingModernMonorail extends DrawingMonorail {
|
||||
public DrawingModernMonorail(int speed, float weight, Color bodyColor, Color additionalColor, boolean monorailTrack, boolean cabin)
|
||||
{
|
||||
super(speed, weight, bodyColor, 190, 80);
|
||||
|
||||
_entityMonorail = new EntityModernMonorail(speed, weight, bodyColor, additionalColor, monorailTrack, cabin);
|
||||
_wheels = new DrawingWheels();
|
||||
Random rnd = new Random();
|
||||
_wheels.SetCountWheels(2 + rnd.nextInt(0, 3));
|
||||
_wheelsSeed = rnd.nextInt(0, 2);
|
||||
}
|
||||
|
||||
public DrawingModernMonorail(EntityModernMonorail entityModernMonorail, IDrawingWheels wheels)
|
||||
{
|
||||
super((EntityMonorail)entityModernMonorail, 190, 80, wheels);
|
||||
|
||||
_entityMonorail = new EntityModernMonorail(entityModernMonorail.getSpeed(), entityModernMonorail.getWeight(), entityModernMonorail.getBodyColor(), entityModernMonorail.getAdditionalColor(), entityModernMonorail.getMonorailTrack(), entityModernMonorail.getMonorailTrack());
|
||||
_wheels = new DrawingWheels();
|
||||
Random rnd = new Random();
|
||||
_wheels.SetCountWheels(2 + rnd.nextInt(0, 3));
|
||||
_wheelsSeed = rnd.nextInt(0, 2);
|
||||
}
|
||||
|
||||
@Override
|
||||
public void DrawTransport(Graphics g)
|
||||
{
|
||||
if (! (_entityMonorail instanceof EntityModernMonorail)) return;
|
||||
|
||||
super.DrawTransport(g);
|
||||
|
||||
EntityModernMonorail modernMonorail = (EntityModernMonorail)_entityMonorail;
|
||||
Graphics2D g2 = (Graphics2D) g;
|
||||
|
||||
g.setColor(modernMonorail.getAdditionalColor());
|
||||
//Окна
|
||||
g.drawRect(_startPositionX + 14, _startPositionY + 2, 5, 6);
|
||||
g.drawRect(_startPositionX + 21, _startPositionY + 2, 5, 6);
|
||||
g.drawRect(_startPositionX + 70, _startPositionY + 2, 5, 6);
|
||||
|
||||
g.setColor(modernMonorail.getBodyColor());
|
||||
|
||||
if (modernMonorail.getMonorailTrack()) {
|
||||
if (modernMonorail.getCabin()) {
|
||||
g.fillRect(_startPositionX, _startPositionY + 35, 170, 5);
|
||||
}
|
||||
else {
|
||||
g.fillRect(_startPositionX, _startPositionY + 35, 86, 5);
|
||||
}
|
||||
}
|
||||
|
||||
//Колеса
|
||||
int[] coordinatesX = new int[_wheels.getCountWheels()];
|
||||
coordinatesX[0] = _startPositionX + 10;
|
||||
coordinatesX[1] = _startPositionX + 65;
|
||||
|
||||
if (coordinatesX.length == 4) {
|
||||
coordinatesX[2] = _startPositionX + 25;
|
||||
coordinatesX[3] = _startPositionX + 50;
|
||||
}
|
||||
else if (coordinatesX.length == 3) {
|
||||
Random rnd = new Random();
|
||||
if (_wheelsSeed == 1) {
|
||||
coordinatesX[2] = _startPositionX + 25;
|
||||
}
|
||||
else {
|
||||
coordinatesX[2] = _startPositionX + 50;
|
||||
}
|
||||
}
|
||||
|
||||
_wheels.DrawWheels(g2, coordinatesX, _startPositionY + 30, modernMonorail.getAdditionalColor());
|
||||
|
||||
if (modernMonorail.getCabin()) {
|
||||
int offset = 170;
|
||||
|
||||
g.setColor(modernMonorail.getBodyColor());
|
||||
//Кузов монорельса
|
||||
g.drawLine(_startPositionX - 8 + offset, _startPositionY + 10, _startPositionX - 13 + offset, _startPositionY);
|
||||
g.drawLine(_startPositionX - 13 + offset, _startPositionY, _startPositionX - 80 + offset, _startPositionY);
|
||||
g.drawLine(_startPositionX - 80 + offset, _startPositionY, _startPositionX - 80 + offset, _startPositionY + 25);
|
||||
g.drawLine(_startPositionX - 80 + offset, _startPositionY + 25, _startPositionX - 8 + offset, _startPositionY + 25);
|
||||
g.drawLine(_startPositionX - 8 + offset, _startPositionY + 25, _startPositionX - 8 + offset, _startPositionY + 10);
|
||||
g.drawLine(_startPositionX - 8 + offset, _startPositionY + 10, _startPositionX - 30 + offset, _startPositionY + 10);
|
||||
g.drawLine(_startPositionX - 39 + offset, _startPositionY + 10, _startPositionX - 80 + offset, _startPositionY + 10);
|
||||
|
||||
//Дверь
|
||||
g.drawRect(_startPositionX - 39 + offset, _startPositionY + 5, 9, 15);
|
||||
|
||||
//Окна
|
||||
g.setColor(modernMonorail.getAdditionalColor());
|
||||
g.drawRect(_startPositionX - 20 + offset, _startPositionY + 2, 5, 6);
|
||||
g.drawRect(_startPositionX - 27 + offset, _startPositionY + 2, 5, 6);
|
||||
g.drawRect(_startPositionX - 76 + offset, _startPositionY + 2, 5, 6);
|
||||
|
||||
//Связка монорельса
|
||||
g.setColor(_entityMonorail.getBodyColor());
|
||||
g.fillRect(_startPositionX - 87 + offset, _startPositionY + 2, 7, 22);
|
||||
|
||||
//Нижняя часть монорельса
|
||||
int[] xPoly_LeftSide = new int[]{_startPositionX + offset, _startPositionX - 8 + offset, _startPositionX - 72 + offset, _startPositionX - 36 + offset, _startPositionX - 36 + offset, _startPositionX - 15 + offset, _startPositionX - 15 + offset, _startPositionX + offset};
|
||||
int[] yPoly_LeftSide = new int[] {_startPositionY + 30, _startPositionY + 25, _startPositionY + 25, _startPositionY + 25, _startPositionY + 32, _startPositionY + 32, _startPositionY + 35, _startPositionY + 32};
|
||||
g.fillPolygon(xPoly_LeftSide, yPoly_LeftSide, xPoly_LeftSide.length);
|
||||
|
||||
int[] xPoly_RightSide = new int[]{_startPositionX - 86 + offset, _startPositionX - 80 + offset, _startPositionX - 50 + offset, _startPositionX - 50 + offset, _startPositionX - 69 + offset, _startPositionX - 79 + offset, _startPositionX - 86 + offset};
|
||||
int[] yPoly_RightSide = new int[] {_startPositionY + 30, _startPositionY + 25, _startPositionY+ 25, _startPositionY + 32, _startPositionY + 32 , _startPositionY + 35, _startPositionY + 32};
|
||||
g.fillPolygon(xPoly_RightSide, yPoly_RightSide, xPoly_RightSide.length);
|
||||
g.fillRect(_startPositionX - 80 + offset, _startPositionY + 25, 70, 3);
|
||||
|
||||
//Колеса
|
||||
coordinatesX = new int[_wheels.getCountWheels()];
|
||||
coordinatesX[0] = _startPositionX - 20 + offset;
|
||||
coordinatesX[1] = _startPositionX - 75 + offset;
|
||||
|
||||
if (coordinatesX.length == 4) {
|
||||
coordinatesX[2] = _startPositionX - 35 + offset;
|
||||
coordinatesX[3] = _startPositionX - 60 + offset;
|
||||
}
|
||||
else if (coordinatesX.length == 3) {
|
||||
Random rnd = new Random();
|
||||
if (_wheelsSeed == 1) {
|
||||
coordinatesX[2] = _startPositionX - 35 + offset;
|
||||
}
|
||||
else {
|
||||
coordinatesX[2] = _startPositionX - 60 + offset;
|
||||
}
|
||||
}
|
||||
|
||||
_wheels.DrawWheels(g2, coordinatesX , _startPositionY + 30, modernMonorail.getAdditionalColor());
|
||||
}
|
||||
}
|
||||
}
|
||||
243
ProjectMonorail/src/Scripts/Drawing/DrawingMonorail.java
Normal file
243
ProjectMonorail/src/Scripts/Drawing/DrawingMonorail.java
Normal file
@@ -0,0 +1,243 @@
|
||||
package Scripts.Drawing;
|
||||
|
||||
import Scripts.Entities.EntityMonorail;
|
||||
import Scripts.Wheels.DrawingWheels;
|
||||
import Scripts.Wheels.IDrawingWheels;
|
||||
|
||||
import java.awt.*;
|
||||
import java.util.Random;
|
||||
|
||||
public class DrawingMonorail {
|
||||
protected EntityMonorail _entityMonorail;
|
||||
protected IDrawingWheels _wheels;
|
||||
|
||||
private Integer _pictureWidth = null;
|
||||
private Integer _pictureHeight = null;
|
||||
|
||||
protected int _startPositionX;
|
||||
protected int _startPositionY;
|
||||
|
||||
private int _drawningMonorailWidth = 100;
|
||||
private int _drawningMonorailHeight = 80;
|
||||
|
||||
public EntityMonorail getMonorail() {return _entityMonorail;}
|
||||
public IDrawingWheels getWheels() {return _wheels;}
|
||||
protected int _wheelsSeed;
|
||||
|
||||
public int GetPositionX() { return _startPositionX;}
|
||||
|
||||
public int GetPositionY() {return _startPositionY;}
|
||||
|
||||
public int GetWidth() { return _drawningMonorailWidth;}
|
||||
|
||||
public int GetHeight() { return _drawningMonorailHeight;}
|
||||
|
||||
public DrawingMonorail(int speed, float weight, Color bodyColor, Integer drawningMonorailWidth, Integer drawningMonorailHeight)
|
||||
{
|
||||
this(drawningMonorailWidth, drawningMonorailHeight);
|
||||
|
||||
_entityMonorail = new EntityMonorail(speed, weight, bodyColor);
|
||||
_wheels = new DrawingWheels();
|
||||
Random rnd = new Random();
|
||||
_wheels.SetCountWheels(2 + rnd.nextInt(0, 3));
|
||||
_wheelsSeed = rnd.nextInt(0, 2);
|
||||
}
|
||||
|
||||
public DrawingMonorail(int speed, float weight, Color bodyColor)
|
||||
{
|
||||
this(100, 40);
|
||||
|
||||
_entityMonorail = new EntityMonorail(speed, weight, bodyColor);
|
||||
_wheels = new DrawingWheels();
|
||||
Random rnd = new Random();
|
||||
_wheels.SetCountWheels(2 + rnd.nextInt(0, 3));
|
||||
_wheelsSeed = rnd.nextInt(0, 2);
|
||||
}
|
||||
|
||||
public DrawingMonorail(EntityMonorail entityMonorail, Integer drawningMonorailWidth, Integer drawningMonorailHeight, IDrawingWheels wheels)
|
||||
{
|
||||
this(drawningMonorailWidth, drawningMonorailHeight);
|
||||
|
||||
_wheels = new DrawingWheels();
|
||||
_wheels.SetCountWheels(wheels.getCountWheels());
|
||||
|
||||
_entityMonorail = new EntityMonorail(entityMonorail.getSpeed(), entityMonorail.getWeight(), entityMonorail.getBodyColor());
|
||||
_wheels = new DrawingWheels();
|
||||
Random rnd = new Random();
|
||||
_wheels.SetCountWheels(2 + rnd.nextInt(0, 3));
|
||||
_wheelsSeed = rnd.nextInt(0, 2);
|
||||
}
|
||||
|
||||
public DrawingMonorail(EntityMonorail entityMonorail, IDrawingWheels wheels)
|
||||
{
|
||||
this(100, 40);
|
||||
|
||||
_wheels = new DrawingWheels();
|
||||
_wheels.SetCountWheels(wheels.getCountWheels());
|
||||
|
||||
_entityMonorail = new EntityMonorail(entityMonorail.getSpeed(), entityMonorail.getWeight(), entityMonorail.getBodyColor());
|
||||
_wheels = new DrawingWheels();
|
||||
Random rnd = new Random();
|
||||
_wheels.SetCountWheels(2 + rnd.nextInt(0, 3));
|
||||
_wheelsSeed = rnd.nextInt(0, 2);
|
||||
}
|
||||
|
||||
protected DrawingMonorail(Integer drawningMonorailWidth, Integer drawningMonorailHeight) {
|
||||
if(drawningMonorailWidth == null || drawningMonorailHeight == null) return;
|
||||
|
||||
_drawningMonorailWidth = drawningMonorailWidth;
|
||||
_drawningMonorailHeight = drawningMonorailHeight;
|
||||
}
|
||||
|
||||
public boolean SetPictureSize(int width, int height)
|
||||
{
|
||||
if (_drawningMonorailWidth > width || _drawningMonorailHeight > height) return false;
|
||||
|
||||
if (_startPositionX >= 0 && _startPositionY >= 0)
|
||||
{
|
||||
if (_startPositionX + _drawningMonorailWidth > width)
|
||||
{
|
||||
_startPositionX = width - _drawningMonorailWidth;
|
||||
}
|
||||
if (_startPositionY + _drawningMonorailHeight > height)
|
||||
{
|
||||
_startPositionY = height - _drawningMonorailHeight;
|
||||
}
|
||||
}
|
||||
|
||||
_pictureWidth = width;
|
||||
_pictureHeight = height;
|
||||
return true;
|
||||
}
|
||||
|
||||
public void SetPosition(int x, int y)
|
||||
{
|
||||
if (_pictureHeight == null || _pictureWidth == null) return;
|
||||
|
||||
if (x + _drawningMonorailWidth > _pictureWidth || x < 0)
|
||||
{
|
||||
_startPositionX = (int)Math.random() * (_pictureWidth - _drawningMonorailWidth);
|
||||
}
|
||||
else
|
||||
{
|
||||
_startPositionX = x;
|
||||
}
|
||||
|
||||
if (y + _drawningMonorailHeight > _pictureHeight || y < 0)
|
||||
{
|
||||
_startPositionY = (int)Math.random() * (_pictureHeight - _drawningMonorailHeight);
|
||||
}
|
||||
else
|
||||
{
|
||||
_startPositionY = y;
|
||||
}
|
||||
}
|
||||
|
||||
public boolean MoveTransport(DirectionType direction)
|
||||
{
|
||||
if (_pictureWidth == null || _pictureHeight == null) return false;
|
||||
|
||||
switch (direction)
|
||||
{
|
||||
case Right:
|
||||
if (_startPositionX + _drawningMonorailWidth + _entityMonorail.Step < _pictureWidth)
|
||||
{
|
||||
_startPositionX += _entityMonorail.Step;
|
||||
}
|
||||
return true;
|
||||
case Left:
|
||||
if (_startPositionX - _entityMonorail.Step >= 0)
|
||||
{
|
||||
_startPositionX -= _entityMonorail.Step;
|
||||
}
|
||||
return true;
|
||||
case Up:
|
||||
if (_startPositionY - _entityMonorail.Step >= 0)
|
||||
{
|
||||
_startPositionY -= _entityMonorail.Step;
|
||||
}
|
||||
return true;
|
||||
case Down:
|
||||
if (_startPositionY + _drawningMonorailHeight + _entityMonorail.Step < _pictureHeight)
|
||||
{
|
||||
_startPositionY += _entityMonorail.Step;
|
||||
}
|
||||
return true;
|
||||
default:
|
||||
return false;
|
||||
}
|
||||
}
|
||||
|
||||
public boolean CanMove(DirectionType direction) {
|
||||
if (_entityMonorail == null) {
|
||||
return false;
|
||||
}
|
||||
return switch (direction) {
|
||||
case Left -> _startPositionX - _entityMonorail.Step > 0;
|
||||
case Up -> _startPositionY - _entityMonorail.Step > 0;
|
||||
case Right -> _startPositionX + _drawningMonorailWidth + _entityMonorail.Step < _pictureWidth;
|
||||
case Down -> _startPositionY + _drawningMonorailHeight + _entityMonorail.Step < _pictureHeight;
|
||||
};
|
||||
}
|
||||
|
||||
public void DrawTransport(Graphics g)
|
||||
{
|
||||
if (_startPositionX < 0 || _startPositionY < 0 || _pictureHeight== null || _pictureWidth== null) return;
|
||||
|
||||
Graphics2D g2 = (Graphics2D) g;
|
||||
g.setColor(_entityMonorail.getBodyColor());
|
||||
|
||||
//Кузов монорельса
|
||||
g.drawLine(_startPositionX + 8, _startPositionY + 10, _startPositionX + 13, _startPositionY);
|
||||
g.drawLine(_startPositionX + 13, _startPositionY, _startPositionX + 80, _startPositionY);
|
||||
g.drawLine(_startPositionX + 80, _startPositionY, _startPositionX + 80, _startPositionY + 25);
|
||||
g.drawLine(_startPositionX + 80, _startPositionY + 25, _startPositionX + 8, _startPositionY + 25);
|
||||
g.drawLine(_startPositionX + 8, _startPositionY + 25, _startPositionX + 8, _startPositionY + 10);
|
||||
g.drawLine(_startPositionX + 8, _startPositionY + 10, _startPositionX + 30, _startPositionY + 10);
|
||||
g.drawLine(_startPositionX + 39, _startPositionY + 10, _startPositionX + 80, _startPositionY + 10);
|
||||
|
||||
//Дверь
|
||||
g.drawRect(_startPositionX + 30, _startPositionY + 5, 9, 15);
|
||||
|
||||
//Окна
|
||||
g.drawRect(_startPositionX + 14, _startPositionY + 2, 5, 6);
|
||||
g.drawRect(_startPositionX + 21, _startPositionY + 2, 5, 6);
|
||||
g.drawRect(_startPositionX + 70, _startPositionY + 2, 5, 6);
|
||||
|
||||
//Связка монорельса
|
||||
g.setColor(_entityMonorail.getBodyColor());
|
||||
g.fillRect(_startPositionX + 80, _startPositionY + 2, 7, 22);
|
||||
|
||||
//Нижняя часть монорельса
|
||||
int xPoly_LeftSide[] = {_startPositionX, _startPositionX + 8, _startPositionX + 72, _startPositionX + 36, _startPositionX + 36, _startPositionX + 15, _startPositionX + 15, _startPositionX};
|
||||
int yPoly_LeftSide[] = {_startPositionY + 30, _startPositionY + 25, _startPositionY + 25, _startPositionY + 25, _startPositionY + 32, _startPositionY + 32, _startPositionY + 35, _startPositionY + 32};
|
||||
g.fillPolygon(xPoly_LeftSide, yPoly_LeftSide, xPoly_LeftSide.length);
|
||||
|
||||
int xPoly_RightSide[] = {_startPositionX + 86, _startPositionX + 80, _startPositionX + 50, _startPositionX + 50, _startPositionX + 69, _startPositionX + 79, _startPositionX + 86};
|
||||
int yPoly_RightSide[] = {_startPositionY + 30, _startPositionY + 25, _startPositionY + 25, _startPositionY + 32, _startPositionY + 32, _startPositionY + 35, _startPositionY + 32};
|
||||
g.fillPolygon(xPoly_RightSide, yPoly_RightSide, xPoly_RightSide.length);
|
||||
|
||||
g.fillRect(_startPositionX + 8, _startPositionY + 25, 70, 3);
|
||||
|
||||
//Колеса
|
||||
int[] coordinatesX = new int[_wheels.getCountWheels()];
|
||||
coordinatesX[0] = _startPositionX + 10;
|
||||
coordinatesX[1] = _startPositionX + 65;
|
||||
|
||||
if (coordinatesX.length == 4) {
|
||||
coordinatesX[2] = _startPositionX + 25;
|
||||
coordinatesX[3] = _startPositionX + 50;
|
||||
}
|
||||
else if (coordinatesX.length == 3) {
|
||||
Random rnd = new Random();
|
||||
if (_wheelsSeed == 1) {
|
||||
coordinatesX[2] = _startPositionX + 25;
|
||||
}
|
||||
else {
|
||||
coordinatesX[2] = _startPositionX + 50;
|
||||
}
|
||||
}
|
||||
|
||||
_wheels.DrawWheels(g2, coordinatesX, _startPositionY + 30, _entityMonorail.getBodyColor());
|
||||
}
|
||||
}
|
||||
@@ -0,0 +1,28 @@
|
||||
package Scripts.Entities;
|
||||
|
||||
import java.awt.*;
|
||||
import java.util.Random;
|
||||
|
||||
public class EntityModernMonorail extends EntityMonorail {
|
||||
private Color _additionalColor;
|
||||
private boolean _monorailTrack;
|
||||
private boolean _cabin;
|
||||
|
||||
public Color getAdditionalColor() {return _additionalColor;}
|
||||
public boolean getMonorailTrack() {return _monorailTrack;}
|
||||
public boolean getCabin() {return _cabin;}
|
||||
|
||||
public EntityModernMonorail(int speed, float weight, Color bodyColor, Color additionalColor, boolean monorailTrack, boolean cabin){
|
||||
super(speed, weight, bodyColor);
|
||||
Random rnd = new Random();
|
||||
_speed = speed <= 0 ? rnd.nextInt(50)+10 : speed;
|
||||
_weight = weight <= 0 ? rnd.nextInt(100)+500 : weight;
|
||||
_bodyColor = bodyColor;
|
||||
_additionalColor = additionalColor;
|
||||
_monorailTrack = monorailTrack;
|
||||
_cabin = cabin;
|
||||
|
||||
Step = _speed * 100/ (int)_weight;
|
||||
}
|
||||
}
|
||||
|
||||
30
ProjectMonorail/src/Scripts/Entities/EntityMonorail.java
Normal file
30
ProjectMonorail/src/Scripts/Entities/EntityMonorail.java
Normal file
@@ -0,0 +1,30 @@
|
||||
package Scripts.Entities;
|
||||
|
||||
import java.awt.*;
|
||||
import java.util.Random;
|
||||
|
||||
public class EntityMonorail {
|
||||
public float Step;
|
||||
protected int _speed;
|
||||
protected float _weight;
|
||||
protected Color _bodyColor;
|
||||
|
||||
public int getSpeed() {
|
||||
return _speed;
|
||||
}
|
||||
public float getWeight() {
|
||||
return _weight;
|
||||
}
|
||||
public Color getBodyColor() {
|
||||
return _bodyColor;
|
||||
}
|
||||
|
||||
public EntityMonorail(int speed, float weight, Color bodyColor){
|
||||
Random rnd = new Random();
|
||||
_speed = speed <= 0 ? rnd.nextInt(50)+10 : speed;
|
||||
_weight = weight <= 0 ? rnd.nextInt(100)+500 : weight;
|
||||
_bodyColor = bodyColor;
|
||||
|
||||
Step = _speed * 100/ (int)_weight;
|
||||
}
|
||||
}
|
||||
@@ -0,0 +1,32 @@
|
||||
package Scripts.Forms;
|
||||
|
||||
import Scripts.CollectionGenericObjects.AbstractCompany;
|
||||
import Scripts.Drawing.DrawingMonorail;
|
||||
|
||||
import javax.swing.*;
|
||||
|
||||
import java.awt.*;
|
||||
|
||||
public class CanvasFormMonorailCollection<T> extends JComponent {
|
||||
public AbstractCompany company = null;
|
||||
public void SetCollectionToCanvas(AbstractCompany company) {
|
||||
this.company = company;
|
||||
}
|
||||
public CanvasFormMonorailCollection() {};
|
||||
public void paintComponent(Graphics g) {
|
||||
super.paintComponents(g);
|
||||
if (company == null || company._collection == null) {
|
||||
return;
|
||||
}
|
||||
company.DrawBackgound(g);
|
||||
for (int i = 0; i < company._collection.getCount(); i++) {
|
||||
|
||||
Graphics2D g2d = (Graphics2D) g;
|
||||
T obj = (T) company._collection.Get(i);
|
||||
if (obj instanceof DrawingMonorail) {
|
||||
((DrawingMonorail) obj).DrawTransport(g2d);
|
||||
}
|
||||
}
|
||||
super.repaint();
|
||||
}
|
||||
}
|
||||
20
ProjectMonorail/src/Scripts/Forms/CanvasMonorail.java
Normal file
20
ProjectMonorail/src/Scripts/Forms/CanvasMonorail.java
Normal file
@@ -0,0 +1,20 @@
|
||||
package Scripts.Forms;
|
||||
|
||||
import Scripts.Drawing.DrawingMonorail;
|
||||
|
||||
import javax.swing.*;
|
||||
import java.awt.*;
|
||||
|
||||
public class CanvasMonorail extends JComponent {
|
||||
public DrawingMonorail _drawingMonorail;
|
||||
public CanvasMonorail(){}
|
||||
public void paintComponent(Graphics g) {
|
||||
if (_drawingMonorail == null) {
|
||||
return;
|
||||
}
|
||||
super.paintComponents(g);
|
||||
Graphics2D g2d = (Graphics2D) g;
|
||||
_drawingMonorail.DrawTransport(g2d);
|
||||
super.repaint();
|
||||
}
|
||||
}
|
||||
133
ProjectMonorail/src/Scripts/Forms/FormAdditionalCollection.java
Normal file
133
ProjectMonorail/src/Scripts/Forms/FormAdditionalCollection.java
Normal file
@@ -0,0 +1,133 @@
|
||||
package Scripts.Forms;
|
||||
|
||||
import Scripts.CollectionGenericObjects.AbstractCompany;
|
||||
import Scripts.CollectionGenericObjects.AdditionalCollection;
|
||||
import Scripts.Drawing.DrawingModernMonorail;
|
||||
import Scripts.Drawing.DrawingMonorail;
|
||||
import Scripts.Entities.EntityModernMonorail;
|
||||
import Scripts.Entities.EntityMonorail;
|
||||
import Scripts.Wheels.DrawingWheels;
|
||||
|
||||
import javax.swing.*;
|
||||
import java.awt.*;
|
||||
import java.awt.event.ActionEvent;
|
||||
import java.awt.event.ActionListener;
|
||||
import java.util.Random;
|
||||
|
||||
public class FormAdditionalCollection extends JFrame {
|
||||
public DrawingMonorail _drawingMonorail = null;
|
||||
private DrawingMonorail _copyMonorail = null;
|
||||
private AbstractCompany _company = null;
|
||||
private CanvasMonorail _canvasMonorail = new CanvasMonorail();
|
||||
private AdditionalCollection<EntityMonorail, DrawingWheels> _additionalCollection = null;
|
||||
private Random random = new Random();
|
||||
private JButton buttonGenerate = new JButton("Создать");
|
||||
private JButton buttonGoToCollection = new JButton("В коллекцию");
|
||||
private JList<String> listEntity = new JList<String>();
|
||||
private JList<String> listWheels = new JList<String>();
|
||||
public FormAdditionalCollection() {
|
||||
setTitle("Случайные монорельсы");
|
||||
setMinimumSize(new Dimension(970,310));
|
||||
_additionalCollection = new AdditionalCollection<EntityMonorail, DrawingWheels>(3,(Class)EntityMonorail.class,(Class)DrawingWheels.class);
|
||||
AddEntities();
|
||||
AddWheels();
|
||||
buttonGoToCollection.addActionListener(new ActionListener() {
|
||||
@Override
|
||||
public void actionPerformed(ActionEvent e) {
|
||||
if(_drawingMonorail !=null){
|
||||
_company._collection.Insert(_copyMonorail);
|
||||
FormMonorailCollection.canvasShow();
|
||||
dispose();
|
||||
}
|
||||
}
|
||||
});
|
||||
|
||||
buttonGenerate.addActionListener(new ActionListener() {
|
||||
@Override
|
||||
public void actionPerformed(ActionEvent e) {
|
||||
_drawingMonorail = _additionalCollection.CreateAdditionalCollectionMonorail();
|
||||
_drawingMonorail.SetPictureSize(getWidth(), getHeight());
|
||||
_drawingMonorail.SetPosition(360,30);
|
||||
_canvasMonorail._drawingMonorail = _drawingMonorail;
|
||||
_canvasMonorail.repaint();
|
||||
if (_drawingMonorail instanceof DrawingModernMonorail)
|
||||
_copyMonorail = new DrawingModernMonorail((EntityModernMonorail) _drawingMonorail.getMonorail(), _drawingMonorail.getWheels());
|
||||
else
|
||||
_copyMonorail = new DrawingMonorail(_drawingMonorail.getMonorail(), _drawingMonorail.getWheels());
|
||||
}
|
||||
});
|
||||
|
||||
buttonGoToCollection.setBounds(830,200,120,60);
|
||||
buttonGenerate.setBounds(830, 130, 120, 60);
|
||||
listEntity.setBounds(10,200,400,60);
|
||||
listWheels.setBounds(420,200,400,60);
|
||||
add(buttonGenerate);
|
||||
add(buttonGoToCollection);
|
||||
add(listEntity);
|
||||
add(listWheels);
|
||||
add(_canvasMonorail);
|
||||
setVisible(true);
|
||||
}
|
||||
private String ToString(EntityMonorail entity) {
|
||||
String str = "";
|
||||
if (entity instanceof EntityModernMonorail) str += "EntityModernMonorail ";
|
||||
else str += "EntityMonorail ";
|
||||
str += entity.getBodyColor().toString();
|
||||
return str;
|
||||
}
|
||||
private String ToString(DrawingWheels wheels) {
|
||||
if (wheels == null || wheels.getCountWheels() == 0)
|
||||
return "Не имеет колес";
|
||||
String str = ""+wheels.getCountWheels();
|
||||
str+=" колес";
|
||||
|
||||
return str;
|
||||
}
|
||||
public void AddEntities() {
|
||||
for (int i = 0; i < _additionalCollection.CountEntities; i++) {
|
||||
random = new Random();
|
||||
int speed = random.nextInt(100, 300);
|
||||
float weight = random.nextInt(1000, 3000);
|
||||
Color bodycolor = new Color(random.nextInt(256), random.nextInt(256), random.nextInt(256));
|
||||
EntityMonorail entityMonorail;
|
||||
if (random.nextBoolean()) {
|
||||
entityMonorail = new EntityMonorail(speed, weight, bodycolor);
|
||||
}
|
||||
else {
|
||||
Color additionalcolor = new Color(random.nextInt(256), random.nextInt(256), random.nextInt(256));
|
||||
boolean monorailTrack = random.nextBoolean();
|
||||
boolean cabin = random.nextBoolean();
|
||||
entityMonorail = new EntityModernMonorail(speed, weight, bodycolor, additionalcolor, monorailTrack, cabin);
|
||||
}
|
||||
_additionalCollection.Insert(entityMonorail);
|
||||
}
|
||||
}
|
||||
public void AddWheels() {
|
||||
for (int i = 0; i < _additionalCollection.CountWheels; i++) {
|
||||
random = new Random();
|
||||
EntityMonorail entity = _additionalCollection._collectionEntity[i];
|
||||
DrawingWheels drawingWheels = null;
|
||||
drawingWheels = new DrawingWheels();
|
||||
drawingWheels.SetCountWheels((int) ((Math.random() * 3) + 1) * 2);
|
||||
|
||||
if(drawingWheels!=null){
|
||||
_additionalCollection.Insert(drawingWheels);
|
||||
}
|
||||
}
|
||||
}
|
||||
void setCompany(AbstractCompany company) {
|
||||
this._company = company;
|
||||
String[] data1 = new String[_additionalCollection.CountEntities];
|
||||
for (int i = 0; i < _additionalCollection.CountEntities; i++) {
|
||||
EntityMonorail entity = _additionalCollection._collectionEntity[i];
|
||||
data1[i] = ToString(entity);
|
||||
}
|
||||
String[] data2 = new String[_additionalCollection.CountWheels];
|
||||
for (int i = 0; i < _additionalCollection.CountWheels; i++) {
|
||||
DrawingWheels wheels = _additionalCollection._collectionWheels[i];
|
||||
data2[i] = ToString(wheels);
|
||||
}
|
||||
listEntity.setListData(data1);
|
||||
listWheels.setListData(data2);
|
||||
}
|
||||
}
|
||||
174
ProjectMonorail/src/Scripts/Forms/FormModernMonorail.java
Normal file
174
ProjectMonorail/src/Scripts/Forms/FormModernMonorail.java
Normal file
@@ -0,0 +1,174 @@
|
||||
package Scripts.Forms;
|
||||
|
||||
import Scripts.Drawing.DrawingField;
|
||||
import Scripts.Drawing.DrawingMonorail;
|
||||
import Scripts.MovementStratagy.*;
|
||||
|
||||
import javax.swing.*;
|
||||
import java.awt.*;
|
||||
import java.awt.event.ComponentAdapter;
|
||||
import java.awt.event.ComponentEvent;
|
||||
public class FormModernMonorail extends JFrame{
|
||||
private int Width;
|
||||
private int Height;
|
||||
|
||||
private JPanel BottomPanel = new JPanel();
|
||||
private JPanel CreatePanel = new JPanel();
|
||||
private JPanel BottomAndCreatePanel = new JPanel();
|
||||
private JPanel DimentionPanel = new JPanel();
|
||||
private JPanel UPanel = new JPanel();
|
||||
private JPanel DPanel = new JPanel();
|
||||
private JPanel LRPanel = new JPanel();
|
||||
|
||||
private DrawingField field = new DrawingField(this);
|
||||
|
||||
private Icon _iconUp = new ImageIcon("Resource\\Arrows\\ArrowUp.png");
|
||||
private Icon _iconDown = new ImageIcon("Resource\\Arrows\\ArrowDown.png");
|
||||
private Icon _iconRight = new ImageIcon("Resource\\Arrows\\ArrowRight.png");
|
||||
private Icon _iconLeft = new ImageIcon("Resource\\Arrows\\ArrowLeft.png");
|
||||
|
||||
private JButton ButtonUp=new JButton(_iconUp);
|
||||
private JButton ButtonDown=new JButton(_iconDown);
|
||||
private JButton ButtonRight=new JButton(_iconRight);
|
||||
private JButton ButtonLeft=new JButton(_iconLeft);
|
||||
|
||||
private JPanel StrategyPanel = new JPanel();
|
||||
private AbstractStrategy _abstractStrategy;
|
||||
private String[] _strategyItems = {
|
||||
"ToCenter",
|
||||
"ToBorder"
|
||||
};
|
||||
private JComboBox ComboBoxStrategy = new JComboBox(_strategyItems);
|
||||
private JButton ButtonStep = new JButton("Step");
|
||||
|
||||
public FormModernMonorail(){
|
||||
super("Modern Monorail");
|
||||
setSize(600,480);
|
||||
Width=getWidth();
|
||||
Height=getHeight();
|
||||
ShowWindow();
|
||||
RefreshWindow();
|
||||
setVisible(true);
|
||||
}
|
||||
|
||||
public void ShowWindow(){
|
||||
|
||||
Dimension dimen=new Dimension(30,30);
|
||||
|
||||
ButtonUp.setPreferredSize(dimen);
|
||||
ButtonUp.addActionListener(e->{
|
||||
field.UpButtonAction();
|
||||
repaint();
|
||||
});
|
||||
|
||||
ButtonDown.setPreferredSize(dimen);
|
||||
ButtonDown.addActionListener(e->{
|
||||
field.DownButtonAction();
|
||||
repaint();
|
||||
});
|
||||
|
||||
ButtonRight.setPreferredSize(dimen);
|
||||
ButtonRight.addActionListener(e->{
|
||||
field.RightButtonAction();
|
||||
repaint();
|
||||
});
|
||||
|
||||
ButtonLeft.setPreferredSize(dimen);
|
||||
ButtonLeft.addActionListener(e->{
|
||||
field.LeftButtonAction();
|
||||
repaint();
|
||||
});
|
||||
|
||||
LRPanel.setLayout(new FlowLayout(FlowLayout.CENTER,50,0));
|
||||
LRPanel.setBackground(new Color(0,0,0,0));
|
||||
LRPanel.add(ButtonLeft);
|
||||
LRPanel.add(ButtonRight);
|
||||
|
||||
UPanel.setLayout(new FlowLayout());
|
||||
UPanel.setBackground(new Color(0,0,0,0));
|
||||
UPanel.add(ButtonUp);
|
||||
|
||||
DPanel.setLayout(new FlowLayout());
|
||||
DPanel.setBackground(new Color(0,0,0,0));
|
||||
DPanel.add(ButtonDown);
|
||||
|
||||
DimentionPanel.setLayout(new BoxLayout(DimentionPanel,BoxLayout.Y_AXIS));
|
||||
DimentionPanel.setBackground(new Color(0,0,0,0));
|
||||
DimentionPanel.add(UPanel);
|
||||
DimentionPanel.add(LRPanel);
|
||||
DimentionPanel.add(DPanel);
|
||||
add(DimentionPanel);
|
||||
|
||||
CreatePanel.setLayout(new FlowLayout(FlowLayout.RIGHT,0,0));
|
||||
CreatePanel.setBackground(new Color(0,0,0,0));
|
||||
|
||||
StrategyPanel.setLayout(new FlowLayout(FlowLayout.RIGHT,0,0));
|
||||
StrategyPanel.setBackground(new Color(0,0,0,0));
|
||||
StrategyPanel.add(ButtonStep);
|
||||
StrategyPanel.add(ComboBoxStrategy);
|
||||
|
||||
ButtonStep.addActionListener(e -> {
|
||||
if (field.getDrawingMonorail() == null) {
|
||||
return;
|
||||
}
|
||||
if (ComboBoxStrategy.isEnabled()) {
|
||||
_abstractStrategy = switch (ComboBoxStrategy.getSelectedIndex()) {
|
||||
case 0 -> new MoveToCenter();
|
||||
case 1 -> new MoveToBorder();
|
||||
default -> null;
|
||||
};
|
||||
if (_abstractStrategy == null)
|
||||
{
|
||||
return;
|
||||
}
|
||||
_abstractStrategy.SetData(new MoveableMonorail(field.getDrawingMonorail()), Width, Height);
|
||||
}
|
||||
if (_abstractStrategy == null)
|
||||
{
|
||||
return;
|
||||
}
|
||||
ComboBoxStrategy.setEnabled(false);
|
||||
_abstractStrategy.MakeStep();
|
||||
repaint();
|
||||
if (_abstractStrategy.GetStatus() == StrategyStatus.Finish)
|
||||
{
|
||||
ComboBoxStrategy.setEnabled(true);
|
||||
_abstractStrategy = null;
|
||||
}
|
||||
});
|
||||
|
||||
BottomPanel.setLayout(new FlowLayout());
|
||||
BottomPanel.setBackground(new Color(0,0,0,0));
|
||||
|
||||
BottomAndCreatePanel.setLayout(new BoxLayout(BottomAndCreatePanel,BoxLayout.Y_AXIS));
|
||||
BottomAndCreatePanel.setBackground(new Color(0,0,0,0));
|
||||
BottomAndCreatePanel.add(CreatePanel);
|
||||
BottomAndCreatePanel.add(StrategyPanel);
|
||||
BottomAndCreatePanel.add(BottomPanel);
|
||||
|
||||
add(BottomAndCreatePanel);
|
||||
add(field);
|
||||
|
||||
addComponentListener(new ComponentAdapter() {
|
||||
@Override
|
||||
public void componentResized(ComponentEvent e) {
|
||||
super.componentResized(e);
|
||||
Width=getWidth();
|
||||
Height=getHeight();
|
||||
|
||||
field.ResizeField();
|
||||
repaint();
|
||||
RefreshWindow();
|
||||
}
|
||||
});
|
||||
}
|
||||
public void RefreshWindow(){
|
||||
field.setBounds(0,0,Width,Height);
|
||||
BottomAndCreatePanel.setBounds(-220,Height-110,Width,80);
|
||||
DimentionPanel.setBounds(Width-170,Height-170,190,140);
|
||||
}
|
||||
|
||||
public void Init(DrawingMonorail drawingMonorail) {
|
||||
field.setDrawingMonorail(drawingMonorail);
|
||||
}
|
||||
}
|
||||
211
ProjectMonorail/src/Scripts/Forms/FormMonorailCollection.java
Normal file
211
ProjectMonorail/src/Scripts/Forms/FormMonorailCollection.java
Normal file
@@ -0,0 +1,211 @@
|
||||
package Scripts.Forms;
|
||||
|
||||
import Scripts.CollectionGenericObjects.AbstractCompany;
|
||||
import Scripts.CollectionGenericObjects.DepotSharingService;
|
||||
import Scripts.CollectionGenericObjects.MassiveGenericObjects;
|
||||
import Scripts.Drawing.DrawingModernMonorail;
|
||||
import Scripts.Drawing.DrawingMonorail;
|
||||
|
||||
import javax.swing.*;
|
||||
import java.awt.*;
|
||||
import java.awt.event.*;
|
||||
import java.util.Random;
|
||||
|
||||
import static java.lang.Integer.parseInt;
|
||||
|
||||
public class FormMonorailCollection extends JFrame{
|
||||
private String title;
|
||||
private Dimension dimension;
|
||||
public static CanvasFormMonorailCollection<DrawingMonorail> _canvasMonorail = new CanvasFormMonorailCollection<DrawingMonorail>();
|
||||
private static AbstractCompany _company = null;
|
||||
private JButton CreateButton = new JButton("Создать современный монорельс");;
|
||||
private JButton CreateShipButton = new JButton("Создать монорельс");
|
||||
private JButton RemoveButton = new JButton("Удалить");
|
||||
private JButton GoToCheckButton = new JButton("На проверку");
|
||||
private JButton RandomButton = new JButton("Случайные");
|
||||
private JButton RefreshButton = new JButton("Обновить");
|
||||
private JComboBox ComboBoxCollections = new JComboBox(new String[]{"", "Хранилище"});
|
||||
private JFormattedTextField TextField;
|
||||
public FormMonorailCollection(String title, Dimension dimension) {
|
||||
this.title = title;
|
||||
this.dimension = dimension;
|
||||
}
|
||||
public static void canvasShow() {
|
||||
_company.SetPosition();
|
||||
_canvasMonorail.SetCollectionToCanvas(_company);
|
||||
_canvasMonorail.repaint();
|
||||
}
|
||||
private void CreateObject(String typeOfClass){
|
||||
if (_company == null) return;
|
||||
int speed = (int)(Math.random() * 300 + 100);
|
||||
float weight = (float)(Math.random() * 3000 + 1000);
|
||||
Color bodyColor = getColor();
|
||||
DrawingMonorail drawingMonorail;
|
||||
switch (typeOfClass) {
|
||||
case "DrawingMonorail":
|
||||
drawingMonorail = new DrawingMonorail(speed, weight, bodyColor);
|
||||
break;
|
||||
case "DrawingModernMonorail":
|
||||
Color additionalColor = getColor();
|
||||
boolean monorailTrack = new Random().nextBoolean();
|
||||
boolean cabin = true;
|
||||
drawingMonorail = new DrawingModernMonorail(speed, weight, bodyColor, additionalColor, monorailTrack, cabin);
|
||||
break;
|
||||
default: return;
|
||||
}
|
||||
if (_company._collection.Insert(drawingMonorail, 0) != -1) {
|
||||
JOptionPane.showMessageDialog(null, "Объект добавлен");
|
||||
canvasShow();
|
||||
}
|
||||
else {
|
||||
JOptionPane.showMessageDialog(null, "Объект не удалось добавить");
|
||||
}
|
||||
}
|
||||
public Color getColor() {
|
||||
Color initializator = new Color((int)(Math.random() * 255 + 0),(int)(Math.random() * 255 + 0),(int)(Math.random() * 255 + 0));
|
||||
Color color = JColorChooser.showDialog(this, "Цвет", initializator);
|
||||
return color;
|
||||
}
|
||||
public void Init() {
|
||||
setTitle(title);
|
||||
setMinimumSize(dimension);
|
||||
setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
|
||||
|
||||
TextField = new JFormattedTextField();
|
||||
|
||||
ComboBoxCollections.addActionListener(new ActionListener() {
|
||||
@Override
|
||||
public void actionPerformed(ActionEvent e) {
|
||||
switch (ComboBoxCollections.getSelectedItem().toString()) {
|
||||
case "Хранилище":
|
||||
_company = new DepotSharingService(getWidth()-200, getHeight()-110, new MassiveGenericObjects<DrawingMonorail>());
|
||||
break;
|
||||
}
|
||||
}
|
||||
});
|
||||
|
||||
CreateShipButton.addActionListener(new ActionListener() {
|
||||
@Override
|
||||
public void actionPerformed(ActionEvent e) {
|
||||
CreateObject("DrawingMonorail");
|
||||
}
|
||||
});
|
||||
CreateButton.addActionListener(new ActionListener() {
|
||||
@Override
|
||||
public void actionPerformed(ActionEvent e) {
|
||||
CreateObject("DrawingModernMonorail");
|
||||
}
|
||||
});
|
||||
|
||||
RemoveButton.addActionListener(new ActionListener() {
|
||||
@Override
|
||||
public void actionPerformed(ActionEvent e) {
|
||||
if (_company == null || TextField.getText() == null) {
|
||||
return;
|
||||
}
|
||||
int pos = parseInt(TextField.getText());
|
||||
int resultConfirmDialog = JOptionPane.showConfirmDialog(null, "Удалить", "Удаление", JOptionPane.YES_NO_OPTION);
|
||||
if (resultConfirmDialog == JOptionPane.NO_OPTION) return;
|
||||
if (_company._collection.Remove(pos) != null) {
|
||||
System.out.println(pos);
|
||||
JOptionPane.showMessageDialog(null, "Объект удален");
|
||||
canvasShow();
|
||||
}
|
||||
else {
|
||||
JOptionPane.showMessageDialog(null, "Не удалось удалить объект");
|
||||
}
|
||||
}
|
||||
});
|
||||
|
||||
GoToCheckButton.addActionListener(new ActionListener() {
|
||||
@Override
|
||||
public void actionPerformed(ActionEvent e) {
|
||||
if (_company == null)
|
||||
{
|
||||
return;
|
||||
}
|
||||
DrawingMonorail drawingMonorail = null;
|
||||
int counter = 100;
|
||||
while (drawingMonorail == null)
|
||||
{
|
||||
drawingMonorail = _company.GetRandomObject();
|
||||
counter--;
|
||||
if (counter <= 0)
|
||||
{
|
||||
break;
|
||||
}
|
||||
}
|
||||
if (drawingMonorail == null)
|
||||
{
|
||||
return;
|
||||
}
|
||||
FormModernMonorail form = new FormModernMonorail();
|
||||
form.addWindowListener(new WindowAdapter() {
|
||||
@Override
|
||||
public void windowClosing(WindowEvent e) {
|
||||
canvasShow();
|
||||
super.windowClosing(e);
|
||||
}
|
||||
});
|
||||
form.Init(drawingMonorail);
|
||||
}
|
||||
});
|
||||
|
||||
RefreshButton.addActionListener(new ActionListener() {
|
||||
@Override
|
||||
public void actionPerformed(ActionEvent e) {
|
||||
if (_company == null)
|
||||
{
|
||||
return;
|
||||
}
|
||||
canvasShow();
|
||||
}
|
||||
});
|
||||
RandomButton.addActionListener(new ActionListener() {
|
||||
@Override
|
||||
public void actionPerformed(ActionEvent e) {
|
||||
if(_company==null){
|
||||
return;
|
||||
}
|
||||
FormAdditionalCollection form = new FormAdditionalCollection();
|
||||
form.setCompany(_company);
|
||||
}
|
||||
});
|
||||
_canvasMonorail.setBounds(0, 0, getWidth()-200, getHeight());
|
||||
ComboBoxCollections.setBounds(getWidth()-190, 10, 150, 20);
|
||||
CreateShipButton.setBounds(getWidth()-190, 60, 150, 30);
|
||||
CreateButton.setBounds(getWidth()-190, 100, 150, 30);
|
||||
RandomButton.setBounds(getWidth()-190, 140, 150, 30);
|
||||
TextField.setBounds(getWidth()-190,200,150,30);
|
||||
RemoveButton.setBounds(getWidth()-190, 240, 150, 30);
|
||||
GoToCheckButton.setBounds(getWidth()-190, 280, 150, 30);
|
||||
RefreshButton.setBounds(getWidth()-190, getHeight()-90, 150, 30);
|
||||
|
||||
setSize(dimension.width,dimension.height);
|
||||
setLayout(null);
|
||||
add(_canvasMonorail);
|
||||
add(ComboBoxCollections);
|
||||
add(CreateShipButton);
|
||||
add(CreateButton);
|
||||
add(TextField);
|
||||
add(RemoveButton);
|
||||
add(GoToCheckButton);
|
||||
add(RandomButton);
|
||||
add(RefreshButton);
|
||||
setVisible(true);
|
||||
|
||||
addComponentListener(new ComponentAdapter() {
|
||||
public void componentResized(ComponentEvent e) {
|
||||
_canvasMonorail.setBounds(0, 0, getWidth()-200, getHeight()-70);
|
||||
ComboBoxCollections.setBounds(getWidth()-190, 10, 150, 20);
|
||||
CreateShipButton.setBounds(getWidth()-190, 60, 150, 30);
|
||||
CreateButton.setBounds(getWidth()-190, 100, 150, 30);
|
||||
TextField.setBounds(getWidth()-190,200,150,30);
|
||||
RemoveButton.setBounds(getWidth()-190, 240, 150, 30);
|
||||
GoToCheckButton.setBounds(getWidth()-190, 280, 150, 30);
|
||||
RandomButton.setBounds(getWidth()-190, 140, 150, 30);
|
||||
RefreshButton.setBounds(getWidth()-190, getHeight()-90, 150, 30);
|
||||
}
|
||||
});
|
||||
}
|
||||
}
|
||||
@@ -0,0 +1,93 @@
|
||||
package Scripts.MovementStratagy;
|
||||
|
||||
import Scripts.Drawing.DirectionType;
|
||||
|
||||
public abstract class AbstractStrategy {
|
||||
private IMoveableObject moveableObject;
|
||||
|
||||
private StrategyStatus state = StrategyStatus.NotInit;
|
||||
|
||||
private int fieldWidth;
|
||||
|
||||
protected int GetFieldWidth() {
|
||||
return fieldWidth;
|
||||
}
|
||||
|
||||
private int fieldHeight;
|
||||
|
||||
protected int GetFieldHeight() {
|
||||
return fieldHeight;
|
||||
}
|
||||
|
||||
public StrategyStatus GetStatus() {
|
||||
return state;
|
||||
}
|
||||
|
||||
public void SetData(IMoveableObject moveableObject, int width, int height) {
|
||||
if (moveableObject == null) {
|
||||
state = StrategyStatus.NotInit;
|
||||
return;
|
||||
}
|
||||
state = StrategyStatus.InProgress;
|
||||
this.moveableObject = moveableObject;
|
||||
fieldWidth = width;
|
||||
fieldHeight = height;
|
||||
}
|
||||
|
||||
public void MakeStep() {
|
||||
if (state != StrategyStatus.InProgress) {
|
||||
return;
|
||||
}
|
||||
if (isTargetDestination()) {
|
||||
state = StrategyStatus.Finish;
|
||||
return;
|
||||
}
|
||||
MoveToTarget();
|
||||
}
|
||||
|
||||
protected boolean MoveLeft() {
|
||||
return MoveTo(DirectionType.Left);
|
||||
}
|
||||
|
||||
protected boolean MoveRight() {
|
||||
return MoveTo(DirectionType.Right);
|
||||
}
|
||||
|
||||
protected boolean MoveUp() { return MoveTo(DirectionType.Up); }
|
||||
|
||||
protected boolean MoveDown() {
|
||||
return MoveTo(DirectionType.Down);
|
||||
}
|
||||
|
||||
protected ObjectParameters GetObjectParameters() {
|
||||
if (moveableObject == null) {
|
||||
return null;
|
||||
}
|
||||
return moveableObject.GetObjectPosition();
|
||||
}
|
||||
|
||||
protected Integer GetStep() {
|
||||
if (state != StrategyStatus.InProgress) {
|
||||
return null;
|
||||
}
|
||||
return moveableObject.GetStep();
|
||||
}
|
||||
|
||||
protected abstract void MoveToTarget();
|
||||
|
||||
protected abstract boolean isTargetDestination();
|
||||
|
||||
private boolean MoveTo(DirectionType direction) {
|
||||
if (state != StrategyStatus.InProgress) {
|
||||
return false;
|
||||
}
|
||||
if (moveableObject == null) {
|
||||
return false;
|
||||
}
|
||||
if (moveableObject.CanMoveObject(direction)) {
|
||||
moveableObject.MoveObject(direction);
|
||||
return true;
|
||||
}
|
||||
return false;
|
||||
}
|
||||
}
|
||||
@@ -0,0 +1,13 @@
|
||||
package Scripts.MovementStratagy;
|
||||
|
||||
import Scripts.Drawing.DirectionType;
|
||||
|
||||
public interface IMoveableObject{
|
||||
ObjectParameters GetObjectPosition();
|
||||
|
||||
int GetStep();
|
||||
|
||||
boolean CanMoveObject(DirectionType direction);
|
||||
|
||||
void MoveObject(DirectionType direction);
|
||||
}
|
||||
@@ -0,0 +1,35 @@
|
||||
package Scripts.MovementStratagy;
|
||||
|
||||
public class MoveToBorder extends AbstractStrategy {
|
||||
@Override
|
||||
protected boolean isTargetDestination() {
|
||||
var objParams = GetObjectParameters();
|
||||
if (objParams == null) {
|
||||
return false;
|
||||
}
|
||||
return objParams.RightBorder() <= GetFieldWidth() &&
|
||||
objParams.RightBorder() + GetStep() >= GetFieldWidth() &&
|
||||
objParams.DownBorder() <= GetFieldHeight() &&
|
||||
objParams.DownBorder() + GetStep() >= GetFieldHeight();
|
||||
}
|
||||
|
||||
@Override
|
||||
protected void MoveToTarget() {
|
||||
var objParams = GetObjectParameters();
|
||||
if (objParams == null) {
|
||||
return;
|
||||
}
|
||||
var diffX = objParams.ObjectMiddleHorizontal() - GetFieldWidth();
|
||||
if (Math.abs(diffX) > GetStep()) {
|
||||
if (diffX < 0) {
|
||||
MoveRight();
|
||||
}
|
||||
}
|
||||
var diffY = objParams.ObjectMiddleVertical() - GetFieldHeight();
|
||||
if (Math.abs(diffY) > GetStep()) {
|
||||
if (diffY < 0) {
|
||||
MoveDown();
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
@@ -0,0 +1,39 @@
|
||||
package Scripts.MovementStratagy;
|
||||
|
||||
public class MoveToCenter extends AbstractStrategy {
|
||||
@Override
|
||||
protected boolean isTargetDestination() {
|
||||
var objParams = GetObjectParameters();
|
||||
if (objParams == null) {
|
||||
return false;
|
||||
}
|
||||
return objParams.ObjectMiddleHorizontal() <= GetFieldWidth() / 2 &&
|
||||
objParams.ObjectMiddleHorizontal() + GetStep() >= GetFieldWidth() / 2 &&
|
||||
objParams.ObjectMiddleVertical() <= GetFieldHeight() / 2 &&
|
||||
objParams.ObjectMiddleVertical() + GetStep() >= GetFieldHeight() / 2;
|
||||
}
|
||||
|
||||
@Override
|
||||
protected void MoveToTarget() {
|
||||
var objParams = GetObjectParameters();
|
||||
if (objParams == null) {
|
||||
return;
|
||||
}
|
||||
var diffX = objParams.ObjectMiddleHorizontal() - GetFieldWidth() / 2;
|
||||
if (Math.abs(diffX) > GetStep()) {
|
||||
if (diffX > 0) {
|
||||
MoveLeft();
|
||||
} else {
|
||||
MoveRight();
|
||||
}
|
||||
}
|
||||
var diffY = objParams.ObjectMiddleVertical() - GetFieldHeight() / 2;
|
||||
if (Math.abs(diffY) > GetStep()) {
|
||||
if (diffY > 0) {
|
||||
MoveUp();
|
||||
} else {
|
||||
MoveDown();
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
@@ -0,0 +1,41 @@
|
||||
package Scripts.MovementStratagy;
|
||||
|
||||
import Scripts.Drawing.DirectionType;
|
||||
import Scripts.Drawing.DrawingMonorail;
|
||||
|
||||
public class MoveableMonorail implements IMoveableObject {
|
||||
private DrawingMonorail _drawingMonorail = null;
|
||||
public MoveableMonorail(DrawingMonorail drawingMonorail)
|
||||
{
|
||||
_drawingMonorail = drawingMonorail;
|
||||
}
|
||||
|
||||
@Override
|
||||
public ObjectParameters GetObjectPosition() {
|
||||
if (_drawingMonorail == null || _drawingMonorail.getMonorail() == null) {
|
||||
return null;
|
||||
}
|
||||
return new ObjectParameters(_drawingMonorail.GetPositionX(), _drawingMonorail.GetPositionY(),
|
||||
_drawingMonorail.GetWidth(), _drawingMonorail.GetHeight());
|
||||
}
|
||||
|
||||
@Override
|
||||
public int GetStep() {
|
||||
if (_drawingMonorail != null && _drawingMonorail.getMonorail()!=null)
|
||||
return (int)(_drawingMonorail.getMonorail().Step);
|
||||
return 0;
|
||||
}
|
||||
|
||||
@Override
|
||||
public boolean CanMoveObject(DirectionType direction) {
|
||||
if (_drawingMonorail != null)
|
||||
return _drawingMonorail.CanMove(direction);
|
||||
return false;
|
||||
}
|
||||
|
||||
@Override
|
||||
public void MoveObject(DirectionType direction) {
|
||||
if (_drawingMonorail != null)
|
||||
_drawingMonorail.MoveTransport(direction);
|
||||
}
|
||||
}
|
||||
@@ -0,0 +1,34 @@
|
||||
package Scripts.MovementStratagy;
|
||||
|
||||
public class ObjectParameters {
|
||||
private final int _x;
|
||||
|
||||
private final int _y;
|
||||
|
||||
private final int _width;
|
||||
|
||||
private final int _height;
|
||||
|
||||
public int RightBorder() {
|
||||
return _x + _width;
|
||||
}
|
||||
|
||||
public int DownBorder() {
|
||||
return _y + _height;
|
||||
}
|
||||
|
||||
public int ObjectMiddleHorizontal() {
|
||||
return _x + _width / 2;
|
||||
}
|
||||
|
||||
public int ObjectMiddleVertical() {
|
||||
return _y + _height / 2;
|
||||
}
|
||||
|
||||
public ObjectParameters(int x, int y, int width, int height) {
|
||||
_x = x;
|
||||
_y = y;
|
||||
_width = width;
|
||||
_height = height;
|
||||
}
|
||||
}
|
||||
@@ -0,0 +1,7 @@
|
||||
package Scripts.MovementStratagy;
|
||||
|
||||
public enum StrategyStatus {
|
||||
NotInit,
|
||||
InProgress,
|
||||
Finish
|
||||
}
|
||||
12
ProjectMonorail/src/Scripts/Program.java
Normal file
12
ProjectMonorail/src/Scripts/Program.java
Normal file
@@ -0,0 +1,12 @@
|
||||
package Scripts;
|
||||
|
||||
import Scripts.Forms.FormMonorailCollection;
|
||||
|
||||
import java.awt.*;
|
||||
|
||||
public class Program {
|
||||
public static void main(String[] args){
|
||||
FormMonorailCollection form = new FormMonorailCollection("Монорельс", new Dimension(800, 800));
|
||||
form.Init();
|
||||
}
|
||||
}
|
||||
14
ProjectMonorail/src/Scripts/Wheels/CountWheels.java
Normal file
14
ProjectMonorail/src/Scripts/Wheels/CountWheels.java
Normal file
@@ -0,0 +1,14 @@
|
||||
package Scripts.Wheels;
|
||||
|
||||
public enum CountWheels {
|
||||
Two(2),
|
||||
Three(3),
|
||||
Four(4);
|
||||
private final int Value;
|
||||
CountWheels(int Count){
|
||||
Value=Count;
|
||||
}
|
||||
public int getCountWheels(){
|
||||
return Value;
|
||||
}
|
||||
}
|
||||
13
ProjectMonorail/src/Scripts/Wheels/DrawOrnament.java
Normal file
13
ProjectMonorail/src/Scripts/Wheels/DrawOrnament.java
Normal file
@@ -0,0 +1,13 @@
|
||||
package Scripts.Wheels;
|
||||
|
||||
import java.awt.*;
|
||||
|
||||
public class DrawOrnament implements IOrnament {
|
||||
private int _offsetDraw = 6;
|
||||
|
||||
@Override
|
||||
public void DrawOrnament(int x, int y, int sizeX, int sizeY, Graphics2D g) {
|
||||
g.setColor(Color.CYAN);
|
||||
g.fillRect(x + _offsetDraw, y + _offsetDraw, sizeX - _offsetDraw, sizeY - _offsetDraw);
|
||||
}
|
||||
}
|
||||
16
ProjectMonorail/src/Scripts/Wheels/DrawOrnamentOval.java
Normal file
16
ProjectMonorail/src/Scripts/Wheels/DrawOrnamentOval.java
Normal file
@@ -0,0 +1,16 @@
|
||||
package Scripts.Wheels;
|
||||
|
||||
import java.awt.*;
|
||||
|
||||
public class DrawOrnamentOval implements IOrnament {
|
||||
|
||||
private int _offsetDraw = 4;
|
||||
|
||||
@Override
|
||||
public void DrawOrnament(int x, int y, int sizeX, int sizeY, Graphics2D g) {
|
||||
g.setColor(Color.DARK_GRAY);
|
||||
g.drawRect(x + _offsetDraw, y + _offsetDraw, sizeX - _offsetDraw, sizeY - _offsetDraw);
|
||||
g.setColor(Color.PINK);
|
||||
g.drawOval(x + _offsetDraw, y + _offsetDraw, sizeX - _offsetDraw, sizeY - _offsetDraw);
|
||||
}
|
||||
}
|
||||
18
ProjectMonorail/src/Scripts/Wheels/DrawOrnamentTriangle.java
Normal file
18
ProjectMonorail/src/Scripts/Wheels/DrawOrnamentTriangle.java
Normal file
@@ -0,0 +1,18 @@
|
||||
package Scripts.Wheels;
|
||||
|
||||
import java.awt.*;
|
||||
|
||||
public class DrawOrnamentTriangle implements IOrnament {
|
||||
|
||||
private int _offsetDraw = 4;
|
||||
|
||||
@Override
|
||||
public void DrawOrnament(int x, int y, int sizeX, int sizeY, Graphics2D g) {
|
||||
g.setColor(Color.RED);
|
||||
Polygon elements = new Polygon();
|
||||
elements.addPoint(x + _offsetDraw, y + _offsetDraw * 2);
|
||||
elements.addPoint(x + _offsetDraw * 2, y + _offsetDraw);
|
||||
elements.addPoint(x+ _offsetDraw, y+ _offsetDraw);
|
||||
g.fillPolygon(elements);
|
||||
}
|
||||
}
|
||||
51
ProjectMonorail/src/Scripts/Wheels/DrawingWheels.java
Normal file
51
ProjectMonorail/src/Scripts/Wheels/DrawingWheels.java
Normal file
@@ -0,0 +1,51 @@
|
||||
package Scripts.Wheels;
|
||||
|
||||
import Scripts.Wheels.CountWheels;
|
||||
|
||||
import java.awt.*;
|
||||
import java.util.Random;
|
||||
|
||||
public class DrawingWheels implements IDrawingWheels{
|
||||
private CountWheels _wheels;
|
||||
private IOrnament _ornament;
|
||||
private int _seedOrnament;
|
||||
|
||||
public void SetCountWheels(int Count){
|
||||
for (CountWheels temp: CountWheels.values())
|
||||
if (temp.getCountWheels() == Count){
|
||||
Random rnd = new Random();
|
||||
_seedOrnament = rnd.nextInt(0, 3);
|
||||
_wheels=temp;
|
||||
return;
|
||||
}
|
||||
}
|
||||
|
||||
public int getCountWheels() {
|
||||
if (_wheels != null) return _wheels.getCountWheels();
|
||||
else {
|
||||
SetCountWheels(2);
|
||||
return _wheels.getCountWheels();
|
||||
}
|
||||
}
|
||||
|
||||
public void DrawWheels(Graphics2D g,int startPosX[], int startPosY, Color color) {
|
||||
switch (_seedOrnament) {
|
||||
case 0:
|
||||
_ornament = new DrawOrnament();
|
||||
break;
|
||||
case 1:
|
||||
_ornament = new DrawOrnamentTriangle();
|
||||
break;
|
||||
case 2:
|
||||
_ornament = new DrawOrnamentOval();
|
||||
break;
|
||||
}
|
||||
|
||||
for (int i = 0; i < startPosX.length; i++) {
|
||||
g.setColor(color);
|
||||
g.drawOval(startPosX[i], startPosY, 10, 10);
|
||||
g.fillOval(startPosX[i], startPosY, 10, 10);
|
||||
_ornament.DrawOrnament(startPosX[i], startPosY, 10, 10, g);
|
||||
}
|
||||
}
|
||||
}
|
||||
9
ProjectMonorail/src/Scripts/Wheels/IDrawingWheels.java
Normal file
9
ProjectMonorail/src/Scripts/Wheels/IDrawingWheels.java
Normal file
@@ -0,0 +1,9 @@
|
||||
package Scripts.Wheels;
|
||||
|
||||
import java.awt.*;
|
||||
|
||||
public interface IDrawingWheels {
|
||||
public void SetCountWheels(int Count);
|
||||
public int getCountWheels();
|
||||
public void DrawWheels(Graphics2D g, int startPosX[], int startPosY, Color color);
|
||||
}
|
||||
7
ProjectMonorail/src/Scripts/Wheels/IOrnament.java
Normal file
7
ProjectMonorail/src/Scripts/Wheels/IOrnament.java
Normal file
@@ -0,0 +1,7 @@
|
||||
package Scripts.Wheels;
|
||||
|
||||
import java.awt.*;
|
||||
|
||||
public interface IOrnament {
|
||||
void DrawOrnament(int x, int y, int sizeX, int sizeY, Graphics2D g);
|
||||
}
|
||||
Reference in New Issue
Block a user