Android安卓实战项目(12)—关于身体分析,BMI计算,喝水提醒,食物卡路里计算APP【支持中英文切换】生活助手类APP(源码在文末)

Android安卓实战项目(12)—关于身体分析,BMI计算,喝水提醒,食物卡路里计算APP【支持中英文切换】生活助手类APP(源码在文末🐕🐕🐕)

一.项目运行介绍

B站演示
【Android安卓实战项目(12)—生活助手类APP—关于身体分析,BMI计算,喝水提醒,食物卡路里计算APP【支持中英文切换】】
https://www.bilibili.com/video/BV1Wu4y1C76j/?share_source=copy_web&vd_source=b2e9b9ed746acda34f499009647748ed

1.开机动画

60ab1e73a75361bcbbff6ca7d80c6c5

2.主页面

image-20230831093217711

3.侧边栏

image-20230831093225406

4.身体分析

image-20230831093239408

5.分析结果

image-20230831093246484

image-20230831093254082

6.显示分析

image-20230831093306291

7.食物热量计算

image-20230831093406559

8.喝水提醒

image-20230831093301687

二.具体实现

1.MainActivity

package ahmux.nutritionpoint;
import android.app.Activity;
import android.app.AlarmManager;
import android.app.PendingIntent;
import android.content.Context;
import android.content.Intent;
import android.content.SharedPreferences;
import android.content.res.Configuration;
import android.graphics.Typeface;
import android.net.Uri;
import android.os.Bundle;
import android.support.v4.app.Fragment;
import android.support.design.widget.NavigationView;
import android.support.v4.view.GravityCompat;
import android.support.v4.widget.DrawerLayout;
import android.support.v7.app.ActionBarDrawerToggle;
import android.support.v7.app.AppCompatActivity;
import android.support.v7.widget.Toolbar;
import android.util.DisplayMetrics;
import android.view.Menu;
import android.view.MenuItem;
import android.widget.Button;
import android.widget.Switch;
import android.widget.TextView;
import android.widget.Toast;import java.lang.reflect.Array;
import java.util.Locale;public class MainActivity extends AppCompatActivityimplements FragmentsCommunicator, NavigationView.OnNavigationItemSelectedListener {String fontPath = "fonts/Questv1-Bold.otf";Toast doubleBackToast;TextView  tv1;@Overrideprotected void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);setContentView(R.layout.activity_main);Toolbar toolbar = (Toolbar) findViewById(R.id.toolbar);setSupportActionBar(toolbar);tv1 = (TextView) findViewById(R.id.textView1);DrawerLayout drawer = (DrawerLayout) findViewById(R.id.drawer_layout);ActionBarDrawerToggle toggle = new ActionBarDrawerToggle(this, drawer, toolbar, R.string.navigation_drawer_open, R.string.navigation_drawer_close);drawer.addDrawerListener(toggle);toggle.syncState();NavigationView navigationView = (NavigationView) findViewById(R.id.nav_view);navigationView.setNavigationItemSelectedListener(this);loadLocale();saveData();waterReminder();// Loading Font FaceTypeface tf = Typeface.createFromAsset(getAssets(), fontPath);tv1.setTypeface(tf);doubleBackToast = Toast.makeText(this,R.string.doubleBackToast, Toast.LENGTH_LONG);}/* ######### Communicate with Fragments ######################################################## */@Override//data1 is key, data2 is valuepublic void respond(String data1, int data2) {SharedPreferences sharedPreferences = getSharedPreferences("UserData", Context.MODE_PRIVATE);SharedPreferences.Editor editor = sharedPreferences.edit();switch (data1){case("male"):editor.putString("gender", getString(R.string.Male));loadFragment(new Fragment2(), R.id.fullparentFramelayout);break;case("female"):editor.putString("gender", getString(R.string.Female));loadFragment(new Fragment2(),R.id.fullparentFramelayout);break;case("no activity"):editor.putString("physical_activity", "no activity");loadFragment(new Fragment3(), R.id.fullparentFramelayout);break;case("walking"):editor.putString("physical_activity", "walking");loadFragment(new Fragment3(), R.id.fullparentFramelayout);break;case("exercize 1-2 days"):loadFragment(new Fragment3(),R.id.fullparentFramelayout);break;case("exercize 3-5 days"):loadFragment(new Fragment3(), R.id.fullparentFramelayout);break;case("everyday"):loadFragment(new Fragment3(), R.id.fullparentFramelayout);break;case("age"):editor.putString("age", String.valueOf(data2));break;case("weight"):editor.putString("weight", String.valueOf(data2));break;case("height"):editor.putString("height", String.valueOf(data2));break;case("analyze"):loadFragment(new Fragment4(),R.id.fullparentFramelayout);break;case("ok"):Intent endIntent = new Intent(this, MainActivity .class);//set flags to clear back stackendIntent.addFlags(Intent.FLAG_ACTIVITY_CLEAR_TOP | Intent.FLAG_ACTIVITY_NEW_TASK);startActivity(endIntent);break;case("clear"):Toast.makeText(this, "DATA CLEARED", Toast.LENGTH_SHORT).show();//clear data from shared preferenceseditor.clear();Intent clearIntent = new Intent(this, MainActivity .class);//clear back stackclearIntent.addFlags(Intent.FLAG_ACTIVITY_CLEAR_TOP | Intent.FLAG_ACTIVITY_NEW_TASK);startActivity(clearIntent);break;case("show"):loadFragment(new Fragment4(),R.id.fullparentFramelayout);break;}editor.commit();}//Fragments loading methodprivate void loadFragment(Fragment f, int layoutId) {android.support.v4.app.FragmentManager fm = getSupportFragmentManager();android.support.v4.app.FragmentTransaction ft = fm.beginTransaction();ft.replace(layoutId, f);ft.addToBackStack(null);  // press back to go to previous fragmentft.commit();}/* ############################################################################################# *//* #############Saving data in Shared Preferences############################################### */private void saveData() {SharedPreferences sharedPreferences = getSharedPreferences("UserData", Context.MODE_PRIVATE);String gender = sharedPreferences.getString("gender", "N/A");String activity = sharedPreferences.getString("physical_activity", "N/A");String age = sharedPreferences.getString("age", "N/A");String weight = sharedPreferences.getString("weight", "N/A");String height = sharedPreferences.getString("height", "N/A");//choose start fraagment or End!android.support.v4.app.FragmentManager fm = getSupportFragmentManager();android.support.v4.app.FragmentTransaction ft = fm.beginTransaction();if (age.matches("N/A")) {ft.replace(R.id.mainFrameLayout, new Fragment1());ft.commit();} else {ft.replace(R.id.mainFrameLayout, new Fragment5());ft.commit();}}//Send data to Fragmentspublic String getMyData(String s) {String myString = s;SharedPreferences sharedPreferences = getSharedPreferences("UserData", Context.MODE_PRIVATE);switch (s){case("gender"):myString = sharedPreferences.getString("gender", null);break;case("age"):myString = sharedPreferences.getString("age", null);break;case("weight"):myString = sharedPreferences.getString("weight", null);break;case("height"):myString = sharedPreferences.getString("height", null);break;}return myString;}/* ############################################################################################# */@Overridepublic boolean onCreateOptionsMenu(Menu menu) {// Inflate the menu; this adds items to the action bar if it is present.getMenuInflater().inflate(R.menu.main, menu);return true;}@Overridepublic boolean onOptionsItemSelected(MenuItem item) {int id = item.getItemId();if (id == R.id.action_about) {loadFragment(new AboutFragment(), R.id.fullparentFramelayout);return true;}else if (id == R.id.action_language){String langPref = "Language";SharedPreferences sharedPreferences = getSharedPreferences("SettingsData", Activity.MODE_PRIVATE);String language = sharedPreferences.getString(langPref, "en");if(language.matches("ar")){changeLang("en");}else{changeLang("ar");}Intent refresh = new Intent(this, MainActivity.class);refresh.setFlags(refresh.getFlags() | Intent.FLAG_ACTIVITY_NO_HISTORY); // Adds the FLAG_ACTIVITY_NO_HISTORY flagstartActivity(refresh);finish();}return super.onOptionsItemSelected(item);}@SuppressWarnings("StatementWithEmptyBody")@Overridepublic boolean onNavigationItemSelected(MenuItem item) {// Handle navigation view item clicks here.int id = item.getItemId();if (id == R.id.nav_home) {Intent intent = new Intent(this, MainActivity.class);startActivity(intent);} else if (id == R.id.nav_reminder) {Intent RemindersIntent = new Intent(this, RemindersActivity.class);startActivity(RemindersIntent);} else if (id == R.id.nav_Recipes) {} else if (id == R.id.nav_calculate) {Intent ApiIntent = new Intent(this, ApiActivity.class);startActivity(ApiIntent);} else if (id == R.id.nav_share) {} else if (id == R.id.nav_facebook) {try {Intent fbIntent = new Intent(Intent.ACTION_VIEW);fbIntent.setData(Uri.parse("https://www.facebook.com/supportnutritionpoit"));startActivity(fbIntent);} catch (Exception e) {}}DrawerLayout drawer = (DrawerLayout) findViewById(R.id.drawer_layout);drawer.closeDrawer(GravityCompat.START);return true;}/* ###### Water Reminder ######################################################################3 */public void waterReminder(){SharedPreferences sharedPreferences = getSharedPreferences("SettingsData", Activity.MODE_PRIVATE);int t = sharedPreferences.getInt("water_delay", 1000);if(sharedPreferences.getString("water_reminder", "false").matches("true")){AlarmManager alarmManager = (AlarmManager)getSystemService(Context.ALARM_SERVICE);Intent alarmIntent = new Intent(this, AlarmReceiver.class);PendingIntent pendingIntent = PendingIntent.getBroadcast(this,0, alarmIntent, PendingIntent.FLAG_UPDATE_CURRENT);alarmManager.setRepeating(AlarmManager.RTC_WAKEUP, System.currentTimeMillis(),t*60*1000, pendingIntent);}}/* ############################################################################################ *//* #########Change Language and restart Main Activity########################################### */public void loadLocale() {String langPref = "Language";SharedPreferences sharedPreferences = getSharedPreferences("SettingsData", Activity.MODE_PRIVATE);String language = sharedPreferences.getString(langPref, "");changeLang(language);}public void changeLang(String lang) {if (lang.equalsIgnoreCase(""))return;Locale myLocale = new Locale(lang, "MR");saveLocale(lang);Locale.setDefault(myLocale);android.content.res.Configuration config = new android.content.res.Configuration();config.locale = myLocale;getBaseContext().getResources().updateConfiguration(config,getBaseContext().getResources().getDisplayMetrics());}public void saveLocale(String lang) {String langPref = "Language";SharedPreferences sharedPreferences = getSharedPreferences("SettingsData", Activity.MODE_PRIVATE);SharedPreferences.Editor editor = sharedPreferences.edit();editor.putString(langPref, lang);editor.commit();}/* ############################################################################################ */@Overridepublic void onBackPressed() {int backStackEntryCount = getSupportFragmentManager().getBackStackEntryCount();DrawerLayout drawer = (DrawerLayout) findViewById(R.id.drawer_layout);if (drawer.isDrawerOpen(GravityCompat.START)) {drawer.closeDrawer(GravityCompat.START);}/* ##### press back twice to exit method #################################// */else if (backStackEntryCount == 0) {if (doubleBackToast.getView().isShown()) {if (doubleBackToast != null) {doubleBackToast.cancel();super.onBackPressed();}}doubleBackToast.show();}else {super.onBackPressed();}/* ######################################################################// */}
}

