Compare commits
No commits in common. "21556e7ce9b8128132a5b993f59387aec126eac5" and "64c70ce271afe9d62c56e8ed960bc3b4cc46f365" have entirely different histories.
21556e7ce9
...
64c70ce271
1
.gitignore
vendored
@ -12,4 +12,3 @@
|
|||||||
/captures
|
/captures
|
||||||
.externalNativeBuild
|
.externalNativeBuild
|
||||||
.cxx
|
.cxx
|
||||||
local.properties
|
|
||||||
|
3
.idea/.gitignore
generated
vendored
@ -1,3 +0,0 @@
|
|||||||
# Default ignored files
|
|
||||||
/shelf/
|
|
||||||
/workspace.xml
|
|
2
.idea/compiler.xml
generated
@ -1,6 +1,6 @@
|
|||||||
<?xml version="1.0" encoding="UTF-8"?>
|
<?xml version="1.0" encoding="UTF-8"?>
|
||||||
<project version="4">
|
<project version="4">
|
||||||
<component name="CompilerConfiguration">
|
<component name="CompilerConfiguration">
|
||||||
<bytecodeTargetLevel target="17" />
|
<bytecodeTargetLevel target="1.8" />
|
||||||
</component>
|
</component>
|
||||||
</project>
|
</project>
|
18
.idea/deploymentTargetSelector.xml
generated
@ -1,18 +0,0 @@
|
|||||||
<?xml version="1.0" encoding="UTF-8"?>
|
|
||||||
<project version="4">
|
|
||||||
<component name="deploymentTargetSelector">
|
|
||||||
<selectionStates>
|
|
||||||
<SelectionState runConfigName="app">
|
|
||||||
<option name="selectionMode" value="DROPDOWN" />
|
|
||||||
<DropdownSelection timestamp="2024-11-15T08:02:02.575931500Z">
|
|
||||||
<Target type="DEFAULT_BOOT">
|
|
||||||
<handle>
|
|
||||||
<DeviceId pluginId="LocalEmulator" identifier="path=C:\Users\HP\.android\avd\Small_Phone_API_28.avd" />
|
|
||||||
</handle>
|
|
||||||
</Target>
|
|
||||||
</DropdownSelection>
|
|
||||||
<DialogSelection />
|
|
||||||
</SelectionState>
|
|
||||||
</selectionStates>
|
|
||||||
</component>
|
|
||||||
</project>
|
|
8
.idea/gradle.xml
generated
@ -4,17 +4,19 @@
|
|||||||
<component name="GradleSettings">
|
<component name="GradleSettings">
|
||||||
<option name="linkedExternalProjectsSettings">
|
<option name="linkedExternalProjectsSettings">
|
||||||
<GradleProjectSettings>
|
<GradleProjectSettings>
|
||||||
|
<option name="testRunner" value="PLATFORM" />
|
||||||
|
<option name="distributionType" value="DEFAULT_WRAPPED" />
|
||||||
<option name="externalProjectPath" value="$PROJECT_DIR$" />
|
<option name="externalProjectPath" value="$PROJECT_DIR$" />
|
||||||
<option name="gradleJvm" value="#GRADLE_LOCAL_JAVA_HOME" />
|
<option name="gradleJvm" value="1.8" />
|
||||||
<option name="modules">
|
<option name="modules">
|
||||||
<set>
|
<set>
|
||||||
<option value="$PROJECT_DIR$" />
|
<option value="$PROJECT_DIR$" />
|
||||||
<option value="$PROJECT_DIR$/app" />
|
<option value="$PROJECT_DIR$/app" />
|
||||||
</set>
|
</set>
|
||||||
</option>
|
</option>
|
||||||
<option name="resolveExternalAnnotations" value="false" />
|
<option name="resolveModulePerSourceSet" value="false" />
|
||||||
|
<option name="useQualifiedModuleNames" value="true" />
|
||||||
</GradleProjectSettings>
|
</GradleProjectSettings>
|
||||||
</option>
|
</option>
|
||||||
<option name="parallelModelFetch" value="true" />
|
|
||||||
</component>
|
</component>
|
||||||
</project>
|
</project>
|
6
.idea/kotlinc.xml
generated
@ -1,6 +0,0 @@
|
|||||||
<?xml version="1.0" encoding="UTF-8"?>
|
|
||||||
<project version="4">
|
|
||||||
<component name="KotlinJpsPluginSettings">
|
|
||||||
<option name="version" value="1.6.21" />
|
|
||||||
</component>
|
|
||||||
</project>
|
|
10
.idea/migrations.xml
generated
@ -1,10 +0,0 @@
|
|||||||
<?xml version="1.0" encoding="UTF-8"?>
|
|
||||||
<project version="4">
|
|
||||||
<component name="ProjectMigrations">
|
|
||||||
<option name="MigrateToGradleLocalJavaHome">
|
|
||||||
<set>
|
|
||||||
<option value="$PROJECT_DIR$" />
|
|
||||||
</set>
|
|
||||||
</option>
|
|
||||||
</component>
|
|
||||||
</project>
|
|
28
.idea/misc.xml
generated
@ -1,30 +1,8 @@
|
|||||||
|
<?xml version="1.0" encoding="UTF-8"?>
|
||||||
<project version="4">
|
<project version="4">
|
||||||
<component name="DesignSurface">
|
<component name="ProjectRootManager" version="2" languageLevel="JDK_1_8" default="true" project-jdk-name="1.8" project-jdk-type="JavaSDK">
|
||||||
<option name="filePathToZoomLevelMap">
|
<output url="file://$PROJECT_DIR$/build/classes" />
|
||||||
<map>
|
|
||||||
<entry key="app/src/main/res/drawable/calculate_btn.xml" value="0.187" />
|
|
||||||
<entry key="app/src/main/res/drawable/female.xml" value="0.1215" />
|
|
||||||
<entry key="app/src/main/res/drawable/female_white.xml" value="0.187" />
|
|
||||||
<entry key="app/src/main/res/drawable/ic_launcher_foreground.xml" value="0.153" />
|
|
||||||
<entry key="app/src/main/res/drawable/ic_logo_foreground.xml" value="0.1215" />
|
|
||||||
<entry key="app/src/main/res/drawable/ic_refresh.xml" value="0.187" />
|
|
||||||
<entry key="app/src/main/res/drawable/ic_share.xml" value="0.187" />
|
|
||||||
<entry key="app/src/main/res/drawable/male.xml" value="0.187" />
|
|
||||||
<entry key="app/src/main/res/drawable/male_white.xml" value="0.1215" />
|
|
||||||
<entry key="app/src/main/res/drawable/result_btn.xml" value="0.187" />
|
|
||||||
<entry key="app/src/main/res/drawable/ripple.xml" value="0.187" />
|
|
||||||
<entry key="app/src/main/res/drawable/stepper_background.xml" value="0.187" />
|
|
||||||
<entry key="app/src/main/res/layout/activity_main.xml" value="0.24270833333333333" />
|
|
||||||
<entry key="app/src/main/res/layout/fragment_home.xml" value="0.24270833333333333" />
|
|
||||||
<entry key="app/src/main/res/layout/fragment_result.xml" value="0.19670747150696496" />
|
|
||||||
<entry key="app/src/main/res/menu/menu_main.xml" value="0.1" />
|
|
||||||
<entry key="app/src/main/res/mipmap-anydpi-v26/ic_launcher.xml" value="0.153" />
|
|
||||||
<entry key="app/src/main/res/mipmap-anydpi-v26/ic_launcher_round.xml" value="0.1565" />
|
|
||||||
<entry key="app/src/main/res/mipmap-anydpi-v26/ic_logo_round.xml" value="0.1565" />
|
|
||||||
</map>
|
|
||||||
</option>
|
|
||||||
</component>
|
</component>
|
||||||
<component name="ProjectRootManager" version="2" languageLevel="JDK_17" default="true" project-jdk-name="jbr-17" project-jdk-type="JavaSDK" />
|
|
||||||
<component name="ProjectType">
|
<component name="ProjectType">
|
||||||
<option name="id" value="Android" />
|
<option name="id" value="Android" />
|
||||||
</component>
|
</component>
|
||||||
|
6
.idea/render.experimental.xml
generated
@ -1,6 +0,0 @@
|
|||||||
<?xml version="1.0" encoding="UTF-8"?>
|
|
||||||
<project version="4">
|
|
||||||
<component name="RenderSettings">
|
|
||||||
<option name="showDecorations" value="true" />
|
|
||||||
</component>
|
|
||||||
</project>
|
|
12
.idea/runConfigurations.xml
generated
Normal file
@ -0,0 +1,12 @@
|
|||||||
|
<?xml version="1.0" encoding="UTF-8"?>
|
||||||
|
<project version="4">
|
||||||
|
<component name="RunConfigurationProducerService">
|
||||||
|
<option name="ignoredProducers">
|
||||||
|
<set>
|
||||||
|
<option value="org.jetbrains.plugins.gradle.execution.test.runner.AllInPackageGradleConfigurationProducer" />
|
||||||
|
<option value="org.jetbrains.plugins.gradle.execution.test.runner.TestClassGradleConfigurationProducer" />
|
||||||
|
<option value="org.jetbrains.plugins.gradle.execution.test.runner.TestMethodGradleConfigurationProducer" />
|
||||||
|
</set>
|
||||||
|
</option>
|
||||||
|
</component>
|
||||||
|
</project>
|
3
.idea/vcs.xml
generated
@ -1,8 +1,5 @@
|
|||||||
<?xml version="1.0" encoding="UTF-8"?>
|
<?xml version="1.0" encoding="UTF-8"?>
|
||||||
<project version="4">
|
<project version="4">
|
||||||
<component name="GitSharedSettings">
|
|
||||||
<option name="synchronizeBranchProtectionRules" value="false" />
|
|
||||||
</component>
|
|
||||||
<component name="VcsDirectoryMappings">
|
<component name="VcsDirectoryMappings">
|
||||||
<mapping directory="$PROJECT_DIR$" vcs="Git" />
|
<mapping directory="$PROJECT_DIR$" vcs="Git" />
|
||||||
</component>
|
</component>
|
||||||
|
50
README.md
@ -1,48 +1,2 @@
|
|||||||
BMI Calculator
|
# BMI-Calculator
|
||||||
=================
|

|
||||||
|
|
||||||
The Body Mass Index (BMI) Calculator can be used to calculate BMI value and corresponding weight status while taking age into consideration.
|
|
||||||
|
|
||||||
Screenshots
|
|
||||||
-----------
|
|
||||||

