20211117
This commit is contained in:
parent
70b5475d83
commit
9b000db778
8
2048/entry/src/main/js/default/app.js
Normal file
8
2048/entry/src/main/js/default/app.js
Normal file
@ -0,0 +1,8 @@
|
|||||||
|
export default {
|
||||||
|
onCreate() {
|
||||||
|
console.info("Application onCreate");
|
||||||
|
},
|
||||||
|
onDestroy() {
|
||||||
|
console.info("Application onDestroy");
|
||||||
|
}
|
||||||
|
};
|
62
2048/entry/src/main/js/default/pages/index/index.css
Normal file
62
2048/entry/src/main/js/default/pages/index/index.css
Normal file
@ -0,0 +1,62 @@
|
|||||||
|
.container{
|
||||||
|
width: 454px;
|
||||||
|
height: 454px;
|
||||||
|
flex-direction: column;
|
||||||
|
justify-content: center;
|
||||||
|
align-items: center;
|
||||||
|
}
|
||||||
|
.score{
|
||||||
|
text-align: center;
|
||||||
|
width: 234px;
|
||||||
|
height: 30px;
|
||||||
|
letter-spacing: 0px;
|
||||||
|
margin-top: 4px;
|
||||||
|
margin-bottom:6px;
|
||||||
|
}
|
||||||
|
.best{
|
||||||
|
text-align: center;
|
||||||
|
width: 234px;
|
||||||
|
height: 30px;
|
||||||
|
letter-spacing: 0px;
|
||||||
|
margin-top: 19px;
|
||||||
|
}
|
||||||
|
.tile-wrap{
|
||||||
|
width: 300px;
|
||||||
|
height: 300px;
|
||||||
|
flex-wrap: wrap;
|
||||||
|
background-color: #FFFFFF;
|
||||||
|
}
|
||||||
|
.tile{
|
||||||
|
width: 70px;
|
||||||
|
height: 70px;
|
||||||
|
margin-top: 4px;
|
||||||
|
margin-left: 4px;
|
||||||
|
justify-content: center;
|
||||||
|
align-items: center;
|
||||||
|
}
|
||||||
|
.btn{
|
||||||
|
width: 135px;
|
||||||
|
height: 45px;
|
||||||
|
background-color: #1F71FF;
|
||||||
|
margin-top: 10px;
|
||||||
|
margin-bottom: 10px;
|
||||||
|
}
|
||||||
|
.text{
|
||||||
|
font-size: 30px;
|
||||||
|
color: #000000;
|
||||||
|
}
|
||||||
|
.stack{
|
||||||
|
width: 300px;
|
||||||
|
height: 300px;
|
||||||
|
}
|
||||||
|
.subcontainer{
|
||||||
|
width: 300px;
|
||||||
|
height: 300px;
|
||||||
|
justify-content: center;
|
||||||
|
align-items: center;
|
||||||
|
background-color: transparent;
|
||||||
|
}
|
||||||
|
.gameover{
|
||||||
|
font-size: 40px;
|
||||||
|
color: #FF7500;
|
||||||
|
}
|
23
2048/entry/src/main/js/default/pages/index/index.hml
Normal file
23
2048/entry/src/main/js/default/pages/index/index.hml
Normal file
@ -0,0 +1,23 @@
|
|||||||
|
<div class="container">
|
||||||
|
<text class="best">
|
||||||
|
Best:{{best}}
|
||||||
|
</text>
|
||||||
|
<text class="score">
|
||||||
|
Score:{{score}}
|
||||||
|
</text>
|
||||||
|
<stack class="stack">
|
||||||
|
<div class="tile-wrap" onswipe="onSwipe">
|
||||||
|
<div class="tile" for="{{tiles}}" style="background-color:#000000">
|
||||||
|
<text class="text" style="color:#FFFFFF">
|
||||||
|
{{$item.text}}
|
||||||
|
</text>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<div class="subcontainer" show="{{isShow}}">
|
||||||
|
<text class="gameover">
|
||||||
|
Gameover!
|
||||||
|
</text>
|
||||||
|
</div>
|
||||||
|
</stack>
|
||||||
|
<input class="btn" type="button" value="Restart!" onclick="onInit" ></input>
|
||||||
|
</div>
|
127
2048/entry/src/main/js/default/pages/index/index.js
Normal file
127
2048/entry/src/main/js/default/pages/index/index.js
Normal file
@ -0,0 +1,127 @@
|
|||||||
|
import brightness from '@system.brightness';
|
||||||
|
let numbers,newNumbers;
|
||||||
|
export default{
|
||||||
|
data:{
|
||||||
|
score:0,
|
||||||
|
best:0,
|
||||||
|
tiles:[],
|
||||||
|
isShow:false,
|
||||||
|
},
|
||||||
|
onInit() {
|
||||||
|
this.isShow=false;
|
||||||
|
this.score=0;
|
||||||
|
this.tiles=[{text:""},{text:""},{text:""},{text:""},{text:""},{text:""},{text:""},{text:""},{text:""},{text:""},{text:""},{text:""},{text:""},{text:""},{text:""},{text:""}];
|
||||||
|
numbers=[0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0];
|
||||||
|
newNumbers=[0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0];
|
||||||
|
this.supplyNumber();
|
||||||
|
this.supplyNumber();
|
||||||
|
this.updateView();
|
||||||
|
brightness.setKeepScreenOn({keepScreenOn: true,});
|
||||||
|
brightness.setMode({mode: 1,});
|
||||||
|
},
|
||||||
|
supplyNumber(){
|
||||||
|
let positions=[];
|
||||||
|
for(let i=0;i<=15;i++){
|
||||||
|
if(!newNumbers[i]) positions.push(i);
|
||||||
|
}
|
||||||
|
let h=Math.floor(Math.random()*positions.length);
|
||||||
|
if (Math.random()<=0.8){
|
||||||
|
newNumbers[positions[h]]=2;
|
||||||
|
}else{
|
||||||
|
newNumbers[positions[h]]=4;
|
||||||
|
}
|
||||||
|
},
|
||||||
|
onSwipe(e) {
|
||||||
|
newNumbers=[0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0];
|
||||||
|
let start=0,differ=0,step=0;
|
||||||
|
switch(e.direction){
|
||||||
|
case 'left':
|
||||||
|
start=0;
|
||||||
|
differ=1;
|
||||||
|
step=4;
|
||||||
|
break;
|
||||||
|
case 'right':
|
||||||
|
start=3;
|
||||||
|
differ=-1;
|
||||||
|
step=4;
|
||||||
|
break;
|
||||||
|
case 'up':
|
||||||
|
start=0;
|
||||||
|
differ=4;
|
||||||
|
step=1;
|
||||||
|
break;
|
||||||
|
case 'down':
|
||||||
|
start=12;
|
||||||
|
differ=-4;
|
||||||
|
step=1;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
let ids;
|
||||||
|
for (let j=0;j<=3;j++){
|
||||||
|
ids=this.getIds(start, differ);
|
||||||
|
let before=null;
|
||||||
|
let noZeros=0;
|
||||||
|
for(let k=0;k<=3;k++){
|
||||||
|
let id=ids[k];
|
||||||
|
let number=numbers[id];
|
||||||
|
if (number!=0){
|
||||||
|
if(number==before){
|
||||||
|
this.score+=number*2;
|
||||||
|
newNumbers[ids[noZeros-1]]*=2;
|
||||||
|
before=null;
|
||||||
|
}else{
|
||||||
|
newNumbers[ids[noZeros]]=number;
|
||||||
|
before=number;
|
||||||
|
noZeros+=1;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
start+=step;
|
||||||
|
}
|
||||||
|
if(this.best>=this.score){
|
||||||
|
this.best=this.best;
|
||||||
|
}else{
|
||||||
|
this.best=this.score;}
|
||||||
|
if(numbers.toString()!=newNumbers.toString()){
|
||||||
|
this.supplyNumber();
|
||||||
|
this.updateView();
|
||||||
|
newNumbers=[0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0];
|
||||||
|
if(this.isGameOver()==true){this.isShow=true;}
|
||||||
|
}
|
||||||
|
},
|
||||||
|
getIds(start, differ){
|
||||||
|
let ids=[];
|
||||||
|
for (let z=4;z>=1;z--){
|
||||||
|
ids.push(start);
|
||||||
|
start+=differ;
|
||||||
|
}
|
||||||
|
return ids;
|
||||||
|
},
|
||||||
|
updateView() {
|
||||||
|
for (let x=0;x<=15;x++) {
|
||||||
|
if (newNumbers[x]!=0){
|
||||||
|
this.tiles[x].text=newNumbers[x].toString();
|
||||||
|
}else{
|
||||||
|
this.tiles[x].text="";
|
||||||
|
}
|
||||||
|
}
|
||||||
|
numbers=newNumbers;
|
||||||
|
},
|
||||||
|
isGameOver(){
|
||||||
|
if(this.isGridsFull()==true && this.isGridsNotMergeable()==true) return true;
|
||||||
|
},
|
||||||
|
isGridsFull(){
|
||||||
|
if(numbers.indexOf(0)==-1){return true;}
|
||||||
|
},
|
||||||
|
isGridsNotMergeable(){
|
||||||
|
for(let l=0;l<=15;l++){
|
||||||
|
if(l<=14){
|
||||||
|
if(numbers[l]==numbers[l+1]&&(l+1)%4!=0) return false;
|
||||||
|
}
|
||||||
|
if(l<=11){
|
||||||
|
if(numbers[l]==numbers[l+4]) return false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return true;
|
||||||
|
},
|
||||||
|
}
|
8
2048/entry/src/main/resources/base/element/string.json
Normal file
8
2048/entry/src/main/resources/base/element/string.json
Normal file
@ -0,0 +1,8 @@
|
|||||||
|
{
|
||||||
|
"string": [
|
||||||
|
{
|
||||||
|
"name": "entry_MainAbility",
|
||||||
|
"value": "entry_MainAbility"
|
||||||
|
}
|
||||||
|
]
|
||||||
|
}
|
BIN
2048/entry/src/main/resources/base/media/icon.png
Normal file
BIN
2048/entry/src/main/resources/base/media/icon.png
Normal file
Binary file not shown.
After Width: | Height: | Size: 5.9 KiB |
BIN
2048/entry/src/main/resources/base/media/icon_small.png
Normal file
BIN
2048/entry/src/main/resources/base/media/icon_small.png
Normal file
Binary file not shown.
After Width: | Height: | Size: 4.3 KiB |
16
MyApplication/.gitignore
vendored
Normal file
16
MyApplication/.gitignore
vendored
Normal file
@ -0,0 +1,16 @@
|
|||||||
|
*.iml
|
||||||
|
.gradle
|
||||||
|
/local.properties
|
||||||
|
/.idea/caches
|
||||||
|
/.idea/libraries
|
||||||
|
/.idea/modules.xml
|
||||||
|
/.idea/workspace.xml
|
||||||
|
/.idea/navEditor.xml
|
||||||
|
/.idea/assetWizardSettings.xml
|
||||||
|
.DS_Store
|
||||||
|
/build
|
||||||
|
/captures
|
||||||
|
.externalNativeBuild
|
||||||
|
/entry/.preview
|
||||||
|
.cxx
|
||||||
|
/node_modules
|
6
MyApplication/.idea/compiler.xml
Normal file
6
MyApplication/.idea/compiler.xml
Normal file
@ -0,0 +1,6 @@
|
|||||||
|
<?xml version="1.0" encoding="UTF-8"?>
|
||||||
|
<project version="4">
|
||||||
|
<component name="CompilerConfiguration">
|
||||||
|
<bytecodeTargetLevel target="11" />
|
||||||
|
</component>
|
||||||
|
</project>
|
22
MyApplication/.idea/gradle.xml
Normal file
22
MyApplication/.idea/gradle.xml
Normal file
@ -0,0 +1,22 @@
|
|||||||
|
<?xml version="1.0" encoding="UTF-8"?>
|
||||||
|
<project version="4">
|
||||||
|
<component name="GradleSettings">
|
||||||
|
<option name="linkedExternalProjectsSettings">
|
||||||
|
<GradleProjectSettings>
|
||||||
|
<option name="testRunner" value="PLATFORM" />
|
||||||
|
<option name="distributionType" value="LOCAL" />
|
||||||
|
<option name="externalProjectPath" value="$PROJECT_DIR$" />
|
||||||
|
<option name="gradleHome" value="C:\Program Files\Huawei\DevEco Studio 3.0.0.601\tools\gradle" />
|
||||||
|
<option name="gradleJvm" value="#JAVA_INTERNAL" />
|
||||||
|
<option name="modules">
|
||||||
|
<set>
|
||||||
|
<option value="$PROJECT_DIR$" />
|
||||||
|
<option value="$PROJECT_DIR$/entry" />
|
||||||
|
</set>
|
||||||
|
</option>
|
||||||
|
<option name="resolveModulePerSourceSet" value="false" />
|
||||||
|
<option name="useQualifiedModuleNames" value="false" />
|
||||||
|
</GradleProjectSettings>
|
||||||
|
</option>
|
||||||
|
</component>
|
||||||
|
</project>
|
36
MyApplication/.idea/inspectionProfiles/Project_Default.xml
Normal file
36
MyApplication/.idea/inspectionProfiles/Project_Default.xml
Normal file
@ -0,0 +1,36 @@
|
|||||||
|
<component name="InspectionProjectProfileManager">
|
||||||
|
<profile version="1.0">
|
||||||
|
<option name="myName" value="Project Default" />
|
||||||
|
<inspection_tool class="JavaDoc" enabled="true" level="WARNING" enabled_by_default="true">
|
||||||
|
<option name="TOP_LEVEL_CLASS_OPTIONS">
|
||||||
|
<value>
|
||||||
|
<option name="ACCESS_JAVADOC_REQUIRED_FOR" value="none" />
|
||||||
|
<option name="REQUIRED_TAGS" value="" />
|
||||||
|
</value>
|
||||||
|
</option>
|
||||||
|
<option name="INNER_CLASS_OPTIONS">
|
||||||
|
<value>
|
||||||
|
<option name="ACCESS_JAVADOC_REQUIRED_FOR" value="none" />
|
||||||
|
<option name="REQUIRED_TAGS" value="" />
|
||||||
|
</value>
|
||||||
|
</option>
|
||||||
|
<option name="METHOD_OPTIONS">
|
||||||
|
<value>
|
||||||
|
<option name="ACCESS_JAVADOC_REQUIRED_FOR" value="none" />
|
||||||
|
<option name="REQUIRED_TAGS" value="@return@param@throws or @exception" />
|
||||||
|
</value>
|
||||||
|
</option>
|
||||||
|
<option name="FIELD_OPTIONS">
|
||||||
|
<value>
|
||||||
|
<option name="ACCESS_JAVADOC_REQUIRED_FOR" value="none" />
|
||||||
|
<option name="REQUIRED_TAGS" value="" />
|
||||||
|
</value>
|
||||||
|
</option>
|
||||||
|
<option name="IGNORE_DEPRECATED" value="false" />
|
||||||
|
<option name="IGNORE_JAVADOC_PERIOD" value="true" />
|
||||||
|
<option name="IGNORE_DUPLICATED_THROWS" value="false" />
|
||||||
|
<option name="IGNORE_POINT_TO_ITSELF" value="false" />
|
||||||
|
<option name="myAdditionalJavadocTags" value="date" />
|
||||||
|
</inspection_tool>
|
||||||
|
</profile>
|
||||||
|
</component>
|
25
MyApplication/.idea/jarRepositories.xml
Normal file
25
MyApplication/.idea/jarRepositories.xml
Normal file
@ -0,0 +1,25 @@
|
|||||||
|
<?xml version="1.0" encoding="UTF-8"?>
|
||||||
|
<project version="4">
|
||||||
|
<component name="RemoteRepositoriesConfiguration">
|
||||||
|
<remote-repository>
|
||||||
|
<option name="id" value="central" />
|
||||||
|
<option name="name" value="Maven Central repository" />
|
||||||
|
<option name="url" value="https://repo1.maven.org/maven2" />
|
||||||
|
</remote-repository>
|
||||||
|
<remote-repository>
|
||||||
|
<option name="id" value="jboss.community" />
|
||||||
|
<option name="name" value="JBoss Community repository" />
|
||||||
|
<option name="url" value="https://repository.jboss.org/nexus/content/repositories/public/" />
|
||||||
|
</remote-repository>
|
||||||
|
<remote-repository>
|
||||||
|
<option name="id" value="maven2" />
|
||||||
|
<option name="name" value="maven2" />
|
||||||
|
<option name="url" value="https://developer.huawei.com/repo/" />
|
||||||
|
</remote-repository>
|
||||||
|
<remote-repository>
|
||||||
|
<option name="id" value="maven" />
|
||||||
|
<option name="name" value="maven" />
|
||||||
|
<option name="url" value="https://repo.huaweicloud.com/repository/maven/" />
|
||||||
|
</remote-repository>
|
||||||
|
</component>
|
||||||
|
</project>
|
4
MyApplication/.idea/misc.xml
Normal file
4
MyApplication/.idea/misc.xml
Normal file
@ -0,0 +1,4 @@
|
|||||||
|
<?xml version="1.0" encoding="UTF-8"?>
|
||||||
|
<project version="4">
|
||||||
|
<component name="ProjectRootManager" version="2" languageLevel="JDK_1_8" default="false" project-jdk-name="1.8" project-jdk-type="JavaSDK" />
|
||||||
|
</project>
|
6
MyApplication/.idea/vcs.xml
Normal file
6
MyApplication/.idea/vcs.xml
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>
|
53
MyApplication/build.gradle
Normal file
53
MyApplication/build.gradle
Normal file
@ -0,0 +1,53 @@
|
|||||||
|
// Top-level build file where you can add configuration options common to all sub-projects/modules.
|
||||||
|
apply plugin: 'com.huawei.ohos.app'
|
||||||
|
|
||||||
|
//For instructions on signature configuration, see https://developer.harmonyos.com/cn/docs/documentation/doc-guides/ide_debug_device-0000001053822404#section1112183053510
|
||||||
|
ohos {
|
||||||
|
signingConfigs {
|
||||||
|
debug {
|
||||||
|
storeFile file('C:\\Study\\key\\xcl2048.p12')
|
||||||
|
storePassword '00000018F7FAD4DE0BB863142993D255B63C586BFE9A4D554EB96CAC51C1C6CDC585B915635C71FE'
|
||||||
|
keyAlias = 'xcl2048'
|
||||||
|
keyPassword '000000180A8B74EFA0A1EBB5688ABB0B67ABC55BF31B52113CCDE96012B649EFAC035688455044DB'
|
||||||
|
signAlg = 'SHA256withECDSA'
|
||||||
|
profile file('C:\\Study\\key\\xcl2048Debug.p7b')
|
||||||
|
certpath file('C:\\Study\\key\\xcl2048.cer')
|
||||||
|
}
|
||||||
|
release {
|
||||||
|
storeFile file('C:\\Study\\key\\xcl2048.p12')
|
||||||
|
storePassword '00000018EC98F99FD59E53EA2D7277BB2A7A47A49EF2C571B438B41317A5F8BD3076BD495B0AA6B9'
|
||||||
|
keyAlias = 'xcl2048'
|
||||||
|
keyPassword '000000188C93967FFACA83A806DEB256E56D7BC2109E027760ED3904F370C99EF5AF5A35F008C506'
|
||||||
|
signAlg = 'SHA256withECDSA'
|
||||||
|
profile file('C:\\Study\\key\\xcl2048fRelease.p7b')
|
||||||
|
certpath file('C:\\Study\\key\\xcl2048f.cer')
|
||||||
|
}
|
||||||
|
}
|
||||||
|
compileSdkVersion 7
|
||||||
|
}
|
||||||
|
|
||||||
|
buildscript {
|
||||||
|
repositories {
|
||||||
|
maven {
|
||||||
|
url 'https://repo.huaweicloud.com/repository/maven/'
|
||||||
|
}
|
||||||
|
maven {
|
||||||
|
url 'https://developer.huawei.com/repo/'
|
||||||
|
}
|
||||||
|
}
|
||||||
|
dependencies {
|
||||||
|
classpath 'com.huawei.ohos:hap:3.0.3.4'
|
||||||
|
classpath 'com.huawei.ohos:decctest:1.2.6.0'
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
allprojects {
|
||||||
|
repositories {
|
||||||
|
maven {
|
||||||
|
url 'https://repo.huaweicloud.com/repository/maven/'
|
||||||
|
}
|
||||||
|
maven {
|
||||||
|
url 'https://developer.huawei.com/repo/'
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
2
MyApplication/entry/.gitignore
vendored
Normal file
2
MyApplication/entry/.gitignore
vendored
Normal file
@ -0,0 +1,2 @@
|
|||||||
|
/build
|
||||||
|
/node_modules
|
24
MyApplication/entry/build.gradle
Normal file
24
MyApplication/entry/build.gradle
Normal file
@ -0,0 +1,24 @@
|
|||||||
|
apply plugin: 'com.huawei.ohos.hap'
|
||||||
|
apply plugin: 'com.huawei.ohos.decctest'
|
||||||
|
//For instructions on signature configuration, see https://developer.harmonyos.com/cn/docs/documentation/doc-guides/ide_debug_device-0000001053822404#section1112183053510
|
||||||
|
ohos {
|
||||||
|
compileSdkVersion 7
|
||||||
|
defaultConfig {
|
||||||
|
compatibleSdkVersion 7
|
||||||
|
}
|
||||||
|
buildTypes {
|
||||||
|
release {
|
||||||
|
proguardOpt {
|
||||||
|
proguardEnabled false
|
||||||
|
rulesFiles 'proguard-rules.pro'
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
dependencies {
|
||||||
|
testImplementation 'junit:junit:4.13.1'
|
||||||
|
}
|
||||||
|
decc {
|
||||||
|
supportType = ['html','xml']
|
||||||
|
}
|
1
MyApplication/entry/proguard-rules.pro
vendored
Normal file
1
MyApplication/entry/proguard-rules.pro
vendored
Normal file
@ -0,0 +1 @@
|
|||||||
|
# config module specific ProGuard rules here.
|
29
MyApplication/entry/src/main/config.json
Normal file
29
MyApplication/entry/src/main/config.json
Normal file
@ -0,0 +1,29 @@
|
|||||||
|
{
|
||||||
|
"app": {
|
||||||
|
"bundleName": "com.xcl2048.myapplication",
|
||||||
|
"vendor": "xcl2048",
|
||||||
|
"version": {
|
||||||
|
"code": 1000000,
|
||||||
|
"name": "1.0.0"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"deviceConfig": {},
|
||||||
|
"module": {
|
||||||
|
"deviceType": [
|
||||||
|
"liteWearable"
|
||||||
|
],
|
||||||
|
"distro": {
|
||||||
|
"deliveryWithInstall": true,
|
||||||
|
"moduleName": "entry",
|
||||||
|
"moduleType": "entry"
|
||||||
|
},
|
||||||
|
"js": [
|
||||||
|
{
|
||||||
|
"pages": [
|
||||||
|
"pages/index/index"
|
||||||
|
],
|
||||||
|
"name": "default"
|
||||||
|
}
|
||||||
|
]
|
||||||
|
}
|
||||||
|
}
|
8
MyApplication/entry/src/main/js/default/app.js
Normal file
8
MyApplication/entry/src/main/js/default/app.js
Normal file
@ -0,0 +1,8 @@
|
|||||||
|
export default {
|
||||||
|
onCreate() {
|
||||||
|
console.info("Application onCreate");
|
||||||
|
},
|
||||||
|
onDestroy() {
|
||||||
|
console.info("Application onDestroy");
|
||||||
|
}
|
||||||
|
};
|
6
MyApplication/entry/src/main/js/default/i18n/en-US.json
Normal file
6
MyApplication/entry/src/main/js/default/i18n/en-US.json
Normal file
@ -0,0 +1,6 @@
|
|||||||
|
{
|
||||||
|
"strings": {
|
||||||
|
"hello": "Hello",
|
||||||
|
"world": "World"
|
||||||
|
}
|
||||||
|
}
|
6
MyApplication/entry/src/main/js/default/i18n/zh-CN.json
Normal file
6
MyApplication/entry/src/main/js/default/i18n/zh-CN.json
Normal file
@ -0,0 +1,6 @@
|
|||||||
|
{
|
||||||
|
"strings": {
|
||||||
|
"hello": "您好",
|
||||||
|
"world": "世界"
|
||||||
|
}
|
||||||
|
}
|
@ -0,0 +1,62 @@
|
|||||||
|
.container{
|
||||||
|
width: 454px;
|
||||||
|
height: 454px;
|
||||||
|
flex-direction: column;
|
||||||
|
justify-content: center;
|
||||||
|
align-items: center;
|
||||||
|
}
|
||||||
|
.score{
|
||||||
|
text-align: center;
|
||||||
|
width: 234px;
|
||||||
|
height: 30px;
|
||||||
|
letter-spacing: 0px;
|
||||||
|
margin-top: 4px;
|
||||||
|
margin-bottom:6px;
|
||||||
|
}
|
||||||
|
.best{
|
||||||
|
text-align: center;
|
||||||
|
width: 234px;
|
||||||
|
height: 30px;
|
||||||
|
letter-spacing: 0px;
|
||||||
|
margin-top: 19px;
|
||||||
|
}
|
||||||
|
.tile-wrap{
|
||||||
|
width: 300px;
|
||||||
|
height: 300px;
|
||||||
|
flex-wrap: wrap;
|
||||||
|
background-color: #FFFFFF;
|
||||||
|
}
|
||||||
|
.tile{
|
||||||
|
width: 70px;
|
||||||
|
height: 70px;
|
||||||
|
margin-top: 4px;
|
||||||
|
margin-left: 4px;
|
||||||
|
justify-content: center;
|
||||||
|
align-items: center;
|
||||||
|
}
|
||||||
|
.btn{
|
||||||
|
width: 135px;
|
||||||
|
height: 45px;
|
||||||
|
background-color: #1F71FF;
|
||||||
|
margin-top: 10px;
|
||||||
|
margin-bottom: 10px;
|
||||||
|
}
|
||||||
|
.text{
|
||||||
|
font-size: 30px;
|
||||||
|
color: #000000;
|
||||||
|
}
|
||||||
|
.stack{
|
||||||
|
width: 300px;
|
||||||
|
height: 300px;
|
||||||
|
}
|
||||||
|
.subcontainer{
|
||||||
|
width: 300px;
|
||||||
|
height: 300px;
|
||||||
|
justify-content: center;
|
||||||
|
align-items: center;
|
||||||
|
background-color: transparent;
|
||||||
|
}
|
||||||
|
.gameover{
|
||||||
|
font-size: 40px;
|
||||||
|
color: #FF7500;
|
||||||
|
}
|
@ -0,0 +1,23 @@
|
|||||||
|
<div class="container">
|
||||||
|
<text class="best">
|
||||||
|
Best:{{best}}
|
||||||
|
</text>
|
||||||
|
<text class="score">
|
||||||
|
Score:{{score}}
|
||||||
|
</text>
|
||||||
|
<stack class="stack">
|
||||||
|
<div class="tile-wrap" onswipe="onSwipe">
|
||||||
|
<div class="tile" for="{{tiles}}" style="background-color:#000000">
|
||||||
|
<text class="text" style="color:#FFFFFF">
|
||||||
|
{{$item.text}}
|
||||||
|
</text>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<div class="subcontainer" show="{{isShow}}">
|
||||||
|
<text class="gameover">
|
||||||
|
Gameover!
|
||||||
|
</text>
|
||||||
|
</div>
|
||||||
|
</stack>
|
||||||
|
<input class="btn" type="button" value="Restart!" onclick="onInit" ></input>
|
||||||
|
</div>
|
127
MyApplication/entry/src/main/js/default/pages/index/index.js
Normal file
127
MyApplication/entry/src/main/js/default/pages/index/index.js
Normal file
@ -0,0 +1,127 @@
|
|||||||
|
import brightness from '@system.brightness';
|
||||||
|
let numbers,newNumbers;
|
||||||
|
export default{
|
||||||
|
data:{
|
||||||
|
score:0,
|
||||||
|
best:0,
|
||||||
|
tiles:[],
|
||||||
|
isShow:false,
|
||||||
|
},
|
||||||
|
onInit() {
|
||||||
|
this.isShow=false;
|
||||||
|
this.score=0;
|
||||||
|
this.tiles=[{text:""},{text:""},{text:""},{text:""},{text:""},{text:""},{text:""},{text:""},{text:""},{text:""},{text:""},{text:""},{text:""},{text:""},{text:""},{text:""}];
|
||||||
|
numbers=[0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0];
|
||||||
|
newNumbers=[0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0];
|
||||||
|
this.supplyNumber();
|
||||||
|
this.supplyNumber();
|
||||||
|
this.updateView();
|
||||||
|
brightness.setKeepScreenOn({keepScreenOn: true,});
|
||||||
|
brightness.setMode({mode: 1,});
|
||||||
|
},
|
||||||
|
supplyNumber(){
|
||||||
|
let positions=[];
|
||||||
|
for(let i=0;i<=15;i++){
|
||||||
|
if(!newNumbers[i]) positions.push(i);
|
||||||
|
}
|
||||||
|
let h=Math.floor(Math.random()*positions.length);
|
||||||
|
if (Math.random()<=0.8){
|
||||||
|
newNumbers[positions[h]]=2;
|
||||||
|
}else{
|
||||||
|
newNumbers[positions[h]]=4;
|
||||||
|
}
|
||||||
|
},
|
||||||
|
onSwipe(e) {
|
||||||
|
newNumbers=[0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0];
|
||||||
|
let start=0,differ=0,step=0;
|
||||||
|
switch(e.direction){
|
||||||
|
case 'left':
|
||||||
|
start=0;
|
||||||
|
differ=1;
|
||||||
|
step=4;
|
||||||
|
break;
|
||||||
|
case 'right':
|
||||||
|
start=3;
|
||||||
|
differ=-1;
|
||||||
|
step=4;
|
||||||
|
break;
|
||||||
|
case 'up':
|
||||||
|
start=0;
|
||||||
|
differ=4;
|
||||||
|
step=1;
|
||||||
|
break;
|
||||||
|
case 'down':
|
||||||
|
start=12;
|
||||||
|
differ=-4;
|
||||||
|
step=1;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
let ids;
|
||||||
|
for (let j=0;j<=3;j++){
|
||||||
|
ids=this.getIds(start, differ);
|
||||||
|
let before=null;
|
||||||
|
let noZeros=0;
|
||||||
|
for(let k=0;k<=3;k++){
|
||||||
|
let id=ids[k];
|
||||||
|
let number=numbers[id];
|
||||||
|
if (number!=0){
|
||||||
|
if(number==before){
|
||||||
|
this.score+=number*2;
|
||||||
|
newNumbers[ids[noZeros-1]]*=2;
|
||||||
|
before=null;
|
||||||
|
}else{
|
||||||
|
newNumbers[ids[noZeros]]=number;
|
||||||
|
before=number;
|
||||||
|
noZeros+=1;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
start+=step;
|
||||||
|
}
|
||||||
|
if(this.best>=this.score){
|
||||||
|
this.best=this.best;
|
||||||
|
}else{
|
||||||
|
this.best=this.score;}
|
||||||
|
if(numbers.toString()!=newNumbers.toString()){
|
||||||
|
this.supplyNumber();
|
||||||
|
this.updateView();
|
||||||
|
newNumbers=[0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0];
|
||||||
|
if(this.isGameOver()==true){this.isShow=true;}
|
||||||
|
}
|
||||||
|
},
|
||||||
|
getIds(start, differ){
|
||||||
|
let ids=[];
|
||||||
|
for (let z=4;z>=1;z--){
|
||||||
|
ids.push(start);
|
||||||
|
start+=differ;
|
||||||
|
}
|
||||||
|
return ids;
|
||||||
|
},
|
||||||
|
updateView() {
|
||||||
|
for (let x=0;x<=15;x++) {
|
||||||
|
if (newNumbers[x]!=0){
|
||||||
|
this.tiles[x].text=newNumbers[x].toString();
|
||||||
|
}else{
|
||||||
|
this.tiles[x].text="";
|
||||||
|
}
|
||||||
|
}
|
||||||
|
numbers=newNumbers;
|
||||||
|
},
|
||||||
|
isGameOver(){
|
||||||
|
if(this.isGridsFull()==true && this.isGridsNotMergeable()==true) return true;
|
||||||
|
},
|
||||||
|
isGridsFull(){
|
||||||
|
if(numbers.indexOf(0)==-1){return true;}
|
||||||
|
},
|
||||||
|
isGridsNotMergeable(){
|
||||||
|
for(let l=0;l<=15;l++){
|
||||||
|
if(l<=14){
|
||||||
|
if(numbers[l]==numbers[l+1]&&(l+1)%4!=0) return false;
|
||||||
|
}
|
||||||
|
if(l<=11){
|
||||||
|
if(numbers[l]==numbers[l+4]) return false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return true;
|
||||||
|
},
|
||||||
|
}
|
@ -0,0 +1,8 @@
|
|||||||
|
{
|
||||||
|
"string": [
|
||||||
|
{
|
||||||
|
"name": "xcl2048",
|
||||||
|
"value": "xcl2048"
|
||||||
|
}
|
||||||
|
]
|
||||||
|
}
|
BIN
MyApplication/entry/src/main/resources/base/media/icon.png
Normal file
BIN
MyApplication/entry/src/main/resources/base/media/icon.png
Normal file
Binary file not shown.
After Width: | Height: | Size: 6.6 KiB |
BIN
MyApplication/entry/src/main/resources/base/media/icon_small.png
Normal file
BIN
MyApplication/entry/src/main/resources/base/media/icon_small.png
Normal file
Binary file not shown.
After Width: | Height: | Size: 5.8 KiB |
13
MyApplication/gradle.properties
Normal file
13
MyApplication/gradle.properties
Normal file
@ -0,0 +1,13 @@
|
|||||||
|
# Project-wide Gradle settings.
|
||||||
|
# IDE (e.g. DevEco Studio) users:
|
||||||
|
# Gradle settings configured through the IDE *will override*
|
||||||
|
# any settings specified in this file.
|
||||||
|
# For more details on how to configure your build environment visit
|
||||||
|
# http://www.gradle.org/docs/current/userguide/build_environment.html
|
||||||
|
# Specifies the JVM arguments used for the daemon process.
|
||||||
|
# The setting is particularly useful for tweaking memory settings.
|
||||||
|
# If the Chinese output is garbled, please configure the following parameter.
|
||||||
|
# This function is enabled by default when the DevEco Studio builds the hap/app,if you need disable gradle parallel,you should set org.gradle.parallel false.
|
||||||
|
# more information see https://docs.gradle.org/current/userguide/performance.html
|
||||||
|
# org.gradle.parallel=false
|
||||||
|
# org.gradle.jvmargs=-Dfile.encoding=GBK
|
BIN
MyApplication/gradle/wrapper/gradle-wrapper.jar
vendored
Normal file
BIN
MyApplication/gradle/wrapper/gradle-wrapper.jar
vendored
Normal file
Binary file not shown.
5
MyApplication/gradle/wrapper/gradle-wrapper.properties
vendored
Normal file
5
MyApplication/gradle/wrapper/gradle-wrapper.properties
vendored
Normal file
@ -0,0 +1,5 @@
|
|||||||
|
distributionBase=GRADLE_USER_HOME
|
||||||
|
distributionPath=wrapper/dists
|
||||||
|
distributionUrl=https\://repo.huaweicloud.com/gradle/gradle-6.3-bin.zip
|
||||||
|
zipStoreBase=GRADLE_USER_HOME
|
||||||
|
zipStorePath=wrapper/dists
|
183
MyApplication/gradlew
vendored
Normal file
183
MyApplication/gradlew
vendored
Normal file
@ -0,0 +1,183 @@
|
|||||||
|
#!/usr/bin/env sh
|
||||||
|
|
||||||
|
#
|
||||||
|
# Copyright 2015 the original author or authors.
|
||||||
|
#
|
||||||
|
# Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
# you may not use this file except in compliance with the License.
|
||||||
|
# You may obtain a copy of the License at
|
||||||
|
#
|
||||||
|
# https://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
#
|
||||||
|
# Unless required by applicable law or agreed to in writing, software
|
||||||
|
# distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
# See the License for the specific language governing permissions and
|
||||||
|
# limitations under the License.
|
||||||
|
#
|
||||||
|
|
||||||
|
##############################################################################
|
||||||
|
##
|
||||||
|
## Gradle start up script for UN*X
|
||||||
|
##
|
||||||
|
##############################################################################
|
||||||
|
|
||||||
|
# Attempt to set APP_HOME
|
||||||
|
# Resolve links: $0 may be a link
|
||||||
|
PRG="$0"
|
||||||
|
# Need this for relative symlinks.
|
||||||
|
while [ -h "$PRG" ]; do
|
||||||
|
ls=$(ls -ld "$PRG")
|
||||||
|
link=$(expr "$ls" : '.*-> \(.*\)$')
|
||||||
|
if expr "$link" : '/.*' >/dev/null; then
|
||||||
|
PRG="$link"
|
||||||
|
else
|
||||||
|
PRG=$(dirname "$PRG")"/$link"
|
||||||
|
fi
|
||||||
|
done
|
||||||
|
SAVED="$(pwd)"
|
||||||
|
cd "$(dirname \"$PRG\")/" >/dev/null
|
||||||
|
APP_HOME="$(pwd -P)"
|
||||||
|
cd "$SAVED" >/dev/null
|
||||||
|
|
||||||
|
APP_NAME="Gradle"
|
||||||
|
APP_BASE_NAME=$(basename "$0")
|
||||||
|
|
||||||
|
# Add default JVM options here. You can also use JAVA_OPTS and GRADLE_OPTS to pass JVM options to this script.
|
||||||
|
DEFAULT_JVM_OPTS='"-Xmx64m" "-Xms64m"'
|
||||||
|
|
||||||
|
# Use the maximum available, or set MAX_FD != -1 to use that value.
|
||||||
|
MAX_FD="maximum"
|
||||||
|
|
||||||
|
warn() {
|
||||||
|
echo "$*"
|
||||||
|
}
|
||||||
|
|
||||||
|
die() {
|
||||||
|
echo
|
||||||
|
echo "$*"
|
||||||
|
echo
|
||||||
|
exit 1
|
||||||
|
}
|
||||||
|
|
||||||
|
# OS specific support (must be 'true' or 'false').
|
||||||
|
cygwin=false
|
||||||
|
msys=false
|
||||||
|
darwin=false
|
||||||
|
nonstop=false
|
||||||
|
case "$(uname)" in
|
||||||
|
CYGWIN*)
|
||||||
|
cygwin=true
|
||||||
|
;;
|
||||||
|
Darwin*)
|
||||||
|
darwin=true
|
||||||
|
;;
|
||||||
|
MINGW*)
|
||||||
|
msys=true
|
||||||
|
;;
|
||||||
|
NONSTOP*)
|
||||||
|
nonstop=true
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
|
||||||
|
CLASSPATH=$APP_HOME/gradle/wrapper/gradle-wrapper.jar
|
||||||
|
|
||||||
|
# Determine the Java command to use to start the JVM.
|
||||||
|
if [ -n "$JAVA_HOME" ]; then
|
||||||
|
if [ -x "$JAVA_HOME/jre/sh/java" ]; then
|
||||||
|
# IBM's JDK on AIX uses strange locations for the executables
|
||||||
|
JAVACMD="$JAVA_HOME/jre/sh/java"
|
||||||
|
else
|
||||||
|
JAVACMD="$JAVA_HOME/bin/java"
|
||||||
|
fi
|
||||||
|
if [ ! -x "$JAVACMD" ]; then
|
||||||
|
die "ERROR: JAVA_HOME is set to an invalid directory: $JAVA_HOME
|
||||||
|
|
||||||
|
Please set the JAVA_HOME variable in your environment to match the
|
||||||
|
location of your Java installation."
|
||||||
|
fi
|
||||||
|
else
|
||||||
|
JAVACMD="java"
|
||||||
|
which java >/dev/null 2>&1 || die "ERROR: JAVA_HOME is not set and no 'java' command could be found in your PATH.
|
||||||
|
|
||||||
|
Please set the JAVA_HOME variable in your environment to match the
|
||||||
|
location of your Java installation."
|
||||||
|
fi
|
||||||
|
|
||||||
|
# Increase the maximum file descriptors if we can.
|
||||||
|
if [ "$cygwin" = "false" -a "$darwin" = "false" -a "$nonstop" = "false" ]; then
|
||||||
|
MAX_FD_LIMIT=$(ulimit -H -n)
|
||||||
|
if [ $? -eq 0 ]; then
|
||||||
|
if [ "$MAX_FD" = "maximum" -o "$MAX_FD" = "max" ]; then
|
||||||
|
MAX_FD="$MAX_FD_LIMIT"
|
||||||
|
fi
|
||||||
|
ulimit -n $MAX_FD
|
||||||
|
if [ $? -ne 0 ]; then
|
||||||
|
warn "Could not set maximum file descriptor limit: $MAX_FD"
|
||||||
|
fi
|
||||||
|
else
|
||||||
|
warn "Could not query maximum file descriptor limit: $MAX_FD_LIMIT"
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
|
||||||
|
# For Darwin, add options to specify how the application appears in the dock
|
||||||
|
if $darwin; then
|
||||||
|
GRADLE_OPTS="$GRADLE_OPTS \"-Xdock:name=$APP_NAME\" \"-Xdock:icon=$APP_HOME/media/gradle.icns\""
|
||||||
|
fi
|
||||||
|
|
||||||
|
# For Cygwin or MSYS, switch paths to Windows format before running java
|
||||||
|
if [ "$cygwin" = "true" -o "$msys" = "true" ]; then
|
||||||
|
APP_HOME=$(cygpath --path --mixed "$APP_HOME")
|
||||||
|
CLASSPATH=$(cygpath --path --mixed "$CLASSPATH")
|
||||||
|
JAVACMD=$(cygpath --unix "$JAVACMD")
|
||||||
|
|
||||||
|
# We build the pattern for arguments to be converted via cygpath
|
||||||
|
ROOTDIRSRAW=$(find -L / -maxdepth 1 -mindepth 1 -type d 2>/dev/null)
|
||||||
|
SEP=""
|
||||||
|
for dir in $ROOTDIRSRAW; do
|
||||||
|
ROOTDIRS="$ROOTDIRS$SEP$dir"
|
||||||
|
SEP="|"
|
||||||
|
done
|
||||||
|
OURCYGPATTERN="(^($ROOTDIRS))"
|
||||||
|
# Add a user-defined pattern to the cygpath arguments
|
||||||
|
if [ "$GRADLE_CYGPATTERN" != "" ]; then
|
||||||
|
OURCYGPATTERN="$OURCYGPATTERN|($GRADLE_CYGPATTERN)"
|
||||||
|
fi
|
||||||
|
# Now convert the arguments - kludge to limit ourselves to /bin/sh
|
||||||
|
i=0
|
||||||
|
for arg in "$@"; do
|
||||||
|
CHECK=$(echo "$arg" | egrep -c "$OURCYGPATTERN" -)
|
||||||
|
CHECK2=$(echo "$arg" | egrep -c "^-") ### Determine if an option
|
||||||
|
|
||||||
|
if [ $CHECK -ne 0 ] && [ $CHECK2 -eq 0 ]; then ### Added a condition
|
||||||
|
eval $(echo args$i)=$(cygpath --path --ignore --mixed "$arg")
|
||||||
|
else
|
||||||
|
eval $(echo args$i)="\"$arg\""
|
||||||
|
fi
|
||||||
|
i=$(expr $i + 1)
|
||||||
|
done
|
||||||
|
case $i in
|
||||||
|
0) set -- ;;
|
||||||
|
1) set -- "$args0" ;;
|
||||||
|
2) set -- "$args0" "$args1" ;;
|
||||||
|
3) set -- "$args0" "$args1" "$args2" ;;
|
||||||
|
4) set -- "$args0" "$args1" "$args2" "$args3" ;;
|
||||||
|
5) set -- "$args0" "$args1" "$args2" "$args3" "$args4" ;;
|
||||||
|
6) set -- "$args0" "$args1" "$args2" "$args3" "$args4" "$args5" ;;
|
||||||
|
7) set -- "$args0" "$args1" "$args2" "$args3" "$args4" "$args5" "$args6" ;;
|
||||||
|
8) set -- "$args0" "$args1" "$args2" "$args3" "$args4" "$args5" "$args6" "$args7" ;;
|
||||||
|
9) set -- "$args0" "$args1" "$args2" "$args3" "$args4" "$args5" "$args6" "$args7" "$args8" ;;
|
||||||
|
esac
|
||||||
|
fi
|
||||||
|
|
||||||
|
# Escape application args
|
||||||
|
save() {
|
||||||
|
for i; do printf %s\\n "$i" | sed "s/'/'\\\\''/g;1s/^/'/;\$s/\$/' \\\\/"; done
|
||||||
|
echo " "
|
||||||
|
}
|
||||||
|
APP_ARGS=$(save "$@")
|
||||||
|
|
||||||
|
# Collect all arguments for the java command, following the shell quoting and substitution rules
|
||||||
|
eval set -- $DEFAULT_JVM_OPTS $JAVA_OPTS $GRADLE_OPTS "\"-Dorg.gradle.appname=$APP_BASE_NAME\"" -classpath "\"$CLASSPATH\"" org.gradle.wrapper.GradleWrapperMain "$APP_ARGS"
|
||||||
|
|
||||||
|
exec "$JAVACMD" "$@"
|
103
MyApplication/gradlew.bat
vendored
Normal file
103
MyApplication/gradlew.bat
vendored
Normal file
@ -0,0 +1,103 @@
|
|||||||
|
@rem
|
||||||
|
@rem Copyright 2015 the original author or authors.
|
||||||
|
@rem
|
||||||
|
@rem Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
@rem you may not use this file except in compliance with the License.
|
||||||
|
@rem You may obtain a copy of the License at
|
||||||
|
@rem
|
||||||
|
@rem https://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
@rem
|
||||||
|
@rem Unless required by applicable law or agreed to in writing, software
|
||||||
|
@rem distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
@rem WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
@rem See the License for the specific language governing permissions and
|
||||||
|
@rem limitations under the License.
|
||||||
|
@rem
|
||||||
|
|
||||||
|
@if "%DEBUG%" == "" @echo off
|
||||||
|
@rem ##########################################################################
|
||||||
|
@rem
|
||||||
|
@rem Gradle startup script for Windows
|
||||||
|
@rem
|
||||||
|
@rem ##########################################################################
|
||||||
|
|
||||||
|
@rem Set local scope for the variables with windows NT shell
|
||||||
|
if "%OS%"=="Windows_NT" setlocal
|
||||||
|
|
||||||
|
set DIRNAME=%~dp0
|
||||||
|
if "%DIRNAME%" == "" set DIRNAME=.
|
||||||
|
set APP_BASE_NAME=%~n0
|
||||||
|
set APP_HOME=%DIRNAME%
|
||||||
|
|
||||||
|
@rem Resolve any "." and ".." in APP_HOME to make it shorter.
|
||||||
|
for %%i in ("%APP_HOME%") do set APP_HOME=%%~fi
|
||||||
|
|
||||||
|
@rem Add default JVM options here. You can also use JAVA_OPTS and GRADLE_OPTS to pass JVM options to this script.
|
||||||
|
set DEFAULT_JVM_OPTS="-Xmx64m" "-Xms64m"
|
||||||
|
|
||||||
|
@rem Find java.exe
|
||||||
|
if defined JAVA_HOME goto findJavaFromJavaHome
|
||||||
|
|
||||||
|
set JAVA_EXE=java.exe
|
||||||
|
%JAVA_EXE% -version >NUL 2>&1
|
||||||
|
if "%ERRORLEVEL%" == "0" goto init
|
||||||
|
|
||||||
|
echo.
|
||||||
|
echo ERROR: JAVA_HOME is not set and no 'java' command could be found in your PATH.
|
||||||
|
echo.
|
||||||
|
echo Please set the JAVA_HOME variable in your environment to match the
|
||||||
|
echo location of your Java installation.
|
||||||
|
|
||||||
|
goto fail
|
||||||
|
|
||||||
|
:findJavaFromJavaHome
|
||||||
|
set JAVA_HOME=%JAVA_HOME:"=%
|
||||||
|
set JAVA_EXE=%JAVA_HOME%/bin/java.exe
|
||||||
|
|
||||||
|
if exist "%JAVA_EXE%" goto init
|
||||||
|
|
||||||
|
echo.
|
||||||
|
echo ERROR: JAVA_HOME is set to an invalid directory: %JAVA_HOME%
|
||||||
|
echo.
|
||||||
|
echo Please set the JAVA_HOME variable in your environment to match the
|
||||||
|
echo location of your Java installation.
|
||||||
|
|
||||||
|
goto fail
|
||||||
|
|
||||||
|
:init
|
||||||
|
@rem Get command-line arguments, handling Windows variants
|
||||||
|
|
||||||
|
if not "%OS%" == "Windows_NT" goto win9xME_args
|
||||||
|
|
||||||
|
:win9xME_args
|
||||||
|
@rem Slurp the command line arguments.
|
||||||
|
set CMD_LINE_ARGS=
|
||||||
|
set _SKIP=2
|
||||||
|
|
||||||
|
:win9xME_args_slurp
|
||||||
|
if "x%~1" == "x" goto execute
|
||||||
|
|
||||||
|
set CMD_LINE_ARGS=%*
|
||||||
|
|
||||||
|
:execute
|
||||||
|
@rem Setup the command line
|
||||||
|
|
||||||
|
set CLASSPATH=%APP_HOME%\gradle\wrapper\gradle-wrapper.jar
|
||||||
|
|
||||||
|
@rem Execute Gradle
|
||||||
|
"%JAVA_EXE%" %DEFAULT_JVM_OPTS% %JAVA_OPTS% %GRADLE_OPTS% "-Dorg.gradle.appname=%APP_BASE_NAME%" -classpath "%CLASSPATH%" org.gradle.wrapper.GradleWrapperMain %CMD_LINE_ARGS%
|
||||||
|
|
||||||
|
:end
|
||||||
|
@rem End local scope for the variables with windows NT shell
|
||||||
|
if "%ERRORLEVEL%"=="0" goto mainEnd
|
||||||
|
|
||||||
|
:fail
|
||||||
|
rem Set variable GRADLE_EXIT_CONSOLE if you need the _script_ return code instead of
|
||||||
|
rem the _cmd.exe /c_ return code!
|
||||||
|
if not "" == "%GRADLE_EXIT_CONSOLE%" exit 1
|
||||||
|
exit /b 1
|
||||||
|
|
||||||
|
:mainEnd
|
||||||
|
if "%OS%"=="Windows_NT" endlocal
|
||||||
|
|
||||||
|
:omega
|
1
MyApplication/package.json
Normal file
1
MyApplication/package.json
Normal file
@ -0,0 +1 @@
|
|||||||
|
{}
|
1
MyApplication/settings.gradle
Normal file
1
MyApplication/settings.gradle
Normal file
@ -0,0 +1 @@
|
|||||||
|
include ':entry'
|
Reference in New Issue
Block a user