这段代码是一个Android应用程序的主要活动(Activity),它是一个基于导航抽屉(Navigation Drawer)的应用,用于管理用户的营养信息。下面我会对代码的各个部分进行详细解释:

  1. 导入必要的类:
    代码开始处导入了一些Android的类,这些类用于构建应用界面、处理用户操作和管理数据。这些类包括Activity、Fragment、Intent等等。

  2. MainActivity类继承自AppCompatActivity:
    这是应用的主要活动类,用于展示应用的界面、处理用户输入和管理应用逻辑。

  3. onCreate方法:
    这个方法是Activity生命周期的一部分,在Activity首次创建时被调用。在这个方法中,进行了许多初始化操作,如设置布局、工具栏、导航抽屉等。

  4. Fragment通信:
    在代码中定义了一个接口FragmentsCommunicator,用于在Activity和Fragments之间进行通信。respond方法根据接收到的不同数据,进行相关的逻辑处理和Fragment的加载。

  5. 数据保存和获取:
    通过SharedPreferences,数据被保存在应用的持久存储中,以便在应用重启后可以恢复。saveData方法用于根据已保存的数据判断是加载起始Fragment还是结束Fragment,getMyData方法用于从SharedPreferences获取特定的用户数据。

  6. 菜单和选项:
    通过onCreateOptionsMenu方法创建应用菜单,通过onOptionsItemSelected方法处理选项菜单的点击事件,比如切换语言、显示关于界面等。

  7. 抽屉导航点击事件:
    通过onNavigationItemSelected方法处理导航抽屉中的选项点击事件,根据点击的选项执行不同的操作,如返回主页面、打开提醒页面、切换语言等。

  8. 水量提醒功能:
    waterReminder方法用于设置水量提醒的闹钟,根据用户的设置,周期性地触发提醒。

  9. 语言切换:
    loadLocale方法用于加载用户选择的语言设置,changeLang方法用于实际改变应用的语言,并重新加载界面。

  10. 返回按钮行为:
    onBackPressed方法重写了返回按钮的行为,实现了“双击返回退出”功能,以及处理Fragment的回退。

  11. 其他细节:
    代码中还包括了加载字体、设置文本样式、处理Facebook链接等其他细节功能。