|
|
||||||
|
|
||||||
|
|
||||||
BMI Range Table
|
|
||||||
-----------
|
|
||||||
|
|
||||||
| Category | BMI range - kg/m² |
|
|
||||||
| ----------------- |:-----------------:|
|
|
||||||
| Severe Thinness | <15 |
|
|
||||||
| Moderate Thinness | 15 - 16 |
|
|
||||||
| Mild Thinness | 16 - 18.5 |
|
|
||||||
| Normal | 18.5 - 25 |
|
|
||||||
| Overweight | 25 - 30 |
|
|
||||||
| Obese Classes | >30 |
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
Library & Features
|
|
||||||
--------------
|
|
||||||
|
|
||||||
* [View Binding][1] - provides the views to bind with the activity which is ongoing.
|
|
||||||
* [Navigation][2] - Handle everything needed for in-app navigation.
|
|
||||||
|
|
||||||
* [Animations & Transitions][3] - Move widgets and transition between screens.
|
|
||||||
* [Fragment][4] - A basic unit of composable UI.
|
|
||||||
|
|
||||||
* [Sharing][5] - uses Intents and their associated extras to allow users to share information quickly and easily, using their favorite apps.
|
|
||||||
|
|
||||||
* [Splash Screen API][6] - implemented a custom splash screen that displays correctly in Android 12 and higher.
|
|
||||||
|
|
||||||
|
|
||||||
[1]: https://developer.android.com/topic/libraries/data-binding/
|
|
||||||
[2]: https://developer.android.com/topic/libraries/architecture/navigation/
|
|
||||||
[3]: https://developer.android.com/training/animation/
|
|
||||||
[4]: https://developer.android.com/guide/components/fragments
|
|
||||||
[5]: https://developer.android.com/training/sharing/send
|
|
||||||
[6]: https://developer.android.com/guide/topics/ui/splash-screen/migrate
|
|
||||||
|
|
||||||
Additional credits
|
|
||||||
--------------------
|
|
||||||
* This App UI design inspiration is from [Ruben Vaalt](https://dribbble.com/shots/4585382-Simple-BMI-Calculator) Dribbbles account
|
|
||||||
|
Before Width: | Height: | Size: 1.7 KiB After Width: | Height: | Size: 132 B |
@ -1,16 +1,13 @@
|
|||||||
plugins {
|
apply plugin: 'com.android.application'
|
||||||
id 'com.android.application'
|
|
||||||
id 'org.jetbrains.kotlin.android'
|
|
||||||
id 'androidx.navigation.safeargs.kotlin'
|
|
||||||
}
|
|
||||||
|
|
||||||
android {
|
android {
|
||||||
compileSdk 31
|
compileSdkVersion 29
|
||||||
|
buildToolsVersion "30.0.2"
|
||||||
|
|
||||||
defaultConfig {
|
defaultConfig {
|
||||||
applicationId "com.tharun.bmicalculator"
|
applicationId "com.adpth.bmicalculator"
|
||||||
minSdk 21
|
minSdkVersion 16
|
||||||
targetSdk 31
|
targetSdkVersion 29
|
||||||
versionCode 1
|
versionCode 1
|
||||||
versionName "1.0"
|
versionName "1.0"
|
||||||
|
|
||||||
@ -24,31 +21,20 @@ android {
|
|||||||
proguardFiles getDefaultProguardFile('proguard-android-optimize.txt'), 'proguard-rules.pro'
|
proguardFiles getDefaultProguardFile('proguard-android-optimize.txt'), 'proguard-rules.pro'
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
compileOptions {
|
|
||||||
sourceCompatibility JavaVersion.VERSION_1_8
|
|
||||||
targetCompatibility JavaVersion.VERSION_1_8
|
|
||||||
}
|
|
||||||
kotlinOptions {
|
|
||||||
jvmTarget = '1.8'
|
|
||||||
}
|
|
||||||
buildFeatures {
|
buildFeatures {
|
||||||
viewBinding true
|
viewBinding = true
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
dependencies {
|
dependencies {
|
||||||
|
implementation fileTree(dir: "libs", include: ["*.jar"])
|
||||||
|
implementation 'androidx.appcompat:appcompat:1.2.0'
|
||||||
|
implementation 'androidx.constraintlayout:constraintlayout:2.0.2'
|
||||||
|
implementation 'androidx.cardview:cardview:1.0.0'
|
||||||
|
testImplementation 'junit:junit:4.13'
|
||||||
|
androidTestImplementation 'androidx.test.ext:junit:1.1.2'
|
||||||
|
androidTestImplementation 'androidx.test.espresso:espresso-core:3.3.0'
|
||||||
|
implementation 'com.github.DanielMartinus:Stepper-Touch:0.6'
|
||||||
|
|
||||||
implementation 'androidx.core:core-ktx:1.8.0'
|
|
||||||
implementation 'androidx.appcompat:appcompat:1.4.2'
|
|
||||||
implementation 'com.google.android.material:material:1.6.1'
|
|
||||||
implementation 'androidx.constraintlayout:constraintlayout:2.1.4'
|
|
||||||
implementation 'androidx.navigation:navigation-fragment-ktx:2.5.0'
|
|
||||||
implementation 'androidx.navigation:navigation-ui-ktx:2.5.0'
|
|
||||||
implementation 'androidx.legacy:legacy-support-v4:1.0.0'
|
|
||||||
implementation "androidx.fragment:fragment-ktx:1.5.0"
|
|
||||||
testImplementation 'junit:junit:4.13.2'
|
|
||||||
androidTestImplementation 'androidx.test.ext:junit:1.1.3'
|
|
||||||
androidTestImplementation 'androidx.test.espresso:espresso-core:3.4.0'
|
|
||||||
|
|
||||||
implementation "androidx.core:core-splashscreen:1.0.0-rc01"
|
|
||||||
}
|
}
|
@ -0,0 +1,26 @@
|
|||||||
|
package com.adpth.bmicalculator;
|
||||||
|
|
||||||
|
import android.content.Context;
|
||||||
|
|
||||||
|
import androidx.test.platform.app.InstrumentationRegistry;
|
||||||
|
import androidx.test.ext.junit.runners.AndroidJUnit4;
|
||||||
|
|
||||||
|
import org.junit.Test;
|
||||||
|
import org.junit.runner.RunWith;
|
||||||
|
|
||||||
|
import static org.junit.Assert.*;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Instrumented test, which will execute on an Android device.
|
||||||
|
*
|
||||||
|
* @see <a href="http://d.android.com/tools/testing">Testing documentation</a>
|
||||||
|
*/
|
||||||
|
@RunWith(AndroidJUnit4.class)
|
||||||
|
public class ExampleInstrumentedTest {
|
||||||
|
@Test
|
||||||
|
public void useAppContext() {
|
||||||
|
// Context of the app under test.
|
||||||
|
Context appContext = InstrumentationRegistry.getInstrumentation().getTargetContext();
|
||||||
|
assertEquals("com.adpth.bmicalculator", appContext.getPackageName());
|
||||||
|
}
|
||||||
|
}
|
@ -1,24 +0,0 @@
|
|||||||
package com.tharun.bmicalculator
|
|
||||||
|
|
||||||
import androidx.test.platform.app.InstrumentationRegistry
|
|
||||||
import androidx.test.ext.junit.runners.AndroidJUnit4
|
|
||||||
|
|
||||||
import org.junit.Test
|
|
||||||
import org.junit.runner.RunWith
|
|
||||||
|
|
||||||
import org.junit.Assert.*
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Instrumented test, which will execute on an Android device.
|
|
||||||
*
|
|
||||||
* See [testing documentation](http://d.android.com/tools/testing).
|
|
||||||
*/
|
|
||||||
@RunWith(AndroidJUnit4::class)
|
|
||||||
class ExampleInstrumentedTest {
|
|
||||||
@Test
|
|
||||||
fun useAppContext() {
|
|
||||||
// Context of the app under test.
|
|
||||||
val appContext = InstrumentationRegistry.getInstrumentation().targetContext
|
|
||||||
assertEquals("com.tharun.bmicalculator", appContext.packageName)
|
|
||||||
}
|
|
||||||
}
|
|
@ -1,22 +1,23 @@
|
|||||||
<?xml version="1.0" encoding="utf-8"?>
|
<?xml version="1.0" encoding="utf-8"?>
|
||||||
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
|
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
|
||||||
package="com.tharun.bmicalculator">
|
package="com.adpth.bmicalculator">
|
||||||
|
|
||||||
<application
|
<application
|
||||||
|
android:allowBackup="true"
|
||||||
android:icon="@mipmap/ic_launcher"
|
android:icon="@mipmap/ic_launcher"
|
||||||
android:label="@string/app_name"
|
android:label="@string/app_name"
|
||||||
android:roundIcon="@mipmap/ic_launcher_round"
|
android:roundIcon="@mipmap/ic_launcher_round"
|
||||||
android:theme="@style/Theme.AppSplash">
|
android:supportsRtl="true"
|
||||||
<activity
|
android:theme="@style/AppTheme">
|
||||||
android:name=".MainActivity"
|
<activity android:name=".ResultActivity"/>
|
||||||
android:exported="true"
|
<activity android:name=".SplashActivity">
|
||||||
android:screenOrientation="portrait">
|
|
||||||
<intent-filter>
|
<intent-filter>
|
||||||
<action android:name="android.intent.action.MAIN" />
|
<action android:name="android.intent.action.MAIN" />
|
||||||
|
|
||||||
<category android:name="android.intent.category.LAUNCHER" />
|
<category android:name="android.intent.category.LAUNCHER" />
|
||||||
</intent-filter>
|
</intent-filter>
|
||||||
</activity>
|
</activity>
|
||||||
|
<activity android:name=".MainActivity"/>
|
||||||
</application>
|
</application>
|
||||||
|
|
||||||
</manifest>
|
</manifest>
|
Before Width: | Height: | Size: 15 KiB |
Before Width: | Height: | Size: 15 KiB |
26
app/src/main/java/com/adpth/bmicalculator/Category.java
Normal file
@ -0,0 +1,26 @@
|
|||||||
|
package com.adpth.bmicalculator;
|
||||||
|
|
||||||
|
public class Category {
|
||||||
|
|
||||||
|
public String getCategory (float result) {
|
||||||
|
String category;
|
||||||
|
if (result < 15) {
|
||||||
|
category = "very severely underweight";
|
||||||
|
} else if (result >=15 && result <= 16) {
|
||||||
|
category = "severely underweight";
|
||||||
|
} else if (result >16 && result <= 18.5) {
|
||||||
|
category = "underweight";
|
||||||
|
} else if (result >18.5 && result <= 25) {
|
||||||
|
category = "normal (healthy weight)";
|
||||||
|
} else if (result >25 && result <= 30) {
|
||||||
|
category = "overweight";
|
||||||
|
} else if (result >30 && result <= 35) {
|
||||||
|
category = "moderately obese";
|
||||||
|
} else if (result >35 && result <= 40) {
|
||||||
|
category = "severely obese";
|
||||||
|
} else {
|
||||||
|
category ="very severely obese";
|
||||||
|
}
|
||||||
|
return category;
|
||||||
|
}
|
||||||
|
}
|
27
app/src/main/java/com/adpth/bmicalculator/Condition.java
Normal file
@ -0,0 +1,27 @@
|
|||||||
|
package com.adpth.bmicalculator;
|
||||||
|
|
||||||
|
public class Condition {
|
||||||
|
|
||||||
|
public String getCategory (float result) {
|
||||||
|
String category;
|
||||||
|
if (result < 15) {
|
||||||
|
category = "Severe Thinness";
|
||||||
|
} else if (result >=15 && result <= 16) {
|
||||||
|
category = "Moderate Thinness";
|
||||||
|
} else if (result >16 && result <= 18.5) {
|
||||||
|
category = "Mild Thinness";
|
||||||
|
} else if (result >18.5 && result <= 25) {
|
||||||
|
category = "Normal";
|
||||||
|
} else if (result >25 && result <= 30) {
|
||||||
|
category = "Overweight";
|
||||||
|
} else if (result >30 && result <= 35) {
|
||||||
|
category = "Obese Class I";
|
||||||
|
} else if (result >35 && result <= 40) {
|
||||||
|
category = "Obese Class II";
|
||||||
|
} else {
|
||||||
|
category ="Obese Class III";
|
||||||
|
}
|
||||||
|
return category;
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
164
app/src/main/java/com/adpth/bmicalculator/MainActivity.java
Normal file
@ -0,0 +1,164 @@
|
|||||||
|
package com.adpth.bmicalculator;
|
||||||
|
|
||||||
|
import androidx.appcompat.app.AppCompatActivity;
|
||||||
|
import androidx.cardview.widget.CardView;
|
||||||
|
|
||||||
|
import android.content.Intent;
|
||||||
|
import android.graphics.Color;
|
||||||
|
|
||||||
|
import android.os.Bundle;
|
||||||
|
import android.view.View;
|
||||||
|
import android.widget.Button;
|
||||||
|
import android.widget.ImageView;
|
||||||
|
import android.widget.RelativeLayout;
|
||||||
|
import android.widget.SeekBar;
|
||||||
|
import android.widget.TextView;
|
||||||
|
|
||||||
|
import com.adpth.bmicalculator.databinding.ActivityMainBinding;
|
||||||
|
|
||||||
|
public class MainActivity extends AppCompatActivity {
|
||||||
|
|
||||||
|
float height,weight;
|
||||||
|
int count_weight = 50,count_age = 19;
|
||||||
|
boolean male_clk = true, female_clk = true, check1 = true, check2 = true;
|
||||||
|
private ActivityMainBinding binding;
|
||||||
|
|
||||||
|
@Override
|
||||||
|
protected void onCreate(Bundle savedInstanceState) {
|
||||||
|
super.onCreate(savedInstanceState);
|
||||||
|
binding = ActivityMainBinding.inflate(getLayoutInflater());
|
||||||
|
View view = binding.getRoot();
|
||||||
|
setContentView(view);
|
||||||
|
|
||||||
|
binding.cardViewMale.setOnClickListener(new View.OnClickListener() {
|
||||||
|
@Override
|
||||||
|
public void onClick(View v) {
|
||||||
|
if (check1) {
|
||||||
|
|
||||||
|
if (male_clk) {
|
||||||
|
|
||||||
|
binding.male.setTextColor(Color.parseColor("#FFFFFF"));
|
||||||
|
binding.male.setCompoundDrawablesWithIntrinsicBounds(0,R.drawable.male_white,0,0);
|
||||||
|
male_clk = false;
|
||||||
|
check2 = false;
|
||||||
|
|
||||||
|
} else {
|
||||||
|
|
||||||
|
binding.male.setTextColor(Color.parseColor("#8D8E99"));
|
||||||
|
binding.male.setCompoundDrawablesWithIntrinsicBounds(0,R.drawable.male,0,0);
|
||||||
|
male_clk = true;
|
||||||
|
check2 = true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
binding.cardViewFemale.setOnClickListener(new View.OnClickListener() {
|
||||||
|
@Override
|
||||||
|
public void onClick(View v) {
|
||||||
|
if (check2) {
|
||||||
|
if (female_clk) {
|
||||||
|
binding.female.setTextColor(Color.parseColor("#FFFFFF"));
|
||||||
|
binding.female.setCompoundDrawablesWithIntrinsicBounds(0,R.drawable.female_white,0,0);
|
||||||
|
female_clk = false;
|
||||||
|
check1 = false;
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
|
||||||
|
binding.female.setTextColor(Color.parseColor("#8D8E99"));
|
||||||
|
binding.female.setCompoundDrawablesWithIntrinsicBounds(0,R.drawable.female,0,0);
|
||||||
|
female_clk = true;
|
||||||
|
check1 = true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
CheckSeekbarStatus();
|
||||||
|
|
||||||
|
CheckWeight();
|
||||||
|
|
||||||
|
CheckAge();
|
||||||
|
|
||||||
|
binding.calculate.setOnClickListener(new View.OnClickListener() {
|
||||||
|
@Override
|
||||||
|
public void onClick(View v) {
|
||||||
|
CalculateBMI();
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
private void CheckAge() {
|
||||||
|
|
||||||
|
binding.agePlus.setOnClickListener(new View.OnClickListener() {
|
||||||
|
@Override
|
||||||
|
public void onClick(View v) {
|
||||||
|
count_age++;
|
||||||
|
binding.age.setText(String.valueOf(count_age));
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
binding.ageMinus.setOnClickListener(new View.OnClickListener() {
|
||||||
|
@Override
|
||||||
|
public void onClick(View v) {
|
||||||
|
count_age--;
|
||||||
|
binding.age.setText(String.valueOf(count_age));
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
private void CheckWeight() {
|
||||||
|
|
||||||
|
binding.weightPlus.setOnClickListener(new View.OnClickListener() {
|
||||||
|
@Override
|
||||||
|
public void onClick(View v) {
|
||||||
|
count_weight++;
|
||||||
|
binding.weight.setText(String.valueOf(count_weight));
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
binding.weightMinus.setOnClickListener(new View.OnClickListener() {
|
||||||
|
@Override
|
||||||
|
public void onClick(View v) {
|
||||||
|
count_weight--;
|
||||||
|
binding.weight.setText(String.valueOf(count_weight));
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
weight = Float.parseFloat(binding.weight.getText().toString());
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
private void CheckSeekbarStatus() {
|
||||||
|
|
||||||
|
binding.Seekbar.setOnSeekBarChangeListener(new SeekBar.OnSeekBarChangeListener() {
|
||||||
|
@Override
|
||||||
|
public void onProgressChanged(SeekBar seekBar, int progress, boolean fromUser) {
|
||||||
|
String ht = progress + getResources().getString(R.string.cm);
|
||||||
|
binding.heightTxt.setText(ht);
|
||||||
|
height = (float)(progress)/100;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void onStartTrackingTouch(SeekBar seekBar) {
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void onStopTrackingTouch(SeekBar seekBar) {
|
||||||
|
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
private void CalculateBMI() {
|
||||||
|
|
||||||
|
float BMI = weight / (height * height);
|
||||||
|
Intent intent = new Intent(MainActivity.this,ResultActivity.class);
|
||||||
|
intent.putExtra("BMI",BMI);
|
||||||
|
intent.putExtra("age",binding.age.getText().toString());
|
||||||
|
startActivity(intent);
|
||||||
|
}
|
||||||
|
}
|
@ -0,0 +1,62 @@
|
|||||||
|
package com.adpth.bmicalculator;
|
||||||
|
|
||||||
|
import androidx.appcompat.app.AppCompatActivity;
|
||||||
|
|
||||||
|
import android.content.Intent;
|
||||||
|
import android.os.Bundle;
|
||||||
|
import android.view.View;
|
||||||
|
import android.widget.Button;
|
||||||
|
import android.widget.RelativeLayout;
|
||||||
|
import android.widget.TextView;
|
||||||
|
|
||||||
|
import org.w3c.dom.Text;
|
||||||
|
|
||||||
|
public class ResultActivity extends AppCompatActivity {
|
||||||
|
|
||||||
|
|
||||||
|
@Override
|
||||||
|
protected void onCreate(Bundle savedInstanceState) {
|
||||||
|
super.onCreate(savedInstanceState);
|
||||||
|
setContentView(R.layout.activity_result);
|
||||||
|
|
||||||
|
Intent intent = getIntent();
|
||||||
|
|
||||||
|
float BMI = Math.round((intent.getFloatExtra("BMI", 0) * 100) / 100);
|
||||||
|
String age_value = intent.getStringExtra("age");
|
||||||
|
|
||||||
|
TextView your_bmi = findViewById(R.id.your_bmi);
|
||||||
|
your_bmi.setText(String.valueOf(BMI));
|
||||||
|
|
||||||
|
TextView age = findViewById(R.id.age);
|
||||||
|
age.setText(age_value);
|
||||||
|
|
||||||
|
TextView category = findViewById(R.id.category);
|
||||||
|
Category category1 = new Category();
|
||||||
|
category.setText(category1.getCategory(BMI));
|
||||||
|
|
||||||
|
TextView condition = findViewById(R.id.condition);
|
||||||
|
Condition condition1 = new Condition();
|
||||||
|
condition.setText(condition1.getCategory(BMI));
|
||||||
|
|
||||||
|
Button recalculate = findViewById(R.id.recalculate);
|
||||||
|
recalculate.setOnClickListener(new View.OnClickListener() {
|
||||||
|
@Override
|
||||||
|
public void onClick(View v) {
|
||||||
|
updateUI();
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
private void updateUI() {
|
||||||
|
Intent intent1 = new Intent(ResultActivity.this,MainActivity.class);
|
||||||
|
startActivity(intent1);
|
||||||
|
fileList();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void onBackPressed() {
|
||||||
|
super.onBackPressed();
|
||||||
|
updateUI();
|
||||||
|
}
|
||||||
|
}
|
@ -0,0 +1,25 @@
|
|||||||
|
package com.adpth.bmicalculator;
|
||||||
|
|
||||||
|
import androidx.appcompat.app.AppCompatActivity;
|
||||||
|
|
||||||
|
import android.content.Intent;
|
||||||
|
import android.os.Bundle;
|
||||||
|
import android.os.Handler;
|
||||||
|
|
||||||
|
public class SplashActivity extends AppCompatActivity {
|
||||||
|
|
||||||
|
@Override
|
||||||
|
protected void onCreate(Bundle savedInstanceState) {
|
||||||
|
super.onCreate(savedInstanceState);
|
||||||
|
setContentView(R.layout.activity_splash);
|
||||||
|
|
||||||
|
new Handler().postDelayed(new Runnable() {
|
||||||
|
@Override
|
||||||
|
public void run() {
|
||||||
|
Intent intent = new Intent(SplashActivity.this,MainActivity.class);
|
||||||
|
startActivity(intent);
|
||||||
|
finish();
|
||||||
|
}
|
||||||
|
},3500);
|
||||||
|
}
|
||||||
|
}
|
@ -1,125 +0,0 @@
|
|||||||
package com.tharun.bmicalculator
|
|
||||||
|
|
||||||
import android.graphics.Color
|
|
||||||
import android.os.Bundle
|
|
||||||
import android.view.LayoutInflater
|
|
||||||
import android.view.View
|
|
||||||
import android.view.ViewGroup
|
|
||||||
import android.widget.SeekBar
|
|
||||||
import android.widget.Toast
|
|
||||||
import androidx.fragment.app.Fragment
|
|
||||||
import androidx.navigation.fragment.findNavController
|
|
||||||
import com.tharun.bmicalculator.databinding.FragmentHomeBinding
|
|
||||||
|
|
||||||
class HomeFragment : Fragment() {
|
|
||||||
|
|
||||||
private var height: Float = 0f
|
|
||||||
private var weight: Float = 0f
|
|
||||||
private var countWeight = 50
|
|
||||||
private var countAge = 19
|
|
||||||
private var chosen: Boolean = true
|
|
||||||
private var _binding: FragmentHomeBinding? = null
|
|
||||||
private val binding get() = _binding!!
|
|
||||||
|
|
||||||
override fun onCreateView(
|
|
||||||
inflater: LayoutInflater, container: ViewGroup?,
|
|
||||||
savedInstanceState: Bundle?
|
|
||||||
): View {
|
|
||||||
|
|
||||||
_binding = FragmentHomeBinding.inflate(inflater, container, false)
|
|
||||||
|
|
||||||
initComponents()
|
|
||||||
|
|
||||||
return binding.root
|
|
||||||
}
|
|
||||||
|
|
||||||
private fun initComponents() {
|
|
||||||
|
|
||||||
binding.apply {
|
|
||||||
|
|
||||||
Seekbar.setOnSeekBarChangeListener(object : SeekBar.OnSeekBarChangeListener {
|
|
||||||
override fun onProgressChanged(seekBar: SeekBar, progress: Int, fromUser: Boolean) {
|
|
||||||
val ht = progress.toString() + resources.getString(R.string.cm)
|
|
||||||
binding.heightTxt.text = ht
|
|
||||||
height = progress.toFloat() / 100
|
|
||||||
}
|
|
||||||
|
|
||||||
override fun onStartTrackingTouch(seekBar: SeekBar) {}
|
|
||||||
override fun onStopTrackingTouch(seekBar: SeekBar) {}
|
|
||||||
})
|
|
||||||
|
|
||||||
weightPlus.setOnClickListener {
|
|
||||||
binding.weightTxt.text = countWeight++.toString()
|
|
||||||
}
|
|
||||||
|
|
||||||
weightMinus.setOnClickListener {
|
|
||||||
binding.weightTxt.text = countWeight--.toString()
|
|
||||||
}
|
|
||||||
|
|
||||||
agePlus.setOnClickListener {
|
|
||||||
binding.age.text = countAge++.toString()
|
|
||||||
}
|
|
||||||
|
|
||||||
ageMinus.setOnClickListener {
|
|
||||||
binding.age.text = countAge--.toString()
|
|
||||||
}
|
|
||||||
|
|
||||||
calculate.setOnClickListener {
|
|
||||||
if(!chosen) {
|
|
||||||
if(height.equals(0f)) {
|
|
||||||
Toast.makeText(requireContext(),"Height cannot be Zero, Try again", Toast.LENGTH_SHORT).show()
|
|
||||||
}
|
|
||||||
else {
|
|
||||||
weight = binding.weightTxt.text.toString().toFloat()
|
|
||||||
calculateBMI(age.text.toString())
|
|
||||||
}
|
|
||||||
}
|
|
||||||
else {
|
|
||||||
Toast.makeText(requireContext(),"Choose your gender", Toast.LENGTH_SHORT).show()
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
cardViewMale.setOnClickListener {
|
|
||||||
if(chosen) {
|
|
||||||
maleTxt.setTextColor(Color.parseColor("#FFFFFF"))
|
|
||||||
maleTxt.setCompoundDrawablesWithIntrinsicBounds(0, R.drawable.male_white, 0, 0)
|
|
||||||
cardViewFemale.isEnabled = false
|
|
||||||
chosen = false
|
|
||||||
|
|
||||||
} else {
|
|
||||||
maleTxt.setTextColor(Color.parseColor("#8D8E99"))
|
|
||||||
maleTxt.setCompoundDrawablesWithIntrinsicBounds(0, R.drawable.male, 0, 0)
|
|
||||||
cardViewFemale.isEnabled = true
|
|
||||||
chosen = true
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
cardViewFemale.setOnClickListener {
|
|
||||||
if(chosen) {
|
|
||||||
femaleTxt.setTextColor(Color.parseColor("#FFFFFF"))
|
|
||||||
femaleTxt.setCompoundDrawablesWithIntrinsicBounds(0, R.drawable.female_white, 0, 0)
|
|
||||||
cardViewMale.isEnabled = false
|
|
||||||
chosen = false
|
|
||||||
|
|
||||||
} else {
|
|
||||||
femaleTxt.setTextColor(Color.parseColor("#8D8E99"))
|
|
||||||
femaleTxt.setCompoundDrawablesWithIntrinsicBounds(0, R.drawable.female, 0, 0)
|
|
||||||
cardViewMale.isEnabled = true
|
|
||||||
chosen = true
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
private fun calculateBMI(age: String) {
|
|
||||||
val bmi = weight / (height*height)
|
|
||||||
val action = HomeFragmentDirections.actionHomeFragmentToResultFragment(bmi,age)
|
|
||||||
findNavController().navigate(action)
|
|
||||||
}
|
|
||||||
|
|
||||||
override fun onDestroyView() {
|
|
||||||
super.onDestroyView()
|
|
||||||
_binding = null
|
|
||||||
}
|
|
||||||
}
|
|
@ -1,20 +0,0 @@
|
|||||||
package com.tharun.bmicalculator
|
|
||||||
|
|
||||||
import android.os.Bundle
|
|
||||||
import androidx.appcompat.app.AppCompatActivity
|
|
||||||
import androidx.core.splashscreen.SplashScreen.Companion.installSplashScreen
|
|
||||||
import com.tharun.bmicalculator.databinding.ActivityMainBinding
|
|
||||||
|
|
||||||
class MainActivity : AppCompatActivity() {
|
|
||||||
|
|
||||||
private lateinit var binding: ActivityMainBinding
|
|
||||||
|
|
||||||
override fun onCreate(savedInstanceState: Bundle?) {
|
|
||||||
super.onCreate(savedInstanceState)
|
|
||||||
|
|
||||||
installSplashScreen()
|
|
||||||
|
|
||||||
binding = ActivityMainBinding.inflate(layoutInflater)
|
|
||||||
setContentView(binding.root)
|
|
||||||
}
|
|
||||||
}
|
|
@ -1,97 +0,0 @@
|
|||||||
package com.tharun.bmicalculator
|
|
||||||
|
|
||||||
import android.content.Intent
|
|
||||||
import android.graphics.Color
|
|
||||||
import android.os.Bundle
|
|
||||||
import android.text.SpannableString
|
|
||||||
import android.text.style.ForegroundColorSpan
|
|
||||||
import android.view.LayoutInflater
|
|
||||||
import android.view.View
|
|
||||||
import android.view.ViewGroup
|
|
||||||
import android.widget.Toast
|
|
||||||
import androidx.fragment.app.Fragment
|
|
||||||
import androidx.navigation.fragment.navArgs
|
|
||||||
import com.tharun.bmicalculator.databinding.FragmentResultBinding
|
|
||||||
import kotlin.math.roundToInt
|
|
||||||
|
|
||||||
class ResultFragment : Fragment() {
|
|
||||||
|
|
||||||
private var _binding: FragmentResultBinding? = null
|
|
||||||
private val binding get() = _binding!!
|
|
||||||
private val args: ResultFragmentArgs by navArgs()
|
|
||||||
|
|
||||||
override fun onCreateView(
|
|
||||||
inflater: LayoutInflater, container: ViewGroup?,
|
|
||||||
savedInstanceState: Bundle?
|
|
||||||
): View {
|
|
||||||
_binding = FragmentResultBinding.inflate(inflater, container, false)
|
|
||||||
|
|
||||||
val bmi = (args.bmi * 100 / 100).roundToInt().toFloat()
|
|
||||||
val age = args.age
|
|
||||||
|
|
||||||
binding.apply {
|
|
||||||
|
|
||||||
yourBmi.text = bmi.toString()
|
|
||||||
condition.text = Utils.checkAdult(age.toInt(),bmi)
|
|
||||||
//category.text = Utils.checkAdult(age.toInt(),bmi)
|
|
||||||
|
|
||||||
recalculate.setOnClickListener {
|
|
||||||
requireActivity().onBackPressed()
|
|
||||||
}
|
|
||||||
|
|
||||||
val spannable = SpannableString("Suggestion: ${Utils.getSuggestions(bmi)}")
|
|
||||||
|
|
||||||
val fColor = ForegroundColorSpan(Color.parseColor("#FE0049"))
|
|
||||||
spannable.setSpan(fColor,0,11,SpannableString.SPAN_INCLUSIVE_EXCLUSIVE)
|
|
||||||
|
|
||||||
suggestion.text = spannable
|
|
||||||
|
|
||||||
val spannable1 = SpannableString("$age (${category(age.toInt())})")
|
|
||||||
|
|
||||||
ageTxt.text = spannable1
|
|
||||||
|
|
||||||
share.setOnClickListener {
|
|
||||||
shareContent(bmi)
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
return binding.root
|
|
||||||
}
|
|
||||||
|
|
||||||
private fun category(age: Int): String {
|
|
||||||
val category:String = when (age) {
|
|
||||||
in 2..19 -> {
|
|
||||||
"Teenage"
|
|
||||||
}
|
|
||||||
else -> {
|
|
||||||
"Adult"
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return category
|
|
||||||
}
|
|
||||||
|
|
||||||
private fun shareContent(bmi: Float) {
|
|
||||||
try {
|
|
||||||
|
|
||||||
val strShareMessage = "Hello!! my BMI is ${bmi}\n\n" +
|
|
||||||
"my current condition: ${binding.condition.text}\n" +
|
|
||||||
"my age is: ${binding.ageTxt.text}\n\n" +
|
|
||||||
"App suggested me that: ${binding.suggestion.text}"
|
|
||||||
|
|
||||||
val i = Intent(Intent.ACTION_SEND)
|
|
||||||
i.putExtra(Intent.EXTRA_TEXT, strShareMessage)
|
|
||||||
i.type = "text/plain"
|
|
||||||
startActivity(Intent.createChooser(i, "Select App to Share with your friends"))
|
|
||||||
|
|
||||||
} catch (e: Exception) {
|
|
||||||
|
|
||||||
Toast.makeText(requireContext(),e.toString(),Toast.LENGTH_LONG).show()
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
override fun onDestroyView() {
|
|
||||||
super.onDestroyView()
|
|
||||||
_binding = null
|
|
||||||
}
|
|
||||||
}
|
|
@ -1,85 +0,0 @@
|
|||||||
package com.tharun.bmicalculator
|
|
||||||
|
|
||||||
object Utils {
|
|
||||||
|
|
||||||
fun checkAdult(age: Int, result: Float): String {
|
|
||||||
val category:String = when (age) {
|
|
||||||
in 2..19 -> {
|
|
||||||
getAdultCategory(result)
|
|
||||||
}
|
|
||||||
else -> {
|
|
||||||
getChildCategory(result)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return category
|
|
||||||
}
|
|
||||||
|
|
||||||
private fun getAdultCategory(result: Float): String {
|
|
||||||
val category: String = if (result < 15) {
|
|
||||||
"Severe Thinness"
|
|
||||||
} else if (result in 15.0..16.0) {
|
|
||||||
"Moderate Thinness"
|
|
||||||
} else if (result > 16 && result <= 18.5) {
|
|
||||||
"Mild Thinness"
|
|
||||||
} else if (result > 18.5 && result <= 25) {
|
|
||||||
"Normal"
|
|
||||||
} else if (result > 25 && result <= 30) {
|
|
||||||
"Overweight"
|
|
||||||
} else if (result > 30 && result <= 35) {
|
|
||||||
"Obese Class I"
|
|
||||||
} else if (result > 35 && result <= 40) {
|
|
||||||
"Obese Class II"
|
|
||||||
} else {
|
|
||||||
"Obese Class III"
|
|
||||||
}
|
|
||||||
return category
|
|
||||||
}
|
|
||||||
|
|
||||||
private fun getChildCategory(result: Float): String {
|
|
||||||
val category: String = when {
|
|
||||||
result < 15 -> {
|
|
||||||
"very severely underweight"
|
|
||||||
}
|
|
||||||
result in 15.0..16.0 -> {
|
|
||||||
"severely underweight"
|
|
||||||
}
|
|
||||||
result > 16 && result <= 18.5 -> {
|
|
||||||
"underweight"
|
|
||||||
}
|
|
||||||
result > 18.5 && result <= 25 -> {
|
|
||||||
"normal (healthy weight)"
|
|
||||||
}
|
|
||||||
result > 25 && result <= 30 -> {
|
|
||||||
"overweight"
|
|
||||||
}
|
|
||||||
result > 30 && result <= 35 -> {
|
|
||||||
"moderately obese"
|
|
||||||
}
|
|
||||||
result > 35 && result <= 40 -> {
|
|
||||||
"severely obese"
|
|
||||||
}
|
|
||||||
else -> {
|
|
||||||
"very severely obese"
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return category
|
|
||||||
}
|
|
||||||
|
|
||||||
fun getSuggestions(result: Float): String {
|
|
||||||
val suggestion: String = when {
|
|
||||||
result < 18.5 -> {
|
|
||||||
"A BMI of under 18.5 indicates that a person has insufficient weight, so they may need to put on some weight. They should ask a doctor or dietitian for advice."
|
|
||||||
}
|
|
||||||
result in 18.5..24.9 -> {
|
|
||||||
"A BMI of 18.5–24.9 indicates that a person has a healthy weight for their height. By maintaining a healthy weight, they can lower their risk of developing serious health problems."
|
|
||||||
}
|
|
||||||
result < 25 && result >=29.9 -> {
|
|
||||||
"A BMI of 25–29.9 indicates that a person is slightly overweight. A doctor may advise them to lose some weight for health reasons. They should talk with a doctor or dietitian for advice."
|
|
||||||
}
|
|
||||||
else -> {
|
|
||||||
"A BMI of over 30 indicates that a person has obesity. Their health may be at risk if they do not lose weight. They should talk with a doctor or dietitian for advice."
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return suggestion
|
|
||||||
}
|
|
||||||
}
|
|
@ -1,6 +0,0 @@
|
|||||||
<?xml version="1.0" encoding="utf-8"?>
|
|
||||||
<set xmlns:android="http://schemas.android.com/apk/res/android">
|
|
||||||
<translate android:fromXDelta="-100%" android:toXDelta="0%"
|
|
||||||
android:fromYDelta="0%" android:toYDelta="0%"
|
|
||||||
android:duration="200"/>
|
|
||||||
</set>
|
|
@ -1,6 +0,0 @@
|
|||||||
<?xml version="1.0" encoding="utf-8"?>
|
|
||||||
<set xmlns:android="http://schemas.android.com/apk/res/android">
|
|
||||||
<translate android:fromXDelta="100%" android:toXDelta="0%"
|
|
||||||
android:fromYDelta="0%" android:toYDelta="0%"
|
|
||||||
android:duration="200"/>
|
|
||||||
</set>
|
|
@ -1,6 +0,0 @@
|
|||||||
<?xml version="1.0" encoding="utf-8"?>
|
|
||||||
<set xmlns:android="http://schemas.android.com/apk/res/android">
|
|
||||||
<translate android:fromXDelta="0%" android:toXDelta="-100%"
|
|
||||||
android:fromYDelta="0%" android:toYDelta="0%"
|
|
||||||
android:duration="200"/>
|
|
||||||
</set>
|
|
@ -1,6 +0,0 @@
|
|||||||
<?xml version="1.0" encoding="utf-8"?>
|
|
||||||
<set xmlns:android="http://schemas.android.com/apk/res/android">
|
|
||||||
<translate android:fromXDelta="0%" android:toXDelta="100%"
|
|
||||||
android:fromYDelta="0%" android:toYDelta="0%"
|
|
||||||
android:duration="200"/>
|
|
||||||
</set>
|
|
23
app/src/main/res/drawable-v24/female_white.xml
Normal file
@ -0,0 +1,23 @@
|
|||||||
|
<?xml version="1.0" encoding="utf-8"?>
|
||||||
|
<vector xmlns:android="http://schemas.android.com/apk/res/android"
|
||||||
|
android:width="90dp"
|
||||||
|
android:height="90dp"
|
||||||
|
android:viewportWidth="944"
|
||||||
|
android:viewportHeight="944">
|
||||||
|
|
||||||
|
<path
|
||||||
|
android:strokeColor="#FFFFFF"
|
||||||
|
android:strokeWidth="60"
|
||||||
|
android:pathData="M437.176 194.639C520.841 110.973 658.703 111.743 745.108 198.148C831.513 284.553 832.283 422.415 748.618 506.081C664.952 589.746 527.09 588.976 440.685 502.571C354.28 416.166 353.51 278.304 437.176 194.639Z" />
|
||||||
|
|
||||||
|
<path
|
||||||
|
android:strokeColor="#FFFFFF"
|
||||||
|
android:strokeWidth="60"
|
||||||
|
android:pathData="M443.562 503.105L178.152 767.54" />
|
||||||
|
|
||||||
|
<path
|
||||||
|
android:strokeColor="#FFFFFF"
|
||||||
|
android:strokeWidth="60"
|
||||||
|
android:pathData="M 376.496 773.551 L 171.435 568.49" />
|
||||||
|
|
||||||
|
</vector>
|
30
app/src/main/res/drawable-v24/ic_launcher_foreground.xml
Normal file
@ -0,0 +1,30 @@
|
|||||||
|
<vector xmlns:android="http://schemas.android.com/apk/res/android"
|
||||||
|
xmlns:aapt="http://schemas.android.com/aapt"
|
||||||
|
android:width="108dp"
|
||||||
|
android:height="108dp"
|
||||||
|
android:viewportWidth="108"
|
||||||
|
android:viewportHeight="108">
|
||||||
|
<path android:pathData="M31,63.928c0,0 6.4,-11 12.1,-13.1c7.2,-2.6 26,-1.4 26,-1.4l38.1,38.1L107,108.928l-32,-1L31,63.928z">
|
||||||
|
<aapt:attr name="android:fillColor">
|
||||||
|
<gradient
|
||||||
|
android:endX="85.84757"
|
||||||
|
android:endY="92.4963"
|
||||||
|
android:startX="42.9492"
|
||||||
|
android:startY="49.59793"
|
||||||
|
android:type="linear">
|
||||||
|
<item
|
||||||
|
android:color="#44000000"
|
||||||
|
android:offset="0.0" />
|
||||||
|
<item
|
||||||
|
android:color="#00000000"
|
||||||
|
android:offset="1.0" />
|
||||||
|
</gradient>
|
||||||
|
</aapt:attr>
|
||||||
|
</path>
|
||||||
|
<path
|
||||||
|
android:fillColor="#FFFFFF"
|
||||||
|
android:fillType="nonZero"
|
||||||
|
android:pathData="M65.3,45.828l3.8,-6.6c0.2,-0.4 0.1,-0.9 -0.3,-1.1c-0.4,-0.2 -0.9,-0.1 -1.1,0.3l-3.9,6.7c-6.3,-2.8 -13.4,-2.8 -19.7,0l-3.9,-6.7c-0.2,-0.4 -0.7,-0.5 -1.1,-0.3C38.8,38.328 38.7,38.828 38.9,39.228l3.8,6.6C36.2,49.428 31.7,56.028 31,63.928h46C76.3,56.028 71.8,49.428 65.3,45.828zM43.4,57.328c-0.8,0 -1.5,-0.5 -1.8,-1.2c-0.3,-0.7 -0.1,-1.5 0.4,-2.1c0.5,-0.5 1.4,-0.7 2.1,-0.4c0.7,0.3 1.2,1 1.2,1.8C45.3,56.528 44.5,57.328 43.4,57.328L43.4,57.328zM64.6,57.328c-0.8,0 -1.5,-0.5 -1.8,-1.2s-0.1,-1.5 0.4,-2.1c0.5,-0.5 1.4,-0.7 2.1,-0.4c0.7,0.3 1.2,1 1.2,1.8C66.5,56.528 65.6,57.328 64.6,57.328L64.6,57.328z"
|
||||||
|
android:strokeWidth="1"
|
||||||
|
android:strokeColor="#00000000" />
|
||||||
|
</vector>
|
7
app/src/main/res/drawable/calculate_btn.xml
Normal file
@ -0,0 +1,7 @@
|
|||||||
|
<?xml version="1.0" encoding="utf-8"?>
|
||||||
|
<shape android:shape="rectangle" xmlns:android="http://schemas.android.com/apk/res/android">
|
||||||
|
|
||||||
|
<solid android:color="@color/colorAccent"/>
|
||||||
|
<corners android:radius="15dp"/>
|
||||||
|
|
||||||
|
</shape>
|
170
app/src/main/res/drawable/ic_launcher_background.xml
Normal file
@ -0,0 +1,170 @@
|
|||||||
|
<?xml version="1.0" encoding="utf-8"?>
|
||||||
|
<vector xmlns:android="http://schemas.android.com/apk/res/android"
|
||||||
|
android:width="108dp"
|
||||||
|
android:height="108dp"
|
||||||
|
android:viewportWidth="108"
|
||||||
|
android:viewportHeight="108">
|
||||||
|
<path
|
||||||
|
android:fillColor="#3DDC84"
|
||||||
|
android:pathData="M0,0h108v108h-108z" />
|
||||||
|
<path
|
||||||
|
android:fillColor="#00000000"
|
||||||
|
android:pathData="M9,0L9,108"
|
||||||
|
android:strokeWidth="0.8"
|
||||||
|
android:strokeColor="#33FFFFFF" />
|
||||||
|
<path
|
||||||
|
android:fillColor="#00000000"
|
||||||
|
android:pathData="M19,0L19,108"
|
||||||
|
android:strokeWidth="0.8"
|
||||||
|
android:strokeColor="#33FFFFFF" />
|
||||||
|
<path
|
||||||
|
android:fillColor="#00000000"
|
||||||
|
android:pathData="M29,0L29,108"
|
||||||
|
android:strokeWidth="0.8"
|
||||||
|
android:strokeColor="#33FFFFFF" />
|
||||||
|
<path
|
||||||
|
android:fillColor="#00000000"
|
||||||
|
android:pathData="M39,0L39,108"
|
||||||
|
android:strokeWidth="0.8"
|
||||||
|
android:strokeColor="#33FFFFFF" />
|
||||||
|
<path
|
||||||
|
android:fillColor="#00000000"
|
||||||
|
android:pathData="M49,0L49,108"
|
||||||
|
android:strokeWidth="0.8"
|
||||||
|
android:strokeColor="#33FFFFFF" />
|
||||||
|
<path
|
||||||
|
android:fillColor="#00000000"
|
||||||
|
android:pathData="M59,0L59,108"
|
||||||
|
android:strokeWidth="0.8"
|
||||||
|
android:strokeColor="#33FFFFFF" />
|
||||||
|
<path
|
||||||
|
android:fillColor="#00000000"
|
||||||
|
android:pathData="M69,0L69,108"
|
||||||
|
android:strokeWidth="0.8"
|
||||||
|
android:strokeColor="#33FFFFFF" />
|
||||||
|
<path
|
||||||
|
android:fillColor="#00000000"
|
||||||
|
android:pathData="M79,0L79,108"
|
||||||
|
android:strokeWidth="0.8"
|
||||||
|
android:strokeColor="#33FFFFFF" />
|
||||||
|
<path
|
||||||
|
android:fillColor="#00000000"
|
||||||
|
android:pathData="M89,0L89,108"
|
||||||
|
android:strokeWidth="0.8"
|
||||||
|
android:strokeColor="#33FFFFFF" />
|
||||||
|
<path
|
||||||
|
android:fillColor="#00000000"
|
||||||
|
android:pathData="M99,0L99,108"
|
||||||
|
android:strokeWidth="0.8"
|
||||||
|
android:strokeColor="#33FFFFFF" />
|
||||||
|
<path
|
||||||
|
android:fillColor="#00000000"
|
||||||
|
android:pathData="M0,9L108,9"
|
||||||
|
android:strokeWidth="0.8"
|
||||||
|
android:strokeColor="#33FFFFFF" />
|
||||||
|
<path
|
||||||
|
android:fillColor="#00000000"
|
||||||
|
android:pathData="M0,19L108,19"
|
||||||
|
android:strokeWidth="0.8"
|
||||||
|
android:strokeColor="#33FFFFFF" />
|
||||||
|
<path
|
||||||
|
android:fillColor="#00000000"
|
||||||
|
android:pathData="M0,29L108,29"
|
||||||
|
android:strokeWidth="0.8"
|
||||||
|
android:strokeColor="#33FFFFFF" />
|
||||||
|
<path
|
||||||
|
android:fillColor="#00000000"
|
||||||
|
android:pathData="M0,39L108,39"
|
||||||
|
android:strokeWidth="0.8"
|
||||||
|
android:strokeColor="#33FFFFFF" />
|
||||||
|
<path
|
||||||
|
android:fillColor="#00000000"
|
||||||
|
android:pathData="M0,49L108,49"
|
||||||
|
android:strokeWidth="0.8"
|
||||||
|
android:strokeColor="#33FFFFFF" />
|
||||||
|
<path
|
||||||
|
android:fillColor="#00000000"
|
||||||
|
android:pathData="M0,59L108,59"
|
||||||
|
android:strokeWidth="0.8"
|
||||||
|
android:strokeColor="#33FFFFFF" />
|
||||||
|
<path
|
||||||
|
android:fillColor="#00000000"
|
||||||
|
android:pathData="M0,69L108,69"
|
||||||
|
android:strokeWidth="0.8"
|
||||||
|
android:strokeColor="#33FFFFFF" />
|
||||||
|
<path
|
||||||
|
android:fillColor="#00000000"
|
||||||
|
android:pathData="M0,79L108,79"
|
||||||
|
android:strokeWidth="0.8"
|
||||||
|
android:strokeColor="#33FFFFFF" />
|
||||||
|
<path
|
||||||
|
android:fillColor="#00000000"
|
||||||
|
android:pathData="M0,89L108,89"
|
||||||
|
android:strokeWidth="0.8"
|
||||||
|
android:strokeColor="#33FFFFFF" />
|
||||||
|
<path
|
||||||
|
android:fillColor="#00000000"
|
||||||
|
android:pathData="M0,99L108,99"
|
||||||
|
android:strokeWidth="0.8"
|
||||||
|
android:strokeColor="#33FFFFFF" />
|
||||||
|
<path
|
||||||
|
android:fillColor="#00000000"
|
||||||
|
android:pathData="M19,29L89,29"
|
||||||
|
android:strokeWidth="0.8"
|
||||||
|
android:strokeColor="#33FFFFFF" />
|
||||||
|
<path
|
||||||
|
android:fillColor="#00000000"
|
||||||
|
android:pathData="M19,39L89,39"
|
||||||
|
android:strokeWidth="0.8"
|
||||||
|
android:strokeColor="#33FFFFFF" />
|
||||||
|
<path
|
||||||
|
android:fillColor="#00000000"
|
||||||
|
android:pathData="M19,49L89,49"
|
||||||
|
android:strokeWidth="0.8"
|
||||||
|
android:strokeColor="#33FFFFFF" />
|
||||||
|
<path
|
||||||
|
android:fillColor="#00000000"
|
||||||
|
android:pathData="M19,59L89,59"
|
||||||
|
android:strokeWidth="0.8"
|
||||||
|
android:strokeColor="#33FFFFFF" />
|
||||||
|
<path
|
||||||
|
android:fillColor="#00000000"
|
||||||
|
android:pathData="M19,69L89,69"
|
||||||
|
android:strokeWidth="0.8"
|
||||||
|
android:strokeColor="#33FFFFFF" />
|
||||||
|
<path
|
||||||
|
android:fillColor="#00000000"
|
||||||
|
android:pathData="M19,79L89,79"
|
||||||
|
android:strokeWidth="0.8"
|
||||||
|
android:strokeColor="#33FFFFFF" />
|
||||||
|
<path
|
||||||
|
android:fillColor="#00000000"
|
||||||
|
android:pathData="M29,19L29,89"
|
||||||
|
android:strokeWidth="0.8"
|
||||||
|
android:strokeColor="#33FFFFFF" />
|
||||||
|
<path
|
||||||
|
android:fillColor="#00000000"
|
||||||
|
android:pathData="M39,19L39,89"
|
||||||
|
android:strokeWidth="0.8"
|
||||||
|
android:strokeColor="#33FFFFFF" />
|
||||||
|
<path
|
||||||
|
android:fillColor="#00000000"
|
||||||
|
android:pathData="M49,19L49,89"
|
||||||
|
android:strokeWidth="0.8"
|
||||||
|
android:strokeColor="#33FFFFFF" />
|
||||||
|
<path
|
||||||
|
android:fillColor="#00000000"
|
||||||
|
android:pathData="M59,19L59,89"
|
||||||
|
android:strokeWidth="0.8"
|
||||||
|
android:strokeColor="#33FFFFFF" />
|
||||||
|
<path
|
||||||
|
android:fillColor="#00000000"
|
||||||
|
android:pathData="M69,19L69,89"
|
||||||
|
android:strokeWidth="0.8"
|
||||||
|
android:strokeColor="#33FFFFFF" />
|
||||||
|
<path
|
||||||
|
android:fillColor="#00000000"
|
||||||
|
android:pathData="M79,19L79,89"
|
||||||
|
android:strokeWidth="0.8"
|
||||||
|
android:strokeColor="#33FFFFFF" />
|
||||||
|
</vector>
|
@ -1,10 +0,0 @@
|
|||||||
<vector xmlns:android="http://schemas.android.com/apk/res/android"
|
|
||||||
android:width="24dp"
|
|
||||||
android:height="24dp"
|
|
||||||
android:viewportWidth="24"
|
|
||||||
android:viewportHeight="24"
|
|
||||||
android:tint="?attr/colorControlNormal">
|
|
||||||
<path
|
|
||||||
android:fillColor="@color/colorAccent"
|
|
||||||
android:pathData="M8.35 1.55l-6.2 0.87L4.43 4.7c-1.55 1.6-2.54 3.67-2.84 5.89-0.3 2.29 0.16 4.61 1.32 6.61 1.15 2 2.94 3.57 5.07 4.45 2.14 0.89 4.5 1.04 6.74 0.45 2.23-0.6 4.2-1.92 5.6-3.75 1.41-1.84 2.18-4.08 2.18-6.4 0-2.3-0.76-4.55-2.17-6.39-1.41-1.83-3.38-3.15-5.61-3.75l-0.39 1.45c1.91 0.51 3.6 1.64 4.81 3.22 1.2 1.57 1.86 3.5 1.86 5.47 0 1.99-0.65 3.91-1.86 5.48-1.2 1.57-2.9 2.7-4.81 3.21-1.91 0.52-3.94 0.39-5.77-0.37-1.84-0.76-3.37-2.1-4.36-3.82-0.96-1.68-1.36-3.63-1.13-5.56 0.23-1.93 1.08-3.73 2.42-5.13l1.97 1.97 0.22-1.49 0.67-4.7Z"/>
|
|
||||||
</vector>
|
|
@ -1,10 +0,0 @@
|
|||||||
<vector xmlns:android="http://schemas.android.com/apk/res/android"
|
|
||||||
android:width="24dp"
|
|
||||||
android:height="24dp"
|
|
||||||
android:viewportWidth="24"
|
|
||||||
android:viewportHeight="24"
|
|
||||||
android:tint="?attr/colorControlNormal">
|
|
||||||
<path
|
|
||||||
android:fillColor="@color/colorAccent"
|
|
||||||
android:pathData="M18,16.08c-0.76,0 -1.44,0.3 -1.96,0.77L8.91,12.7c0.05,-0.23 0.09,-0.46 0.09,-0.7s-0.04,-0.47 -0.09,-0.7l7.05,-4.11c0.54,0.5 1.25,0.81 2.04,0.81 1.66,0 3,-1.34 3,-3s-1.34,-3 -3,-3 -3,1.34 -3,3c0,0.24 0.04,0.47 0.09,0.7L8.04,9.81C7.5,9.31 6.79,9 6,9c-1.66,0 -3,1.34 -3,3s1.34,3 3,3c0.79,0 1.5,-0.31 2.04,-0.81l7.12,4.16c-0.05,0.21 -0.08,0.43 -0.08,0.65 0,1.61 1.31,2.92 2.92,2.92 1.61,0 2.92,-1.31 2.92,-2.92s-1.31,-2.92 -2.92,-2.92z"/>
|
|
||||||
</vector>
|
|
BIN
app/src/main/res/drawable/logo.png
Normal file
After Width: | Height: | Size: 6.4 KiB |
@ -1,13 +0,0 @@
|
|||||||
<?xml version="1.0" encoding="utf-8"?>
|
|
||||||
<shape
|
|
||||||
xmlns:android="http://schemas.android.com/apk/res/android"
|
|
||||||
android:shape="rectangle">
|
|
||||||
|
|
||||||
<stroke android:width="2dp" android:color="@color/colorAccent" />
|
|
||||||
|
|
||||||
<size android:height="50dp"
|
|
||||||
android:width="50dp"/>
|
|
||||||
|
|
||||||
<corners android:radius="10dp"/>
|
|
||||||
|
|
||||||
</shape>
|
|
11
app/src/main/res/drawable/ripple.xml
Normal file
@ -0,0 +1,11 @@
|
|||||||
|
<?xml version="1.0" encoding="utf-8"?>
|
||||||
|
<ripple xmlns:android="http://schemas.android.com/apk/res/android"
|
||||||
|
xmlns:tools="http://schemas.android.com/tools"
|
||||||
|
android:color="@color/stepper"
|
||||||
|
tools:targetApi="lollipop"> <!-- ripple effect color -->
|
||||||
|
<item android:id="@android:id/background">
|
||||||
|
<shape android:shape="rectangle">
|
||||||
|
<solid android:color="#A6A6A6" /> <!-- background color -->
|
||||||
|
</shape>
|
||||||
|
</item>
|
||||||
|
</ripple>
|
@ -1,10 +1,11 @@
|
|||||||
<?xml version="1.0" encoding="utf-8"?>
|
<?xml version="1.0" encoding="utf-8"?>
|
||||||
<androidx.core.widget.NestedScrollView xmlns:android="http://schemas.android.com/apk/res/android"
|
<ScrollView xmlns:android="http://schemas.android.com/apk/res/android"
|
||||||
|
xmlns:app="http://schemas.android.com/apk/res-auto"
|
||||||
xmlns:tools="http://schemas.android.com/tools"
|
xmlns:tools="http://schemas.android.com/tools"
|
||||||
android:layout_width="match_parent"
|
android:layout_width="match_parent"
|
||||||
android:layout_height="match_parent"
|
android:layout_height="match_parent"
|
||||||
xmlns:app="http://schemas.android.com/apk/res-auto"
|
android:background="@color/background"
|
||||||
tools:context=".HomeFragment">
|
tools:context=".MainActivity">
|
||||||
|
|
||||||
<androidx.constraintlayout.widget.ConstraintLayout
|
<androidx.constraintlayout.widget.ConstraintLayout
|
||||||
android:layout_width="match_parent"
|
android:layout_width="match_parent"
|
||||||
@ -17,18 +18,17 @@
|
|||||||
android:layout_marginStart="16dp"
|
android:layout_marginStart="16dp"
|
||||||
android:layout_marginTop="32dp"
|
android:layout_marginTop="32dp"
|
||||||
android:layout_marginEnd="8dp"
|
android:layout_marginEnd="8dp"
|
||||||
app:cardBackgroundColor="@color/card_background"
|
|
||||||
app:cardCornerRadius="10dp"
|
app:cardCornerRadius="10dp"
|
||||||
|
app:layout_constraintHorizontal_weight="1"
|
||||||
|
app:cardBackgroundColor="@color/card_background"
|
||||||
app:layout_constraintBottom_toTopOf="@+id/cardView5"
|
app:layout_constraintBottom_toTopOf="@+id/cardView5"
|
||||||
app:layout_constraintEnd_toStartOf="@+id/cardView_female"
|
app:layout_constraintEnd_toStartOf="@+id/cardView_female"
|
||||||
app:layout_constraintHorizontal_chainStyle="spread"
|
app:layout_constraintHorizontal_chainStyle="spread"
|
||||||
app:layout_constraintHorizontal_weight="1"
|
|
||||||
app:layout_constraintStart_toStartOf="parent"
|
app:layout_constraintStart_toStartOf="parent"
|
||||||
app:layout_constraintTop_toTopOf="parent"
|
app:layout_constraintTop_toTopOf="parent">
|
||||||
app:layout_constraintVertical_bias="1.0">
|
|
||||||
|
|
||||||
<TextView
|
<TextView
|
||||||
android:id="@+id/maleTxt"
|
android:id="@+id/male"
|
||||||
android:layout_width="wrap_content"
|
android:layout_width="wrap_content"
|
||||||
android:layout_height="wrap_content"
|
android:layout_height="wrap_content"
|
||||||
android:layout_gravity="center|bottom"
|
android:layout_gravity="center|bottom"
|
||||||
@ -57,7 +57,7 @@
|
|||||||
app:layout_constraintTop_toTopOf="@+id/cardView_male">
|
app:layout_constraintTop_toTopOf="@+id/cardView_male">
|
||||||
|
|
||||||
<TextView
|
<TextView
|
||||||
android:id="@+id/femaleTxt"
|
android:id="@+id/female"
|
||||||
android:layout_width="wrap_content"
|
android:layout_width="wrap_content"
|
||||||
android:layout_height="wrap_content"
|
android:layout_height="wrap_content"
|
||||||
android:layout_gravity="center|bottom"
|
android:layout_gravity="center|bottom"
|
||||||
@ -116,9 +116,9 @@
|
|||||||
android:layout_height="wrap_content"
|
android:layout_height="wrap_content"
|
||||||
android:layout_marginTop="10dp"
|
android:layout_marginTop="10dp"
|
||||||
android:max="200"
|
android:max="200"
|
||||||
android:thumbTint="@color/colorAccent"
|
|
||||||
android:progressBackgroundTint="#888994"
|
android:progressBackgroundTint="#888994"
|
||||||
android:progressTint="@android:color/white" />
|
android:progressTint="@android:color/white"
|
||||||
|
tools:targetApi="lollipop" />
|
||||||
|
|
||||||
</LinearLayout>
|
</LinearLayout>
|
||||||
|
|
||||||
@ -154,7 +154,7 @@
|
|||||||
android:textStyle="bold" />
|
android:textStyle="bold" />
|
||||||
|
|
||||||
<TextView
|
<TextView
|
||||||
android:id="@+id/weight_txt"
|
android:id="@+id/weight"
|
||||||
android:layout_width="wrap_content"
|
android:layout_width="wrap_content"
|
||||||
android:layout_height="wrap_content"
|
android:layout_height="wrap_content"
|
||||||
android:layout_gravity="center"
|
android:layout_gravity="center"
|
||||||
@ -184,7 +184,7 @@
|
|||||||
android:layout_height="60dp"
|
android:layout_height="60dp"
|
||||||
android:contentDescription="@string/minus"
|
android:contentDescription="@string/minus"
|
||||||
android:padding="14dp"
|
android:padding="14dp"
|
||||||
app:srcCompat="@drawable/subtract" />
|
app:srcCompat="@drawable/substract" />
|
||||||
|
|
||||||
</RelativeLayout>
|
</RelativeLayout>
|
||||||
|
|
||||||
@ -271,7 +271,7 @@
|
|||||||
android:layout_height="60dp"
|
android:layout_height="60dp"
|
||||||
android:contentDescription="@string/minus"
|
android:contentDescription="@string/minus"
|
||||||
android:padding="14dp"
|
android:padding="14dp"
|
||||||
app:srcCompat="@drawable/subtract" />
|
app:srcCompat="@drawable/substract" />
|
||||||
|
|
||||||
</RelativeLayout>
|
</RelativeLayout>
|
||||||
|
|
||||||
@ -299,7 +299,7 @@
|
|||||||
|
|
||||||
</androidx.cardview.widget.CardView>
|
</androidx.cardview.widget.CardView>
|
||||||
|
|
||||||
<com.google.android.material.button.MaterialButton
|
<Button
|
||||||
android:id="@+id/calculate"
|
android:id="@+id/calculate"
|
||||||
android:layout_width="match_parent"
|
android:layout_width="match_parent"
|
||||||
android:layout_height="55dp"
|
android:layout_height="55dp"
|
||||||
@ -307,8 +307,7 @@
|
|||||||
android:layout_marginTop="16dp"
|
android:layout_marginTop="16dp"
|
||||||
android:layout_marginRight="16dp"
|
android:layout_marginRight="16dp"
|
||||||
android:layout_marginBottom="24dp"
|
android:layout_marginBottom="24dp"
|
||||||
app:cornerRadius="7dp"
|
android:background="@drawable/calculate_btn"
|
||||||
android:backgroundTint="@color/colorAccent"
|
|
||||||
android:text="@string/calculate"
|
android:text="@string/calculate"
|
||||||
android:textColor="@android:color/white"
|
android:textColor="@android:color/white"
|
||||||
android:textSize="17sp"
|
android:textSize="17sp"
|
||||||
@ -321,4 +320,4 @@
|
|||||||
|
|
||||||
</androidx.constraintlayout.widget.ConstraintLayout>
|
</androidx.constraintlayout.widget.ConstraintLayout>
|
||||||
|
|
||||||
</androidx.core.widget.NestedScrollView>
|
</ScrollView>
|
@ -1,21 +1,333 @@
|
|||||||
<?xml version="1.0" encoding="utf-8"?>
|
<?xml version="1.0" encoding="utf-8"?>
|
||||||
<androidx.constraintlayout.widget.ConstraintLayout xmlns:android="http://schemas.android.com/apk/res/android"
|
<ScrollView xmlns:android="http://schemas.android.com/apk/res/android"
|
||||||
xmlns:app="http://schemas.android.com/apk/res-auto"
|
xmlns:app="http://schemas.android.com/apk/res-auto"
|
||||||
xmlns:tools="http://schemas.android.com/tools"
|
xmlns:tools="http://schemas.android.com/tools"
|
||||||
android:layout_width="match_parent"
|
android:layout_width="match_parent"
|
||||||
android:layout_height="match_parent"
|
android:layout_height="match_parent"
|
||||||
|
android:background="@color/background"
|
||||||
tools:context=".MainActivity">
|
tools:context=".MainActivity">
|
||||||
|
|
||||||
<androidx.fragment.app.FragmentContainerView
|
<androidx.constraintlayout.widget.ConstraintLayout
|
||||||
android:id="@+id/fragmentContainer"
|
|
||||||
android:layout_width="match_parent"
|
android:layout_width="match_parent"
|
||||||
android:layout_height="match_parent"
|
android:layout_height="wrap_content">
|
||||||
app:defaultNavHost="true"
|
|
||||||
android:name="androidx.navigation.fragment.NavHostFragment"
|
|
||||||
app:layout_constraintBottom_toBottomOf="parent"
|
|
||||||
app:layout_constraintEnd_toEndOf="parent"
|
|
||||||
app:layout_constraintStart_toStartOf="parent"
|
|
||||||
app:layout_constraintTop_toTopOf="parent"
|
|
||||||
app:navGraph="@navigation/nav_graph"/>
|
|
||||||
|
|
||||||
</androidx.constraintlayout.widget.ConstraintLayout>
|
<androidx.cardview.widget.CardView
|
||||||
|
android:id="@+id/cardView_male"
|
||||||
|
android:layout_width="0dp"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
android:layout_marginStart="16dp"
|
||||||
|
android:layout_marginLeft="16dp"
|
||||||
|
android:layout_marginTop="32dp"
|
||||||
|
android:layout_marginEnd="8dp"
|
||||||
|
android:layout_marginRight="8dp"
|
||||||
|
app:cardCornerRadius="10dp"
|
||||||
|
app:layout_constraintHorizontal_weight="1"
|
||||||
|
app:cardBackgroundColor="@color/card_background"
|
||||||
|
app:layout_constraintBottom_toTopOf="@+id/cardView5"
|
||||||
|
app:layout_constraintEnd_toStartOf="@+id/cardView_female"
|
||||||
|
app:layout_constraintHorizontal_chainStyle="spread"
|
||||||
|
app:layout_constraintStart_toStartOf="parent"
|
||||||
|
app:layout_constraintTop_toTopOf="parent">
|
||||||
|
|
||||||
|
<TextView
|
||||||
|
android:id="@+id/male"
|
||||||
|
android:layout_width="wrap_content"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
android:layout_gravity="center|bottom"
|
||||||
|
android:drawablePadding="5sp"
|
||||||
|
android:padding="20dp"
|
||||||
|
android:text="@string/male"
|
||||||
|
android:textAlignment="center"
|
||||||
|
android:textColor="@color/tint"
|
||||||
|
android:textSize="20sp"
|
||||||
|
android:textStyle="bold"
|
||||||
|
app:drawableTopCompat="@drawable/male" />
|
||||||
|
|
||||||
|
</androidx.cardview.widget.CardView>
|
||||||
|
|
||||||
|
<androidx.cardview.widget.CardView
|
||||||
|
android:id="@+id/cardView_female"
|
||||||
|
android:layout_width="0dp"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
android:layout_marginEnd="16dp"
|
||||||
|
android:layout_marginRight="16dp"
|
||||||
|
app:layout_constraintHorizontal_weight="1"
|
||||||
|
app:cardBackgroundColor="@color/card_background"
|
||||||
|
app:cardCornerRadius="10dp"
|
||||||
|
app:layout_constraintBottom_toBottomOf="@+id/cardView_male"
|
||||||
|
app:layout_constraintEnd_toEndOf="parent"
|
||||||
|
app:layout_constraintStart_toEndOf="@+id/cardView_male"
|
||||||
|
app:layout_constraintTop_toTopOf="@+id/cardView_male">
|
||||||
|
|
||||||
|
<TextView
|
||||||
|
android:id="@+id/female"
|
||||||
|
android:layout_width="wrap_content"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
android:layout_gravity="center|bottom"
|
||||||
|
android:drawablePadding="5sp"
|
||||||
|
android:padding="20dp"
|
||||||
|
android:text="@string/female"
|
||||||
|
android:textAlignment="center"
|
||||||
|
android:textColor="@color/tint"
|
||||||
|
android:textSize="20sp"
|
||||||
|
android:textStyle="bold"
|
||||||
|
app:drawableTopCompat="@drawable/female" />
|
||||||
|
|
||||||
|
</androidx.cardview.widget.CardView>
|
||||||
|
|
||||||
|
<androidx.cardview.widget.CardView
|
||||||
|
android:id="@+id/cardView5"
|
||||||
|
android:layout_width="match_parent"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
android:layout_margin="16dp"
|
||||||
|
app:cardBackgroundColor="@color/card_background"
|
||||||
|
app:cardCornerRadius="10dp"
|
||||||
|
app:layout_constraintBottom_toTopOf="@+id/cardView3"
|
||||||
|
app:layout_constraintHorizontal_chainStyle="spread"
|
||||||
|
app:layout_constraintLeft_toLeftOf="parent"
|
||||||
|
app:layout_constraintRight_toRightOf="parent"
|
||||||
|
app:layout_constraintTop_toBottomOf="@+id/cardView_male">
|
||||||
|
|
||||||
|
<LinearLayout
|
||||||
|
android:layout_width="match_parent"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
android:gravity="center"
|
||||||
|
android:orientation="vertical"
|
||||||
|
android:padding="20dp">
|
||||||
|
|
||||||
|
<TextView
|
||||||
|
android:layout_width="wrap_content"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
android:text="@string/height"
|
||||||
|
android:textColor="#8D8E99"
|
||||||
|
android:textSize="20sp"
|
||||||
|
android:textStyle="bold" />
|
||||||
|
|
||||||
|
<TextView
|
||||||
|
android:id="@+id/height_txt"
|
||||||
|
android:layout_width="wrap_content"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
android:text="@string/_0cm"
|
||||||
|
android:textColor="@android:color/white"
|
||||||
|
android:textSize="50sp"
|
||||||
|
android:textStyle="bold" />
|
||||||
|
|
||||||
|
<SeekBar
|
||||||
|
android:id="@+id/Seekbar"
|
||||||
|
style="?android:attr/progressBarStyleHorizontal"
|
||||||
|
android:layout_width="match_parent"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
android:layout_marginTop="10dp"
|
||||||
|
android:max="200"
|
||||||
|
android:progressBackgroundTint="#888994"
|
||||||
|
android:progressTint="@android:color/white"
|
||||||
|
tools:targetApi="lollipop" />
|
||||||
|
|
||||||
|
</LinearLayout>
|
||||||
|
|
||||||
|
</androidx.cardview.widget.CardView>
|
||||||
|
|
||||||
|
<androidx.cardview.widget.CardView
|
||||||
|
android:id="@+id/cardView3"
|
||||||
|
android:layout_width="0dp"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
android:layout_marginStart="16dp"
|
||||||
|
android:layout_marginLeft="16dp"
|
||||||
|
android:layout_marginEnd="8dp"
|
||||||
|
android:layout_marginRight="8dp"
|
||||||
|
app:layout_constraintHorizontal_weight="1"
|
||||||
|
app:cardBackgroundColor="@color/card_background"
|
||||||
|
app:cardCornerRadius="10dp"
|
||||||
|
app:layout_constraintBottom_toTopOf="@+id/calculate"
|
||||||
|
app:layout_constraintEnd_toStartOf="@+id/cardView4"
|
||||||
|
app:layout_constraintStart_toStartOf="parent"
|
||||||
|
app:layout_constraintTop_toBottomOf="@+id/cardView5">
|
||||||
|
|
||||||
|
<LinearLayout
|
||||||
|
android:layout_width="match_parent"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
android:gravity="center_horizontal"
|
||||||
|
android:orientation="vertical"
|
||||||
|
android:padding="15dp">
|
||||||
|
|
||||||
|
<TextView
|
||||||
|
android:layout_width="wrap_content"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
android:text="@string/weight"
|
||||||
|
android:textColor="#8D8E99"
|
||||||
|
android:textSize="20sp"
|
||||||
|
android:textStyle="bold" />
|
||||||
|
|
||||||
|
<TextView
|
||||||
|
android:id="@+id/weight"
|
||||||
|
android:layout_width="wrap_content"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
android:layout_gravity="center"
|
||||||
|
android:text="@string/_50"
|
||||||
|
android:textColor="@android:color/white"
|
||||||
|
android:textSize="50sp"
|
||||||
|
android:textStyle="bold" />
|
||||||
|
|
||||||
|
<LinearLayout
|
||||||
|
android:layout_width="wrap_content"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
android:layout_marginTop="8dp"
|
||||||
|
android:baselineAligned="false"
|
||||||
|
android:gravity="center_horizontal"
|
||||||
|
android:weightSum="2">
|
||||||
|
|
||||||
|
<RelativeLayout
|
||||||
|
android:id="@+id/weight_minus"
|
||||||
|
android:layout_width="wrap_content"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
android:layout_marginEnd="5dp"
|
||||||
|
android:layout_marginRight="5dp"
|
||||||
|
android:layout_weight="1"
|
||||||
|
android:background="@drawable/stepper_background">
|
||||||
|
|
||||||
|
<ImageView
|
||||||
|
android:layout_width="60dp"
|
||||||
|
android:layout_height="60dp"
|
||||||
|
android:contentDescription="@string/minus"
|
||||||
|
android:padding="14dp"
|
||||||
|
app:srcCompat="@drawable/substract" />
|
||||||
|
|
||||||
|
</RelativeLayout>
|
||||||
|
|
||||||
|
|
||||||
|
<RelativeLayout
|
||||||
|
android:id="@+id/weight_plus"
|
||||||
|
android:layout_width="wrap_content"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
android:layout_marginStart="5dp"
|
||||||
|
android:layout_marginLeft="5dp"
|
||||||
|
android:layout_weight="1"
|
||||||
|
android:background="@drawable/stepper_background">
|
||||||
|
|
||||||
|
<ImageView
|
||||||
|
android:layout_width="60dp"
|
||||||
|
android:layout_height="60dp"
|
||||||
|
android:contentDescription="@string/plus"
|
||||||
|
android:padding="3dp"
|
||||||
|
app:srcCompat="@drawable/ic_add" />
|
||||||
|
|
||||||
|
</RelativeLayout>
|
||||||
|
|
||||||
|
</LinearLayout>
|
||||||
|
|
||||||
|
</LinearLayout>
|
||||||
|
|
||||||
|
</androidx.cardview.widget.CardView>
|
||||||
|
|
||||||
|
<androidx.cardview.widget.CardView
|
||||||
|
android:id="@+id/cardView4"
|
||||||
|
android:layout_width="0dp"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
android:layout_marginEnd="16dp"
|
||||||
|
android:layout_marginRight="16dp"
|
||||||
|
app:cardBackgroundColor="@color/card_background"
|
||||||
|
app:cardCornerRadius="10dp"
|
||||||
|
app:layout_constraintHorizontal_weight="1"
|
||||||
|
app:layout_constraintBottom_toBottomOf="@+id/cardView3"
|
||||||
|
app:layout_constraintEnd_toEndOf="parent"
|
||||||
|
app:layout_constraintStart_toEndOf="@+id/cardView3"
|
||||||
|
app:layout_constraintTop_toTopOf="@+id/cardView3">
|
||||||
|
|
||||||
|
<LinearLayout
|
||||||
|
android:layout_width="match_parent"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
android:gravity="center_horizontal"
|
||||||
|
android:orientation="vertical"
|
||||||
|
android:padding="15dp">
|
||||||
|
|
||||||
|
<TextView
|
||||||
|
android:layout_width="wrap_content"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
android:gravity="center"
|
||||||
|
android:text="@string/age"
|
||||||
|
android:textColor="#8D8E99"
|
||||||
|
android:textSize="20sp"
|
||||||
|
android:textStyle="bold" />
|
||||||
|
|
||||||
|
<TextView
|
||||||
|
android:id="@+id/age"
|
||||||
|
android:layout_width="wrap_content"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
android:text="@string/_19"
|
||||||
|
android:textColor="@android:color/white"
|
||||||
|
android:textSize="50sp"
|
||||||
|
android:textStyle="bold" />
|
||||||
|
|
||||||
|
<LinearLayout
|
||||||
|
android:layout_width="wrap_content"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
android:layout_marginTop="8dp"
|
||||||
|
android:baselineAligned="false"
|
||||||
|
android:gravity="center_horizontal"
|
||||||
|
android:weightSum="2">
|
||||||
|
|
||||||
|
<RelativeLayout
|
||||||
|
android:id="@+id/age_minus"
|
||||||
|
android:layout_width="wrap_content"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
android:layout_marginEnd="5dp"
|
||||||
|
android:layout_marginRight="5dp"
|
||||||
|
android:layout_weight="1"
|
||||||
|
android:background="@drawable/stepper_background">
|
||||||
|
|
||||||
|
<ImageView
|
||||||
|
android:layout_width="60dp"
|
||||||
|
android:layout_height="60dp"
|
||||||
|
android:contentDescription="@string/minus"
|
||||||
|
android:padding="14dp"
|
||||||
|
app:srcCompat="@drawable/substract" />
|
||||||
|
|
||||||
|
</RelativeLayout>
|
||||||
|
|
||||||
|
|
||||||
|
<RelativeLayout
|
||||||
|
android:id="@+id/age_plus"
|
||||||
|
android:layout_width="wrap_content"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
android:layout_marginStart="5dp"
|
||||||
|
android:layout_marginLeft="5dp"
|
||||||
|
android:layout_weight="1"
|
||||||
|
android:background="@drawable/stepper_background">
|
||||||
|
|
||||||
|
<ImageView
|
||||||
|
android:layout_width="60dp"
|
||||||
|
android:layout_height="60dp"
|
||||||
|
android:contentDescription="@string/plus"
|
||||||
|
android:padding="3dp"
|
||||||
|
app:srcCompat="@drawable/ic_add" />
|
||||||
|
|
||||||
|
</RelativeLayout>
|
||||||
|
|
||||||
|
</LinearLayout>
|
||||||
|
|
||||||
|
</LinearLayout>
|
||||||
|
|
||||||
|
</androidx.cardview.widget.CardView>
|
||||||
|
|
||||||
|
<Button
|
||||||
|
android:id="@+id/calculate"
|
||||||
|
android:layout_width="match_parent"
|
||||||
|
android:layout_height="55dp"
|
||||||
|
android:layout_marginLeft="16dp"
|
||||||
|
android:layout_marginTop="16dp"
|
||||||
|
android:layout_marginRight="16dp"
|
||||||
|
android:layout_marginBottom="24dp"
|
||||||
|
android:background="@drawable/calculate_btn"
|
||||||
|
android:text="@string/calculate"
|
||||||
|
android:textColor="@android:color/white"
|
||||||
|
android:textSize="17sp"
|
||||||
|
android:textStyle="bold"
|
||||||
|
app:layout_constraintBottom_toBottomOf="parent"
|
||||||
|
app:layout_constraintEnd_toEndOf="parent"
|
||||||
|
app:layout_constraintHorizontal_bias="0.5"
|
||||||
|
app:layout_constraintStart_toStartOf="parent"
|
||||||
|
app:layout_constraintTop_toBottomOf="@+id/cardView3" />
|
||||||
|
|
||||||
|
</androidx.constraintlayout.widget.ConstraintLayout>
|
||||||
|
|
||||||
|
</ScrollView>
|
@ -4,20 +4,21 @@
|
|||||||
xmlns:tools="http://schemas.android.com/tools"
|
xmlns:tools="http://schemas.android.com/tools"
|
||||||
android:layout_width="match_parent"
|
android:layout_width="match_parent"
|
||||||
android:layout_height="match_parent"
|
android:layout_height="match_parent"
|
||||||
tools:context=".ResultFragment">
|
android:background="@color/background"
|
||||||
|
tools:context=".ResultActivity">
|
||||||
|
|
||||||
<TextView
|
<TextView
|
||||||
android:id="@+id/textView"
|
android:id="@+id/textView"
|
||||||
android:layout_width="wrap_content"
|
android:layout_width="wrap_content"
|
||||||
android:layout_height="wrap_content"
|
android:layout_height="wrap_content"
|
||||||
android:layout_margin="16dp"
|
android:layout_margin="16dp"
|
||||||
android:layout_marginEnd="16dp"
|
android:layout_marginLeft="16dp"
|
||||||
|
android:layout_marginRight="16dp"
|
||||||
android:text="@string/your_result"
|
android:text="@string/your_result"
|
||||||
android:textColor="@android:color/white"
|
android:textColor="@android:color/white"
|
||||||
android:textSize="30sp"
|
android:textSize="40sp"
|
||||||
android:textStyle="bold"
|
android:textStyle="bold"
|
||||||
app:layout_constraintBottom_toTopOf="@+id/result_card"
|
app:layout_constraintBottom_toTopOf="@+id/result_card"
|
||||||
app:layout_constraintEnd_toEndOf="parent"
|
|
||||||
app:layout_constraintStart_toStartOf="parent"
|
app:layout_constraintStart_toStartOf="parent"
|
||||||
app:layout_constraintTop_toTopOf="parent" />
|
app:layout_constraintTop_toTopOf="parent" />
|
||||||
|
|
||||||
@ -29,9 +30,8 @@
|
|||||||
android:layout_marginTop="16dp"
|
android:layout_marginTop="16dp"
|
||||||
android:layout_marginRight="16dp"
|
android:layout_marginRight="16dp"
|
||||||
app:cardBackgroundColor="@color/card_background"
|
app:cardBackgroundColor="@color/card_background"
|
||||||
app:cardCornerRadius="10sp"
|
app:cardCornerRadius="20sp"
|
||||||
app:layout_constraintEnd_toEndOf="parent"
|
app:layout_constraintEnd_toEndOf="parent"
|
||||||
app:layout_constraintHorizontal_bias="0.5"
|
|
||||||
app:layout_constraintStart_toStartOf="parent"
|
app:layout_constraintStart_toStartOf="parent"
|
||||||
app:layout_constraintTop_toBottomOf="@+id/textView">
|
app:layout_constraintTop_toBottomOf="@+id/textView">
|
||||||
|
|
||||||
@ -46,8 +46,8 @@
|
|||||||
android:id="@+id/condition"
|
android:id="@+id/condition"
|
||||||
android:layout_width="wrap_content"
|
android:layout_width="wrap_content"
|
||||||
android:layout_height="wrap_content"
|
android:layout_height="wrap_content"
|
||||||
android:layout_marginTop="15dp"
|
android:layout_marginTop="20sp"
|
||||||
android:textColor="@color/green"
|
android:textColor="#5ADC65"
|
||||||
android:textSize="20sp"
|
android:textSize="20sp"
|
||||||
android:textStyle="bold" />
|
android:textStyle="bold" />
|
||||||
|
|
||||||
@ -55,7 +55,7 @@
|
|||||||
android:id="@+id/your_bmi"
|
android:id="@+id/your_bmi"
|
||||||
android:layout_width="wrap_content"
|
android:layout_width="wrap_content"
|
||||||
android:layout_height="wrap_content"
|
android:layout_height="wrap_content"
|
||||||
android:layout_marginTop="8dp"
|
android:layout_marginTop="10dp"
|
||||||
android:textColor="@android:color/white"
|
android:textColor="@android:color/white"
|
||||||
android:textSize="50sp"
|
android:textSize="50sp"
|
||||||
android:textStyle="bold" />
|
android:textStyle="bold" />
|
||||||
@ -66,100 +66,65 @@
|
|||||||
android:layout_marginTop="16dp"
|
android:layout_marginTop="16dp"
|
||||||
android:text="@string/normal_bmi_range"
|
android:text="@string/normal_bmi_range"
|
||||||
android:textColor="#8D8E99"
|
android:textColor="#8D8E99"
|
||||||
android:textSize="22sp"
|
android:textSize="21sp"
|
||||||
android:textStyle="bold" />
|
android:textStyle="bold" />
|
||||||
|
|
||||||
<TextView
|
<TextView
|
||||||
android:layout_width="wrap_content"
|
android:layout_width="wrap_content"
|
||||||
android:layout_height="wrap_content"
|
android:layout_height="wrap_content"
|
||||||
android:layout_marginTop="5dp"
|
|
||||||
android:text="@string/_18_5_25_kg_m2"
|
android:text="@string/_18_5_25_kg_m2"
|
||||||
android:textColor="@android:color/white"
|
android:textColor="@android:color/white"
|
||||||
android:textSize="18sp" />
|
android:textSize="20sp"
|
||||||
|
android:textStyle="bold" />
|
||||||
|
|
||||||
<LinearLayout
|
<TextView
|
||||||
|
android:layout_width="wrap_content"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
android:layout_marginTop="16dp"
|
||||||
|
android:text="@string/your_age"
|
||||||
|
android:textColor="@color/colorAccent"
|
||||||
|
android:textSize="20sp"
|
||||||
|
android:textStyle="bold" />
|
||||||
|
|
||||||
|
<TextView
|
||||||
|
android:id="@+id/age"
|
||||||
|
android:layout_width="wrap_content"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
android:textColor="@android:color/white"
|
||||||
|
android:textSize="20sp" />
|
||||||
|
|
||||||
|
<TextView
|
||||||
|
android:id="@+id/category"
|
||||||
android:layout_width="wrap_content"
|
android:layout_width="wrap_content"
|
||||||
android:layout_height="wrap_content"
|
android:layout_height="wrap_content"
|
||||||
android:layout_marginTop="16dp"
|
android:layout_marginTop="16dp"
|
||||||
android:layout_marginBottom="8dp"
|
android:layout_marginBottom="8dp"
|
||||||
android:gravity="center"
|
android:gravity="center_horizontal"
|
||||||
android:orientation="horizontal">
|
android:textColor="@android:color/white"
|
||||||
|
android:textSize="20sp" />
|
||||||
<TextView
|
|
||||||
android:layout_width="wrap_content"
|
|
||||||
android:layout_height="wrap_content"
|
|
||||||
android:text="@string/your_age"
|
|
||||||
android:textColor="@color/colorAccent"
|
|
||||||
android:textSize="20sp"
|
|
||||||
android:textStyle="bold" />
|
|
||||||
|
|
||||||
<TextView
|
|
||||||
android:id="@+id/ageTxt"
|
|
||||||
android:layout_width="wrap_content"
|
|
||||||
android:layout_height="wrap_content"
|
|
||||||
android:layout_marginStart="5dp"
|
|
||||||
android:textColor="@android:color/white"
|
|
||||||
android:textSize="20sp" />
|
|
||||||
|
|
||||||
</LinearLayout>
|
|
||||||
|
|
||||||
</LinearLayout>
|
</LinearLayout>
|
||||||
|
|
||||||
</androidx.cardview.widget.CardView>
|
</androidx.cardview.widget.CardView>
|
||||||
|
|
||||||
<androidx.cardview.widget.CardView
|
<Button
|
||||||
android:id="@+id/sug_container"
|
|
||||||
android:layout_width="match_parent"
|
|
||||||
android:layout_height="wrap_content"
|
|
||||||
android:layout_marginLeft="16dp"
|
|
||||||
android:layout_marginTop="16dp"
|
|
||||||
android:layout_marginRight="16dp"
|
|
||||||
app:cardCornerRadius="10sp"
|
|
||||||
app:cardBackgroundColor="@color/card_background"
|
|
||||||
app:layout_constraintEnd_toEndOf="parent"
|
|
||||||
app:layout_constraintStart_toStartOf="parent"
|
|
||||||
app:layout_constraintTop_toBottomOf="@+id/result_card">
|
|
||||||
|
|
||||||
<TextView
|
|
||||||
android:id="@+id/suggestion"
|
|
||||||
android:layout_width="match_parent"
|
|
||||||
android:layout_height="match_parent"
|
|
||||||
android:padding="20sp"/>
|
|
||||||
|
|
||||||
</androidx.cardview.widget.CardView>
|
|
||||||
|
|
||||||
<ImageView
|
|
||||||
android:id="@+id/share"
|
|
||||||
android:layout_width="wrap_content"
|
|
||||||
android:layout_height="wrap_content"
|
|
||||||
android:layout_marginBottom="32dp"
|
|
||||||
android:padding="15dp"
|
|
||||||
android:src="@drawable/ic_share"
|
|
||||||
android:contentDescription="@string/share"
|
|
||||||
android:background="@drawable/result_btn"
|
|
||||||
app:layout_constraintBottom_toBottomOf="parent"
|
|
||||||
app:layout_constraintEnd_toStartOf="@+id/recalculate"
|
|
||||||
app:layout_constraintHorizontal_bias="0.5"
|
|
||||||
app:layout_constraintStart_toStartOf="parent"
|
|
||||||
app:layout_constraintTop_toBottomOf="@+id/sug_container"
|
|
||||||
app:layout_constraintVertical_bias="1.0" />
|
|
||||||
|
|
||||||
<ImageView
|
|
||||||
android:id="@+id/recalculate"
|
android:id="@+id/recalculate"
|
||||||
android:layout_width="wrap_content"
|
android:layout_width="match_parent"
|
||||||
android:layout_height="wrap_content"
|
android:layout_height="55dp"
|
||||||
|
android:layout_marginStart="16dp"
|
||||||
|
android:layout_marginLeft="16dp"
|
||||||
|
android:layout_marginTop="32dp"
|
||||||
|
android:layout_marginEnd="16dp"
|
||||||
|
android:layout_marginRight="16dp"
|
||||||
android:layout_marginBottom="32dp"
|
android:layout_marginBottom="32dp"
|
||||||
android:padding="15dp"
|
android:background="@drawable/calculate_btn"
|
||||||
android:contentDescription="@string/recalculate"
|
android:text="@string/recalculate"
|
||||||
android:src="@drawable/ic_refresh"
|
android:textColor="@android:color/white"
|
||||||
android:background="@drawable/result_btn"
|
android:textSize="17sp"
|
||||||
|
android:textStyle="bold"
|
||||||
app:layout_constraintBottom_toBottomOf="parent"
|
app:layout_constraintBottom_toBottomOf="parent"
|
||||||
app:layout_constraintEnd_toEndOf="parent"
|
app:layout_constraintEnd_toEndOf="parent"
|
||||||
app:layout_constraintHorizontal_bias="0.5"
|
app:layout_constraintStart_toStartOf="parent"/>
|
||||||
app:layout_constraintStart_toEndOf="@+id/share"
|
|
||||||
app:layout_constraintTop_toBottomOf="@+id/sug_container"
|
|
||||||
app:layout_constraintVertical_bias="1.0"
|
|
||||||
app:shapeAppearanceOverlay="@style/circleImageView"/>
|
|
||||||
|
|
||||||
|
|
||||||
</androidx.constraintlayout.widget.ConstraintLayout>
|
</androidx.constraintlayout.widget.ConstraintLayout>
|
20
app/src/main/res/layout/activity_splash.xml
Normal file
@ -0,0 +1,20 @@
|
|||||||
|
<?xml version="1.0" encoding="utf-8"?>
|
||||||
|
<androidx.constraintlayout.widget.ConstraintLayout xmlns:android="http://schemas.android.com/apk/res/android"
|
||||||
|
xmlns:app="http://schemas.android.com/apk/res-auto"
|
||||||
|
xmlns:tools="http://schemas.android.com/tools"
|
||||||
|
android:layout_width="match_parent"
|
||||||
|
android:layout_height="match_parent"
|
||||||
|
android:background="@color/background"
|
||||||
|
tools:context=".SplashActivity">
|
||||||
|
|
||||||
|
<ImageView
|
||||||
|
android:layout_width="wrap_content"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
android:src="@drawable/logo"
|
||||||
|
android:contentDescription="@string/app_name"
|
||||||
|
app:layout_constraintBottom_toBottomOf="parent"
|
||||||
|
app:layout_constraintEnd_toEndOf="parent"
|
||||||
|
app:layout_constraintStart_toStartOf="parent"
|
||||||
|
app:layout_constraintTop_toTopOf="parent" />
|
||||||
|
|
||||||
|
</androidx.constraintlayout.widget.ConstraintLayout>
|
@ -1,7 +1,5 @@
|
|||||||
<?xml version="1.0" encoding="utf-8"?>
|
<?xml version="1.0" encoding="utf-8"?>
|
||||||
<adaptive-icon xmlns:android="http://schemas.android.com/apk/res/android">
|
<adaptive-icon xmlns:android="http://schemas.android.com/apk/res/android">
|
||||||
|
<background android:drawable="@drawable/ic_launcher_background" />
|
||||||
<background android:drawable="@color/ic_launcher_background"/>
|
<foreground android:drawable="@drawable/ic_launcher_foreground" />
|
||||||
<foreground android:drawable="@drawable/ic_launcher_foreground"/>
|
|
||||||
|
|
||||||
</adaptive-icon>
|
</adaptive-icon>
|
@ -1,7 +1,5 @@
|
|||||||
<?xml version="1.0" encoding="utf-8"?>
|
<?xml version="1.0" encoding="utf-8"?>
|
||||||
<adaptive-icon xmlns:android="http://schemas.android.com/apk/res/android">
|
<adaptive-icon xmlns:android="http://schemas.android.com/apk/res/android">
|
||||||
|
<background android:drawable="@drawable/ic_launcher_background" />
|
||||||
<background android:drawable="@color/ic_launcher_background"/>
|
<foreground android:drawable="@drawable/ic_launcher_foreground" />
|
||||||
<foreground android:drawable="@drawable/ic_launcher_foreground"/>
|
|
||||||
|
|
||||||
</adaptive-icon>
|
</adaptive-icon>
|
Before Width: | Height: | Size: 1.7 KiB After Width: | Height: | Size: 3.5 KiB |
Before Width: | Height: | Size: 3.4 KiB After Width: | Height: | Size: 5.2 KiB |
Before Width: | Height: | Size: 1.2 KiB After Width: | Height: | Size: 2.6 KiB |
Before Width: | Height: | Size: 2.1 KiB After Width: | Height: | Size: 3.3 KiB |
Before Width: | Height: | Size: 2.5 KiB After Width: | Height: | Size: 4.8 KiB |
Before Width: | Height: | Size: 4.9 KiB After Width: | Height: | Size: 7.3 KiB |
Before Width: | Height: | Size: 3.7 KiB After Width: | Height: | Size: 7.7 KiB |
Before Width: | Height: | Size: 7.7 KiB After Width: | Height: | Size: 12 KiB |
Before Width: | Height: | Size: 5.1 KiB After Width: | Height: | Size: 10 KiB |
Before Width: | Height: | Size: 11 KiB After Width: | Height: | Size: 16 KiB |
@ -1,35 +0,0 @@
|
|||||||
<?xml version="1.0" encoding="utf-8"?>
|
|
||||||
<navigation xmlns:android="http://schemas.android.com/apk/res/android"
|
|
||||||
xmlns:app="http://schemas.android.com/apk/res-auto"
|
|
||||||
xmlns:tools="http://schemas.android.com/tools"
|
|
||||||
android:id="@+id/nav_graph"
|
|
||||||
app:startDestination="@id/homeFragment">
|
|
||||||
|
|
||||||
<fragment
|
|
||||||
android:id="@+id/homeFragment"
|
|
||||||
android:name="com.tharun.bmicalculator.HomeFragment"
|
|
||||||
android:label="fragment_home"
|
|
||||||
tools:layout="@layout/fragment_home" >
|
|
||||||
<action
|
|
||||||
android:id="@+id/action_homeFragment_to_resultFragment"
|
|
||||||
app:destination="@id/resultFragment"
|
|
||||||
app:enterAnim="@anim/slide_in_right"
|
|
||||||
app:exitAnim="@anim/slide_out_left"
|
|
||||||
app:popEnterAnim="@anim/slide_in_left"
|
|
||||||
app:popExitAnim="@anim/slide_out_right" />
|
|
||||||
</fragment>
|
|
||||||
|
|
||||||
<fragment
|
|
||||||
android:id="@+id/resultFragment"
|
|
||||||
android:name="com.tharun.bmicalculator.ResultFragment"
|
|
||||||
android:label="fragment_result"
|
|
||||||
tools:layout="@layout/fragment_result" >
|
|
||||||
<argument
|
|
||||||
android:name="bmi"
|
|
||||||
app:argType="float" />
|
|
||||||
<argument
|
|
||||||
android:name="age"
|
|
||||||
app:argType="string" />
|
|
||||||
</fragment>
|
|
||||||
|
|
||||||
</navigation>
|
|
@ -1,16 +0,0 @@
|
|||||||
<?xml version="1.0" encoding="utf-8"?>
|
|
||||||
<resources xmlns:tools="http://schemas.android.com/tools">
|
|
||||||
|
|
||||||
<style name="Theme.AppSplash" parent="Theme.SplashScreen">
|
|
||||||
<item name="windowSplashScreenBackground">@color/background</item>
|
|
||||||
<item name="windowSplashScreenAnimatedIcon">@mipmap/ic_launcher_round</item>
|
|
||||||
<item name="windowSplashScreenAnimationDuration">1000</item>
|
|
||||||
<item name="postSplashScreenTheme">@style/Theme.BMICalculator</item>
|
|
||||||
|
|
||||||
<!-- Status bar and Nav bar configs -->
|
|
||||||
<item name="android:statusBarColor" tools:targetApi="l">@color/background</item>
|
|
||||||
<item name="android:navigationBarColor">@color/background</item>
|
|
||||||
<item name="android:windowLightStatusBar">false</item>
|
|
||||||
</style>
|
|
||||||
|
|
||||||
</resources>
|
|
@ -1,16 +0,0 @@
|
|||||||
<?xml version="1.0" encoding="utf-8"?>
|
|
||||||
<resources xmlns:tools="http://schemas.android.com/tools">
|
|
||||||
|
|
||||||
<style name="Theme.AppSplash" parent="Theme.SplashScreen">
|
|
||||||
<item name="windowSplashScreenBackground">@color/background</item>
|
|
||||||
<item name="windowSplashScreenAnimatedIcon">@mipmap/ic_launcher_round</item>
|
|
||||||
<item name="windowSplashScreenAnimationDuration">1000</item>
|
|
||||||
<item name="postSplashScreenTheme">@style/Theme.BMICalculator</item>
|
|
||||||
|
|
||||||
<!-- Status bar and Nav bar configs -->
|
|
||||||
<item name="android:statusBarColor" tools:targetApi="l">@color/background</item>
|
|
||||||
<item name="android:navigationBarColor">@color/background</item>
|
|
||||||
<item name="android:windowLightStatusBar" tools:targetApi="m">false</item>
|
|
||||||
</style>
|
|
||||||
|
|
||||||
</resources>
|
|
@ -1,26 +0,0 @@
|
|||||||
<resources xmlns:tools="http://schemas.android.com/tools">
|
|
||||||
<!-- Base application theme. -->
|
|
||||||
<style name="Theme.BMICalculator" parent="Theme.MaterialComponents.DayNight.NoActionBar">
|
|
||||||
<!-- Primary brand color. -->
|
|
||||||
<item name="colorPrimary">@color/colorPrimary</item>
|
|
||||||
<item name="colorPrimaryVariant">@color/colorPrimaryDark</item>
|
|
||||||
<item name="colorOnPrimary">@color/white</item>
|
|
||||||
<!-- Secondary brand color. -->
|
|
||||||
<item name="colorSecondary">@color/teal_200</item>
|
|
||||||
<item name="colorSecondaryVariant">@color/teal_700</item>
|
|
||||||
<item name="colorOnSecondary">@color/black</item>
|
|
||||||
<!-- Status bar color. -->
|
|
||||||
<item name="android:statusBarColor" tools:targetApi="l">?attr/colorPrimaryVariant</item>
|
|
||||||
<!-- Customize your theme here. -->
|
|
||||||
|
|
||||||
<item name="android:windowBackground">@color/background</item>
|
|
||||||
<item name="android:navigationBarColor">@color/background</item>
|
|
||||||
|
|
||||||
</style>
|
|
||||||
|
|
||||||
<style name="circleImageView" parent="">
|
|
||||||
<item name="cornerFamily">rounded</item>
|
|
||||||
<item name="cornerSize">5%</item>
|
|
||||||
</style>
|
|
||||||
|
|
||||||
</resources>
|
|
@ -1,15 +0,0 @@
|
|||||||
<?xml version="1.0" encoding="utf-8"?>
|
|
||||||
<resources xmlns:tools="http://schemas.android.com/tools">
|
|
||||||
|
|
||||||
<style name="Theme.AppSplash" parent="Theme.SplashScreen">
|
|
||||||
<item name="windowSplashScreenBackground">@color/background</item>
|
|
||||||
<item name="windowSplashScreenAnimatedIcon">@mipmap/ic_launcher_round</item>
|
|
||||||
<item name="windowSplashScreenAnimationDuration">1000</item>
|
|
||||||
<item name="postSplashScreenTheme">@style/Theme.BMICalculator</item>
|
|
||||||
|
|
||||||
<!-- Status bar and Nav bar configs -->
|
|
||||||
<item name="android:statusBarColor" tools:targetApi="l">@color/background</item>
|
|
||||||
<item name="android:navigationBarColor">@color/background</item>
|
|
||||||
<item name="android:windowLightStatusBar">false</item>
|
|
||||||
</style>
|
|
||||||
</resources>
|
|
@ -1,16 +1,10 @@
|
|||||||
<?xml version="1.0" encoding="utf-8"?>
|
<?xml version="1.0" encoding="utf-8"?>
|
||||||
<resources>
|
<resources>
|
||||||
<color name="teal_200">#FF03DAC5</color>
|
|
||||||
<color name="teal_700">#FF018786</color>
|
|
||||||
<color name="black">#FF000000</color>
|
|
||||||
<color name="white">#FFFFFFFF</color>
|
|
||||||
|
|
||||||
<color name="colorPrimary">#6200EE</color>
|
<color name="colorPrimary">#6200EE</color>
|
||||||
<color name="colorPrimaryDark">#0B0A24</color>
|
<color name="colorPrimaryDark">#0B0A24</color>
|
||||||
<color name="colorAccent">#FE0049</color>
|
<color name="colorAccent">#FE0049</color>
|
||||||
|
|
||||||
<color name="green">#5ADC65</color>
|
|
||||||
|
|
||||||
<color name="background">#0B0A24</color>
|
<color name="background">#0B0A24</color>
|
||||||
<color name="card_background">#11122A</color>
|
<color name="card_background">#11122A</color>
|
||||||
|
|
||||||
|
@ -1,4 +0,0 @@
|
|||||||
<?xml version="1.0" encoding="utf-8"?>
|
|
||||||
<resources>
|
|
||||||
<color name="ic_launcher_background">#0B0A24</color>
|
|
||||||
</resources>
|
|
@ -1,4 +0,0 @@
|
|||||||
<?xml version="1.0" encoding="utf-8"?>
|
|
||||||
<resources>
|
|
||||||
<color name="ic_logo_background">#0B0A24</color>
|
|
||||||
</resources>
|
|
@ -1,16 +0,0 @@
|
|||||||
<?xml version="1.0" encoding="utf-8"?>
|
|
||||||
<resources xmlns:tools="http://schemas.android.com/tools">
|
|
||||||
|
|
||||||
<style name="Theme.AppSplash" parent="Theme.SplashScreen">
|
|
||||||
<item name="windowSplashScreenBackground">@color/background</item>
|
|
||||||
<item name="windowSplashScreenAnimatedIcon">@mipmap/ic_launcher_round</item>
|
|
||||||
<item name="windowSplashScreenAnimationDuration">1000</item>
|
|
||||||
<item name="postSplashScreenTheme">@style/Theme.BMICalculator</item>
|
|
||||||
|
|
||||||
<!-- Status bar and Nav bar configs -->
|
|
||||||
<item name="android:statusBarColor" tools:targetApi="l">@color/background</item>
|
|
||||||
<item name="android:navigationBarColor">@color/background</item>
|
|
||||||
<item name="android:windowLightStatusBar" tools:targetApi="m">false</item>
|
|
||||||
</style>
|
|
||||||
|
|
||||||
</resources>
|
|
@ -1,7 +1,6 @@
|
|||||||
<resources>
|
<resources>
|
||||||
<string name="app_name">BMI Calculator</string>
|
<string name="app_name">BMI Calculator</string>
|
||||||
|
<string name="_18_5_25_kg_m2">18.5 – 25 kg/m2</string>
|
||||||
<string name="_18_5_25_kg_m2">18.5 – 25 kg/m²</string>
|
|
||||||
<string name="normal_bmi_range">Normal BMI range:</string>
|
<string name="normal_bmi_range">Normal BMI range:</string>
|
||||||
<string name="recalculate">Recalculate your BMI</string>
|
<string name="recalculate">Recalculate your BMI</string>
|
||||||
<string name="calculate">Calculate your BMI</string>
|
<string name="calculate">Calculate your BMI</string>
|
||||||
@ -16,8 +15,6 @@
|
|||||||
<string name="_50">50</string>
|
<string name="_50">50</string>
|
||||||
<string name="_19">19</string>
|
<string name="_19">19</string>
|
||||||
<string name="your_result">Your Result</string>
|
<string name="your_result">Your Result</string>
|
||||||
|
<string name="your_age">Your Age</string>
|
||||||
<string name="cm">cm</string>
|
<string name="cm">cm</string>
|
||||||
<string name="share">share your Result</string>
|
|
||||||
<string name="your_age">your Age:</string>
|
|
||||||
|
|
||||||
</resources>
|
</resources>
|
10
app/src/main/res/values/styles.xml
Normal file
@ -0,0 +1,10 @@
|
|||||||
|
<resources>
|
||||||
|
<!-- Base application theme. -->
|
||||||
|
<style name="AppTheme" parent="Theme.AppCompat.Light.NoActionBar">
|
||||||
|
<!-- Customize your theme here. -->
|
||||||
|
<item name="colorPrimary">@color/colorPrimary</item>
|
||||||
|
<item name="colorPrimaryDark">@color/colorPrimaryDark</item>
|
||||||
|
<item name="colorAccent">@color/colorAccent</item>
|
||||||
|
</style>
|
||||||
|
|
||||||
|
</resources>
|
@ -1,26 +0,0 @@
|
|||||||
<resources xmlns:tools="http://schemas.android.com/tools">
|
|
||||||
<!-- Base application theme. -->
|
|
||||||
<style name="Theme.BMICalculator" parent="Theme.MaterialComponents.DayNight.NoActionBar">
|
|
||||||
<!-- Primary brand color. -->
|
|
||||||
<item name="colorPrimary">@color/colorPrimary</item>
|
|
||||||
<item name="colorPrimaryVariant">@color/colorPrimaryDark</item>
|
|
||||||
<item name="colorOnPrimary">@color/white</item>
|
|
||||||
<!-- Secondary brand color. -->
|
|
||||||
<item name="colorSecondary">@color/teal_200</item>
|
|
||||||
<item name="colorSecondaryVariant">@color/teal_700</item>
|
|
||||||
<item name="colorOnSecondary">@color/black</item>
|
|
||||||
<!-- Status bar color. -->
|
|
||||||
<item name="android:statusBarColor" tools:targetApi="l">?attr/colorPrimaryVariant</item>
|
|
||||||
<!-- Customize your theme here. -->
|
|
||||||
|
|
||||||
<item name="android:windowBackground">@color/background</item>
|
|
||||||
<item name="android:navigationBarColor">@color/background</item>
|
|
||||||
|
|
||||||
</style>
|
|
||||||
|
|
||||||
<style name="circleImageView" parent="">
|
|
||||||
<item name="cornerFamily">rounded</item>
|
|
||||||
<item name="cornerSize">5%</item>
|
|
||||||
</style>
|
|
||||||
|
|
||||||
</resources>
|
|
@ -0,0 +1,17 @@
|
|||||||
|
package com.adpth.bmicalculator;
|
||||||
|
|
||||||
|
import org.junit.Test;
|
||||||
|
|
||||||
|
import static org.junit.Assert.*;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Example local unit test, which will execute on the development machine (host).
|
||||||
|
*
|
||||||
|
* @see <a href="http://d.android.com/tools/testing">Testing documentation</a>
|
||||||
|
*/
|
||||||
|
public class ExampleUnitTest {
|
||||||
|
@Test
|
||||||
|
public void addition_isCorrect() {
|
||||||
|
assertEquals(4, 2 + 2);
|
||||||
|
}
|
||||||
|
}
|
@ -1,17 +0,0 @@
|
|||||||
package com.tharun.bmicalculator
|
|
||||||
|
|
||||||
import org.junit.Test
|
|
||||||
|
|
||||||
import org.junit.Assert.*
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Example local unit test, which will execute on the development machine (host).
|
|
||||||
*
|
|
||||||
* See [testing documentation](http://d.android.com/tools/testing).
|
|
||||||
*/
|
|
||||||
class ExampleUnitTest {
|
|
||||||
@Test
|
|
||||||
fun addition_isCorrect() {
|
|
||||||
assertEquals(4, 2 + 2)
|
|
||||||
}
|
|
||||||
}
|
|
17
build.gradle
@ -2,17 +2,22 @@
|
|||||||
buildscript {
|
buildscript {
|
||||||
repositories {
|
repositories {
|
||||||
google()
|
google()
|
||||||
|
jcenter()
|
||||||
}
|
}
|
||||||
dependencies {
|
dependencies {
|
||||||
classpath "com.android.tools.build:gradle:7.0.4"
|
classpath "com.android.tools.build:gradle:4.0.2"
|
||||||
classpath "androidx.navigation:navigation-safe-args-gradle-plugin:2.5.0"
|
|
||||||
|
// NOTE: Do not place your application dependencies here; they belong
|
||||||
|
// in the individual module build.gradle files
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
plugins {
|
allprojects {
|
||||||
id 'com.android.application' version '7.1.2' apply false
|
repositories {
|
||||||
id 'com.android.library' version '7.1.2' apply false
|
google()
|
||||||
id 'org.jetbrains.kotlin.android' version '1.6.20' apply false
|
jcenter()
|
||||||
|
maven { url 'https://jitpack.io' }
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
task clean(type: Delete) {
|
task clean(type: Delete) {
|
||||||
|
@ -6,8 +6,7 @@
|
|||||||
# http://www.gradle.org/docs/current/userguide/build_environment.html
|
# http://www.gradle.org/docs/current/userguide/build_environment.html
|
||||||
# Specifies the JVM arguments used for the daemon process.
|
# Specifies the JVM arguments used for the daemon process.
|
||||||
# The setting is particularly useful for tweaking memory settings.
|
# The setting is particularly useful for tweaking memory settings.
|
||||||
|
org.gradle.jvmargs=-Xmx2048m
|
||||||
org.gradle.jvmargs=-Xmx2048m -Dfile.encoding=UTF-8
|
|
||||||
# When configured, Gradle will run in incubating parallel mode.
|
# When configured, Gradle will run in incubating parallel mode.
|
||||||
# This option should only be used with decoupled projects. More details, visit
|
# This option should only be used with decoupled projects. More details, visit
|
||||||
# http://www.gradle.org/docs/current/userguide/multi_project_builds.html#sec:decoupled_projects
|
# http://www.gradle.org/docs/current/userguide/multi_project_builds.html#sec:decoupled_projects
|
||||||
@ -16,9 +15,5 @@ org.gradle.jvmargs=-Xmx2048m -Dfile.encoding=UTF-8
|
|||||||
# Android operating system, and which are packaged with your app"s APK
|
# Android operating system, and which are packaged with your app"s APK
|
||||||
# https://developer.android.com/topic/libraries/support-library/androidx-rn
|
# https://developer.android.com/topic/libraries/support-library/androidx-rn
|
||||||
android.useAndroidX=true
|
android.useAndroidX=true
|
||||||
# Kotlin code style for this project: "official" or "obsolete":
|
# Automatically convert third-party libraries to use AndroidX
|
||||||
kotlin.code.style=official
|
android.enableJetifier=true
|
||||||
# Enables namespacing of each library's R class so that its R class includes only the
|
|
||||||
# resources declared in the library itself and none from the library's dependencies,
|
|
||||||
# thereby reducing the size of the R class for that library
|
|
||||||
android.nonTransitiveRClass=true
|
|
BIN
gradle/wrapper/gradle-wrapper.jar
vendored
6
gradle/wrapper/gradle-wrapper.properties
vendored
@ -1,6 +1,6 @@
|
|||||||
#Fri Jul 29 01:35:58 IST 2022
|
#Tue Oct 13 11:55:01 IST 2020
|
||||||
distributionBase=GRADLE_USER_HOME
|
distributionBase=GRADLE_USER_HOME
|
||||||
distributionUrl=https\://services.gradle.org/distributions/gradle-7.2-bin.zip
|
|
||||||
distributionPath=wrapper/dists
|
distributionPath=wrapper/dists
|
||||||
zipStorePath=wrapper/dists
|
|
||||||
zipStoreBase=GRADLE_USER_HOME
|
zipStoreBase=GRADLE_USER_HOME
|
||||||
|
zipStorePath=wrapper/dists
|
||||||
|
distributionUrl=https\://services.gradle.org/distributions/gradle-6.1.1-all.zip
|
||||||
|
58
gradlew
vendored
@ -1,24 +1,5 @@
|
|||||||
#!/usr/bin/env sh
|
#!/usr/bin/env sh
|
||||||
|
|
||||||
<<<<<<< HEAD
|
|
||||||
#
|
|
||||||
# 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.
|
|
||||||
#
|
|
||||||
|
|
||||||
=======
|
|
||||||
>>>>>>> 5428ae08b054eba7bfde28f2912f029b02e54b12
|
|
||||||
##############################################################################
|
##############################################################################
|
||||||
##
|
##
|
||||||
## Gradle start up script for UN*X
|
## Gradle start up script for UN*X
|
||||||
@ -47,11 +28,7 @@ APP_NAME="Gradle"
|
|||||||
APP_BASE_NAME=`basename "$0"`
|
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.
|
# Add default JVM options here. You can also use JAVA_OPTS and GRADLE_OPTS to pass JVM options to this script.
|
||||||
<<<<<<< HEAD
|
|
||||||
DEFAULT_JVM_OPTS='"-Xmx64m" "-Xms64m"'
|
|
||||||
=======
|
|
||||||
DEFAULT_JVM_OPTS=""
|
DEFAULT_JVM_OPTS=""
|
||||||
>>>>>>> 5428ae08b054eba7bfde28f2912f029b02e54b12
|
|
||||||
|
|
||||||
# Use the maximum available, or set MAX_FD != -1 to use that value.
|
# Use the maximum available, or set MAX_FD != -1 to use that value.
|
||||||
MAX_FD="maximum"
|
MAX_FD="maximum"
|
||||||
@ -89,10 +66,6 @@ esac
|
|||||||
|
|
||||||
CLASSPATH=$APP_HOME/gradle/wrapper/gradle-wrapper.jar
|
CLASSPATH=$APP_HOME/gradle/wrapper/gradle-wrapper.jar
|
||||||
|
|
||||||
<<<<<<< HEAD
|
|
||||||
|
|
||||||
=======
|
|
||||||
>>>>>>> 5428ae08b054eba7bfde28f2912f029b02e54b12
|
|
||||||
# Determine the Java command to use to start the JVM.
|
# Determine the Java command to use to start the JVM.
|
||||||
if [ -n "$JAVA_HOME" ] ; then
|
if [ -n "$JAVA_HOME" ] ; then
|
||||||
if [ -x "$JAVA_HOME/jre/sh/java" ] ; then
|
if [ -x "$JAVA_HOME/jre/sh/java" ] ; then
|
||||||
@ -136,18 +109,10 @@ if $darwin; then
|
|||||||
GRADLE_OPTS="$GRADLE_OPTS \"-Xdock:name=$APP_NAME\" \"-Xdock:icon=$APP_HOME/media/gradle.icns\""
|
GRADLE_OPTS="$GRADLE_OPTS \"-Xdock:name=$APP_NAME\" \"-Xdock:icon=$APP_HOME/media/gradle.icns\""
|
||||||
fi
|
fi
|
||||||
|
|
||||||
<<<<<<< HEAD
|
|
||||||
# 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"`
|
|
||||||
|
|
||||||
=======
|
|
||||||
# For Cygwin, switch paths to Windows format before running java
|
# For Cygwin, switch paths to Windows format before running java
|
||||||
if $cygwin ; then
|
if $cygwin ; then
|
||||||
APP_HOME=`cygpath --path --mixed "$APP_HOME"`
|
APP_HOME=`cygpath --path --mixed "$APP_HOME"`
|
||||||
CLASSPATH=`cygpath --path --mixed "$CLASSPATH"`
|
CLASSPATH=`cygpath --path --mixed "$CLASSPATH"`
|
||||||
>>>>>>> 5428ae08b054eba7bfde28f2912f029b02e54b12
|
|
||||||
JAVACMD=`cygpath --unix "$JAVACMD"`
|
JAVACMD=`cygpath --unix "$JAVACMD"`
|
||||||
|
|
||||||
# We build the pattern for arguments to be converted via cygpath
|
# We build the pattern for arguments to be converted via cygpath
|
||||||
@ -173,21 +138,6 @@ if $cygwin ; then
|
|||||||
else
|
else
|
||||||
eval `echo args$i`="\"$arg\""
|
eval `echo args$i`="\"$arg\""
|
||||||
fi
|
fi
|
||||||
<<<<<<< HEAD
|
|
||||||
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" ;;
|
|
||||||
=======
|
|
||||||
i=$((i+1))
|
i=$((i+1))
|
||||||
done
|
done
|
||||||
case $i in
|
case $i in
|
||||||
@ -201,7 +151,6 @@ if $cygwin ; then
|
|||||||
(7) set -- "$args0" "$args1" "$args2" "$args3" "$args4" "$args5" "$args6" ;;
|
(7) set -- "$args0" "$args1" "$args2" "$args3" "$args4" "$args5" "$args6" ;;
|
||||||
(8) set -- "$args0" "$args1" "$args2" "$args3" "$args4" "$args5" "$args6" "$args7" ;;
|
(8) set -- "$args0" "$args1" "$args2" "$args3" "$args4" "$args5" "$args6" "$args7" ;;
|
||||||
(9) set -- "$args0" "$args1" "$args2" "$args3" "$args4" "$args5" "$args6" "$args7" "$args8" ;;
|
(9) set -- "$args0" "$args1" "$args2" "$args3" "$args4" "$args5" "$args6" "$args7" "$args8" ;;
|
||||||
>>>>>>> 5428ae08b054eba7bfde28f2912f029b02e54b12
|
|
||||||
esac
|
esac
|
||||||
fi
|
fi
|
||||||
|
|
||||||
@ -210,21 +159,14 @@ save () {
|
|||||||
for i do printf %s\\n "$i" | sed "s/'/'\\\\''/g;1s/^/'/;\$s/\$/' \\\\/" ; done
|
for i do printf %s\\n "$i" | sed "s/'/'\\\\''/g;1s/^/'/;\$s/\$/' \\\\/" ; done
|
||||||
echo " "
|
echo " "
|
||||||
}
|
}
|
||||||
<<<<<<< HEAD
|
|
||||||
APP_ARGS=`save "$@"`
|
|
||||||
=======
|
|
||||||
APP_ARGS=$(save "$@")
|
APP_ARGS=$(save "$@")
|
||||||
>>>>>>> 5428ae08b054eba7bfde28f2912f029b02e54b12
|
|
||||||
|
|
||||||
# Collect all arguments for the java command, following the shell quoting and substitution rules
|
# 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"
|
eval set -- $DEFAULT_JVM_OPTS $JAVA_OPTS $GRADLE_OPTS "\"-Dorg.gradle.appname=$APP_BASE_NAME\"" -classpath "\"$CLASSPATH\"" org.gradle.wrapper.GradleWrapperMain "$APP_ARGS"
|
||||||
|
|
||||||
<<<<<<< HEAD
|
|
||||||
=======
|
|
||||||
# by default we should be in the correct project dir, but when run from Finder on Mac, the cwd is wrong
|
# by default we should be in the correct project dir, but when run from Finder on Mac, the cwd is wrong
|
||||||
if [ "$(uname)" = "Darwin" ] && [ "$HOME" = "$PWD" ]; then
|
if [ "$(uname)" = "Darwin" ] && [ "$HOME" = "$PWD" ]; then
|
||||||
cd "$(dirname "$0")"
|
cd "$(dirname "$0")"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
>>>>>>> 5428ae08b054eba7bfde28f2912f029b02e54b12
|
|
||||||
exec "$JAVACMD" "$@"
|
exec "$JAVACMD" "$@"
|
||||||
|
44
gradlew.bat
vendored
@ -1,22 +1,3 @@
|
|||||||
<<<<<<< HEAD
|
|
||||||
@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
|
|
||||||
|
|
||||||
=======
|
|
||||||
>>>>>>> 5428ae08b054eba7bfde28f2912f029b02e54b12
|
|
||||||
@if "%DEBUG%" == "" @echo off
|
@if "%DEBUG%" == "" @echo off
|
||||||
@rem ##########################################################################
|
@rem ##########################################################################
|
||||||
@rem
|
@rem
|
||||||
@ -32,27 +13,15 @@ if "%DIRNAME%" == "" set DIRNAME=.
|
|||||||
set APP_BASE_NAME=%~n0
|
set APP_BASE_NAME=%~n0
|
||||||
set APP_HOME=%DIRNAME%
|
set APP_HOME=%DIRNAME%
|
||||||
|
|
||||||
<<<<<<< HEAD
|
|
||||||
@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 Add default JVM options here. You can also use JAVA_OPTS and GRADLE_OPTS to pass JVM options to this script.
|
@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=
|
set DEFAULT_JVM_OPTS=
|
||||||
>>>>>>> 5428ae08b054eba7bfde28f2912f029b02e54b12
|
|
||||||
|
|
||||||
@rem Find java.exe
|
@rem Find java.exe
|
||||||
if defined JAVA_HOME goto findJavaFromJavaHome
|
if defined JAVA_HOME goto findJavaFromJavaHome
|
||||||
|
|
||||||
set JAVA_EXE=java.exe
|
set JAVA_EXE=java.exe
|
||||||
%JAVA_EXE% -version >NUL 2>&1
|
%JAVA_EXE% -version >NUL 2>&1
|
||||||
<<<<<<< HEAD
|
|
||||||
if "%ERRORLEVEL%" == "0" goto execute
|
|
||||||
=======
|
|
||||||
if "%ERRORLEVEL%" == "0" goto init
|
if "%ERRORLEVEL%" == "0" goto init
|
||||||
>>>>>>> 5428ae08b054eba7bfde28f2912f029b02e54b12
|
|
||||||
|
|
||||||
echo.
|
echo.
|
||||||
echo ERROR: JAVA_HOME is not set and no 'java' command could be found in your PATH.
|
echo ERROR: JAVA_HOME is not set and no 'java' command could be found in your PATH.
|
||||||
@ -66,11 +35,7 @@ goto fail
|
|||||||
set JAVA_HOME=%JAVA_HOME:"=%
|
set JAVA_HOME=%JAVA_HOME:"=%
|
||||||
set JAVA_EXE=%JAVA_HOME%/bin/java.exe
|
set JAVA_EXE=%JAVA_HOME%/bin/java.exe
|
||||||
|
|
||||||
<<<<<<< HEAD
|
|
||||||
if exist "%JAVA_EXE%" goto execute
|
|
||||||
=======
|
|
||||||
if exist "%JAVA_EXE%" goto init
|
if exist "%JAVA_EXE%" goto init
|
||||||
>>>>>>> 5428ae08b054eba7bfde28f2912f029b02e54b12
|
|
||||||
|
|
||||||
echo.
|
echo.
|
||||||
echo ERROR: JAVA_HOME is set to an invalid directory: %JAVA_HOME%
|
echo ERROR: JAVA_HOME is set to an invalid directory: %JAVA_HOME%
|
||||||
@ -80,8 +45,6 @@ echo location of your Java installation.
|
|||||||
|
|
||||||
goto fail
|
goto fail
|
||||||
|
|
||||||
<<<<<<< HEAD
|
|
||||||
=======
|
|
||||||
:init
|
:init
|
||||||
@rem Get command-line arguments, handling Windows variants
|
@rem Get command-line arguments, handling Windows variants
|
||||||
|
|
||||||
@ -97,20 +60,13 @@ if "x%~1" == "x" goto execute
|
|||||||
|
|
||||||
set CMD_LINE_ARGS=%*
|
set CMD_LINE_ARGS=%*
|
||||||
|
|
||||||
>>>>>>> 5428ae08b054eba7bfde28f2912f029b02e54b12
|
|
||||||
:execute
|
:execute
|
||||||
@rem Setup the command line
|
@rem Setup the command line
|
||||||
|
|
||||||
set CLASSPATH=%APP_HOME%\gradle\wrapper\gradle-wrapper.jar
|
set CLASSPATH=%APP_HOME%\gradle\wrapper\gradle-wrapper.jar
|
||||||
|
|
||||||
<<<<<<< HEAD
|
|
||||||
|
|
||||||
@rem Execute Gradle
|
|
||||||
"%JAVA_EXE%" %DEFAULT_JVM_OPTS% %JAVA_OPTS% %GRADLE_OPTS% "-Dorg.gradle.appname=%APP_BASE_NAME%" -classpath "%CLASSPATH%" org.gradle.wrapper.GradleWrapperMain %*
|
|
||||||
=======
|
|
||||||
@rem Execute Gradle
|
@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%
|
"%JAVA_EXE%" %DEFAULT_JVM_OPTS% %JAVA_OPTS% %GRADLE_OPTS% "-Dorg.gradle.appname=%APP_BASE_NAME%" -classpath "%CLASSPATH%" org.gradle.wrapper.GradleWrapperMain %CMD_LINE_ARGS%
|
||||||
>>>>>>> 5428ae08b054eba7bfde28f2912f029b02e54b12
|
|
||||||
|
|
||||||
:end
|
:end
|
||||||
@rem End local scope for the variables with windows NT shell
|
@rem End local scope for the variables with windows NT shell
|
||||||
|
Before Width: | Height: | Size: 34 KiB |
Before Width: | Height: | Size: 29 KiB |
@ -1,16 +1,2 @@
|
|||||||
pluginManagement {
|
|
||||||
repositories {
|
|
||||||
gradlePluginPortal()
|
|
||||||
google()
|
|
||||||
mavenCentral()
|
|
||||||
}
|
|
||||||
}
|
|
||||||
dependencyResolutionManagement {
|
|
||||||
repositoriesMode.set(RepositoriesMode.FAIL_ON_PROJECT_REPOS)
|
|
||||||
repositories {
|
|
||||||
google()
|
|
||||||
mavenCentral()
|
|
||||||
}
|
|
||||||
}
|
|
||||||
rootProject.name = "BMI Calculator"
|
|
||||||
include ':app'
|
include ':app'
|
||||||
|
rootProject.name = "BMI Calculator"
|