2.ApiActivity.java

package ahmux.nutritionpoint;import android.os.AsyncTask;
import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.view.View;
import android.widget.EditText;
import android.widget.TextView;
import android.widget.Toast;import org.json.JSONArray;
import org.json.JSONException;
import org.json.JSONObject;import java.io.BufferedReader;
import java.io.InputStreamReader;
import java.net.HttpURLConnection;
import java.net.URL;public class ApiActivity extends AppCompatActivity {String food;EditText et;TextView tv1, tv2,tv3, tv4, tv5;View v1, v2;@Overrideprotected void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);setContentView(R.layout.activity_api);et = (EditText)findViewById(R.id.editText);tv1 = (TextView)findViewById(R.id.textView13);tv2 = (TextView)findViewById(R.id.textView16);tv3 = (TextView)findViewById(R.id.textView17);tv4 = (TextView)findViewById(R.id.textView18);tv5 = (TextView)findViewById(R.id.textView19);}public void calculateClk(View view) {food = et.getText().toString();Toast.makeText(this, "Searching...", Toast.LENGTH_SHORT).show();new MyAsyncTask().execute();}/* #####AsyncTask Subclass################################################################### */private class MyAsyncTask extends AsyncTask<String, String, String>{@Overrideprotected String doInBackground(String... strings) {String allStrings;try{URL myUrl = new URL("https://api.nutritionix.com/v1_1/search/" +food +"?fields=item_name%2Citem_id%2Cnf_calories%2Cnf_total_fat" +"&appId=3fe5fa47&appKey=61729b9d2d8612a629467f0cdbbd6d2c");HttpURLConnection connection =(HttpURLConnection) myUrl.openConnection();connection.setConnectTimeout(700);connection.connect();//Create a new InputStreamReaderInputStreamReader streamReader = new InputStreamReader(connection.getInputStream());//Create a new buffered reader and String BuilderBufferedReader reader = new BufferedReader(streamReader);String inputLine;StringBuilder stringBuilder = new StringBuilder();//Check if the line we are reading is not nullwhile((inputLine = reader.readLine()) != null){stringBuilder.append(inputLine);}reader.close();streamReader.close();allStrings = stringBuilder.toString();publishProgress(allStrings);}catch(Exception e){}return "";}@Overrideprotected void onProgressUpdate(String... values) {try {JSONObject j = new  JSONObject(values[0]);JSONArray h= (JSONArray) j.get("hits");JSONObject rec = h.getJSONObject(0);JSONObject fields = rec.getJSONObject("fields");String calories = fields.getString("nf_calories");String fat = fields.getString("nf_total_fat");String name = fields.getString("item_name");tv2.setText("Nutrition Facts");tv3.setText("Amount: " + name);tv4.setText("Calories: " +calories);tv5.setText("Total Fat: " + fat);v1 = findViewById(R.id.view);v1.setVisibility(View.VISIBLE);v2 = findViewById(R.id.view);v2.setVisibility(View.VISIBLE);} catch (JSONException e) {e.printStackTrace();}}}
}

这段代码是一个Android应用中的Java类,用于从一个外部的API获取食物的营养信息,并在界面上显示出来。我会逐步解释每个部分的功能和作用。

  1. 导入库和包:代码开头导入了一些需要的库和包,用于支持Android应用的开发和功能实现。

  2. 类定义:定义了一个名为 ApiActivity 的类,继承自 AppCompatActivity,即用于创建一个与Android界面交互的活动(Activity)。

  3. 成员变量的声明:在类内部,声明了一系列的成员变量,用于存储界面上的控件和数据。例如,String food 用于存储食物名称,EditText et 用于获取用户输入的食物名称,TextView 类型的 tv1, tv2, tv3, tv4, tv5 用于显示不同的文本信息,View v1View v2 则是视图元素。

  4. onCreate 方法:这是Android活动的生命周期方法之一,会在活动创建时被调用。在这里,首先设置了界面的布局,然后通过 findViewById 方法获取布局中的各个控件,将它们和之前声明的成员变量进行关联。

  5. calculateClk 方法:这个方法是在用户点击某个按钮时触发的,它从 EditText 控件中获取用户输入的食物名称,显示一个短时的提示消息,然后创建并执行一个异步任务 MyAsyncTask 来获取营养信息。

  6. MyAsyncTask 内部类:这是一个内部类,继承自 AsyncTask,用于在后台执行网络请求和数据处理操作。

    • doInBackground 方法:在后台线程执行,它首先构建一个URL来访问特定的API,然后通过HTTP连接获取API返回的数据。这部分操作是在后台进行的,以避免在主线程上进行网络请求,防止应用界面的卡顿。获取的数据被转化为字符串并通过 publishProgress 发送到主线程更新。

    • onProgressUpdate 方法:在主线程执行,用于处理后台任务的进度更新。在这里,获取的字符串数据被解析为JSON对象,然后从中提取出营养信息,最后将这些信息设置到界面上的 TextView 控件中,并显示一些视图元素。

总的来说,这段代码实现了以下功能:

  • 用户在输入框中输入食物名称,点击按钮后,应用通过网络请求从特定API获取食物的营养信息。
  • 营养信息包括名称、卡路里和总脂肪,并将这些信息显示在界面上的 TextView 控件中。
  • 异步任务的使用确保了网络请求等耗时操作不会阻塞应用的主线程,保持了应用的响应性。

3.RemindersActivity.java

package ahmux.nutritionpoint;/* ######################################## */
/*  Nutrition Point App developed by Ahmux  */
/* ##### Ahmux.freelander@gmail.com ######  */
/* ######################################## */import android.app.Activity;
import android.app.AlarmManager;
import android.app.PendingIntent;
import android.content.Context;
import android.content.Intent;
import android.content.SharedPreferences;
import android.graphics.Color;
import android.support.v7.app.ActionBar;
import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.view.View;
import android.widget.Button;
import android.widget.Toast;public class RemindersActivity extends AppCompatActivity implements View.OnClickListener {Button b1,b2, b3, b4, b5,b6,b7;@Overrideprotected void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);setContentView(R.layout.activity_reminders);ActionBar actionBar = getSupportActionBar();actionBar.setTitle(R.string.reminders_title);SharedPreferences sharedPreferences = getSharedPreferences("SettingsData", Activity.MODE_PRIVATE);b1 = (Button)findViewById(R.id.min15Btn);b1.setOnClickListener(this);b2 = (Button)findViewById(R.id.min30Btn);b2.setOnClickListener(this);b3 = (Button)findViewById(R.id.h1Btn);b3.setOnClickListener(this);b4 = (Button)findViewById(R.id.h2Btn);b4.setOnClickListener(this);b5 = (Button)findViewById(R.id.h4Btn);b5.setOnClickListener(this);b6 = (Button)findViewById(R.id.startBtn);b6.setOnClickListener(this);b7 = (Button)findViewById(R.id.stopBtn);b7.setOnClickListener(this);}@Overridepublic void onClick(View view) {SharedPreferences sharedPreferences = getSharedPreferences("SettingsData", Activity.MODE_PRIVATE);SharedPreferences.Editor editor = sharedPreferences.edit();int delay = sharedPreferences.getInt("water_delay", 300);if (view.getId() == R.id.min15Btn || delay == 15){editor.putInt("water_delay", 15);b1.setTextColor(Color.parseColor("#FFCC00"));b2.setTextColor(Color.WHITE);b3.setTextColor(Color.WHITE);b4.setTextColor(Color.WHITE);b5.setTextColor(Color.WHITE);}else if (view.getId() == R.id.min30Btn || delay == 30){editor.putInt("water_delay", 30);b1.setTextColor(Color.WHITE);b2.setTextColor(Color.parseColor("#FFCC00"));b3.setTextColor(Color.WHITE);b4.setTextColor(Color.WHITE);b5.setTextColor(Color.WHITE);}else if (view.getId() == R.id.h1Btn || delay == 60){editor.putInt("water_delay", 60);b1.setTextColor(Color.WHITE);b2.setTextColor(Color.WHITE);b3.setTextColor(Color.parseColor("#FFCC00"));b4.setTextColor(Color.WHITE);b5.setTextColor(Color.WHITE);}else if (view.getId() == R.id.h2Btn || delay == 120){editor.putInt("water_delay", 120);b1.setTextColor(Color.WHITE);b2.setTextColor(Color.WHITE);b3.setTextColor(Color.WHITE);b4.setTextColor(Color.parseColor("#FFCC00"));b5.setTextColor(Color.WHITE);}else if (view.getId() == R.id.h4Btn || delay == 240){editor.putInt("water_delay", 240);b1.setTextColor(Color.WHITE);b2.setTextColor(Color.WHITE);b3.setTextColor(Color.WHITE);b4.setTextColor(Color.parseColor("#FFCC00"));b5.setTextColor(Color.WHITE);}else if (view.getId() == R.id.startBtn){AlarmManager alarmManager = (AlarmManager)getSystemService(Context.ALARM_SERVICE);Intent alarmIntent = new Intent(this, AlarmReceiver.class);PendingIntent pendingIntent = PendingIntent.getBroadcast(this,0, alarmIntent, PendingIntent.FLAG_UPDATE_CURRENT);alarmManager.setRepeating(AlarmManager.RTC_WAKEUP, System.currentTimeMillis(),delay*60*1000, pendingIntent);editor.putString("water_reminder", "true");}else if (view.getId() == R.id.stopBtn){editor.putString("water_reminder", "false");AlarmManager alarmManager = (AlarmManager)getSystemService(Context.ALARM_SERVICE);Intent alarmIntent = new Intent(this, AlarmReceiver.class);PendingIntent pendingIntent = PendingIntent.getBroadcast(this,0, alarmIntent, PendingIntent.FLAG_UPDATE_CURRENT);alarmManager.cancel(pendingIntent);Toast.makeText(this, "Water Reminders Stopped", Toast.LENGTH_SHORT).show();}}
}

这段代码是一个Android应用中的Java类,它似乎是一个提醒用户喝水的功能部分。下面我将对代码的不同部分进行详细解释:

  1. 导入库和声明类:

    • import 语句用于导入所需的类和库,让你可以在代码中使用它们。
    • package ahmux.nutritionpoint; 声明了当前类所在的包名。
    • public class RemindersActivity extends AppCompatActivity implements View.OnClickListener 声明了一个名为 RemindersActivity 的类,它继承自 AppCompatActivity 类,并实现了 View.OnClickListener 接口。
  2. 成员变量声明:

    • Button b1, b2, b3, b4, b5, b6, b7; 声明了七个按钮对象的成员变量,这些按钮将用于用户与界面交互。
  3. onCreate 方法:

    • onCreate 是 Android 生命周期中的一个方法,在创建 Activity 时被调用。在这里,你进行了一些初始化操作。
    • setContentView(R.layout.activity_reminders); 设置当前 Activity 使用的布局文件为 activity_reminders.xml
    • 通过 getSupportActionBar() 获取应用的操作栏,并设置标题为 “reminders_title” 字符串资源的值。
    • 获取名为 “SettingsData” 的共享偏好设置实例。
  4. 按钮初始化和点击事件:

    • 初始化了七个按钮对象,并分别为它们设置了点击监听器。
    • 当用户点击按钮时,相应的 onClick 方法将被调用。
  5. onClick 方法:

    • 在用户点击按钮时触发的方法,这个方法实现了对不同按钮的响应操作。
    • 首先,获取共享偏好设置实例和编辑器。
    • 根据用户点击的按钮或者已经保存的延迟时间,修改偏好设置中的 “water_delay” 值。
    • 根据点击的按钮,修改按钮的文本颜色以进行视觉提示。
    • 如果用户点击了 “startBtn”,设置一个重复性闹钟,以提醒用户喝水。
    • 如果用户点击了 “stopBtn”,取消之前设置的闹钟,并显示一个提示信息。

这段代码实现了一个界面,用户可以点击不同的按钮来设置提醒的时间间隔,以及开始和停止喝水提醒的功能。

三.项目源码

链接:https://pan.baidu.com/s/1Ydtv31fBAuenfCQJeJCeOw?pwd=0616
提取码:0616

创作不易,项目已加密,有偿(仅一杯奶茶钱,可做实验报告,代码讲解等…)

请私信作者或

(v)15135757306

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/114801.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

小兔鲜商03

进入可视区加载数据&#xff1a; 首页有很多模块&#xff0c;如果一次性加载所有数据&#xff0c;很卡&#xff0c;&#xff0c;当移动到要显示的地方&#xff0c;才加载数据 使用 vueuse 库中 useIntersectionObserver方法&#xff0c;&#xff0c; 传入要监听的元素 target …

Spring Boot存在路径遍历漏洞CVE-2021-22118

文章目录 0.前言1.参考文档2.基础介绍1. 影响的版本2. **漏洞利用原理&#xff1a;** 3.解决方案3.1. 方案13.2. 方案23. 方案3 0.前言 背景&#xff1a;Spring Boot存在路径遍历漏洞。CVE-2021-22118: 官方 issue也有对此的记录&#xff0c;感兴趣可以看下 https://github.com…

8.物联网LWIP,简要介绍http(超文本,URL),html(css,ajax),web实现打开灯

一。HTTP详解 1.超文本&#xff1a;&#xff08;HyperText&#xff09; &#xff08;1&#xff09;超文本文件彼此链接&#xff0c;形成网状&#xff08;web&#xff09;&#xff0c;内含有超链接&#xff08;Link&#xff09;与各种媒体元素标记&#xff08;Markup&#xff…

微服务架构七种模式

微服务架构七种模式 目录概述需求&#xff1a; 设计思路实现思路分析 参考资料和推荐阅读 Survive by day and develop by night. talk for import biz , show your perfect code,full busy&#xff0c;skip hardness,make a better result,wait for change,challenge Survive.…

1773_把vim的tab键设置为4个空格显示

全部学习汇总&#xff1a; GitHub - GreyZhang/editors_skills: Summary for some common editor skills I used. 有时候自己觉得自己很奇怪&#xff0c;看着Linux的命令窗口就觉得很顺眼。那些花花绿绿的字符以及繁多的方便命令工具&#xff0c;确实是比Windows强不少。不过&a…

大数据时代下的精准营销

在大数据时代&#xff0c;人们的信息越来越透明&#xff0c;留在网络上的各种数据也是企业进行营销的一个重要的生产要素。一直以来&#xff0c;营销的科学性正是因为运用了自然科学中一级互联网中的数据收集手段&#xff0c;严谨的记录、搜集和分析消费者的各项数据和日常生活…

Openlayer系列:利用GeoServer和Openlayer地图显示区域掩模

前言 利用GeoServer和Openlayer地图显示区域掩模 利用GeoServer进行图层发布 Openlayer地图显示区域掩模 对界面地图进行切换&#xff0c;卫星图利用GeoServer&#xff0c;水系等根据geojson文件生成图层&#xff0c;效果如下 卫星图部分代码如下&#xff1a; // 创建卫星图…

在CentOS7中,安装并配置Redis【个人笔记】

一、拓展——Ubuntu上安装Redis 输入命令su --->切换到root用户【如果已经是&#xff0c;则不需要进行该操作】apt search redis --->使用apt命令来搜索redis相关的软件包【查询后&#xff0c;检查redis版本是否是你需要的&#xff0c;如果不是则需要看看其他资料~】ap…

蓝牙运动耳机哪个牌子好、好用的运动蓝牙耳机推荐

作为一个热爱运动的人&#xff0c;我对耳机非常关注。我相信许多喜欢运动的人在锻炼时都会佩戴耳机&#xff0c;这样可以为运动增添一份乐趣&#xff0c;享受自己喜爱的音乐或聆听有趣的小说&#xff0c;激发内心的动力。但很多人都不知道要怎么选一款优质的运动耳机&#xff0…

安捷伦Agilent E8362C网络分析仪

产品概述 Agilent E8362C网络分析仪提供通用网络分析&#xff0c;带有可选软件和/或硬件&#xff0c;可根据您的应用进行定制&#xff0c;如多端口、脉冲射频等。 Agilent E8362C网络分析仪的显示窗口数量不限&#xff0c;可以调整大小和重新排列&#xff0c;每个窗口最多有24…

python-数据分析-numpy、pandas、matplotlib的常用方法

一、numpy import numpy as np1.numpy 数组 和 list 的区别 输出方式不同 里面包含的元素类型 2.构造并访问二维数组 使用 索引/切片 访问ndarray元素 切片 左闭右开 np.array(list) 3.快捷构造高维数组 np.arange() np.random.randn() - - - 服从标准正态分布- - - …

【高阶数据结构】map和set的介绍和使用 {关联式容器;键值对;map和set;multimap和multiset;OJ练习}

map和set的介绍和使用 一、关联式容器 关联式容器和序列式容器是C STL中的两种不同类型的容器。 关联式容器是基于键值对的容器&#xff0c;其中每个元素都有一个唯一的键值&#xff0c;可以通过键值来访问元素。关联式容器包括set、multiset、map和multimap。 序列式容器是…

常静相伴:深度解析C++中的const与static关键字

个人主页&#xff1a;北海 &#x1f390;CSDN新晋作者 &#x1f389;欢迎 &#x1f44d;点赞✍评论⭐收藏✨收录专栏&#xff1a;C/C&#x1f91d;希望作者的文章能对你有所帮助&#xff0c;有不足的地方请在评论区留言指正&#xff0c;大家一起学习交流&#xff01;&#x1f9…

玩转 PI 系列-看起来像服务器的 ARM 开发板矩阵-Firefly Cluster Server

前言 基于我个人的工作内容和兴趣&#xff0c;想要在家里搞一套服务器集群&#xff0c;用于容器/K8s 等方案的测试验证。 考虑过使用二手服务器&#xff0c;比如 Dell R730, 还搞了一套配置清单&#xff0c;如下&#xff1a; Dell R7303.5 尺寸规格硬盘CPU: 2686v4*2 内存&a…

DBO优化SVM的电力负荷预测,附MATLAB代码

今天为大家带来一期基于DBO-SVM的电力负荷预测。 原理详解 文章对支持向量机(SVM)的两个参数进行优化&#xff0c;分别是&#xff1a;惩罚系数c和 gamma。 其中&#xff0c;惩罚系数c表示对误差的宽容度。c越高&#xff0c;说明越不能容忍出现误差,容易过拟合。c越小&#xff0…

链表OJ练习(1)

一、移除链表元素 本题为力扣原题203 题目介绍&#xff1a; 给你一个链表的头节点 head 和一个整数 val &#xff0c;请你删除链表中所有满足 Node.val val 的节点&#xff0c;并返回 新的头节点 。 列表中的节点数目范围在 0~10000内 1<Node.val<50 0<val<50 …

基于VUE3+Layui从头搭建通用后台管理系统(前端篇)十一:通用表单组件封装实现

一、本章内容 本章实现通用表单组件,根据实体配置识别实体属性,并自动生成编辑组件,实现对应数据填充、校验及保存等逻辑。 1. 详细课程地址: 待发布 2. 源码下载地址: 待发布 二、界面预览 三、开发视频 3.1 B站视频地址:

OpenCV

文章目录 OpenCV学习报告读取图片和网络摄像头1.1 图片读取1.2 视频读取1.1.1 读取视频文件1.1.2读取网络摄像头 OpenCV基础功能调整、裁剪图像3.1 调整图像大小3.2 裁剪图像 图像上绘制形状和文本4.1 图像上绘制形状4.2图像上写文字 透视变换图像拼接颜色检测轮廓检测人脸检测…

【Nacos】使用Nacos进行服务发现、配置管理

Nacos Nacos是 Dynamic Naming and Configuration Service 的首字母简称&#xff0c;一个更易于构建云原生应用的动态服务发现、配置管理和服务管理平台。 版本说明&#xff1a;版本说明 alibaba/spring-cloud-alibaba Wiki GitHub <properties><java.version>…