在Androidstudio中设计一个简单学生选课系统并给出代码

时间: 2024-06-07 08:12:05 浏览: 210
为了设计一个简单的学生选课系统,我们需要考虑以下几个方面: 1. 数据存储:我们需要在系统中存储学生和课程的信息,可以使用SQLite数据库进行存储。 2. 用户界面:我们需要提供一个界面来展示课程信息和学生信息,以及提供选课和退课的功能。 3. 业务逻辑:我们需要编写代码实现选课和退课的逻辑,以及显示课程和学生的信息。 下面是一个简单的学生选课系统的示例代码: 1. 首先,在Android Studio中创建一个新的项目,并添加SQLite库的依赖。 2. 创建一个名为Course的Java类,表示课程信息: ```java public class Course { private int id; private String name; private int capacity; public Course(int id, String name, int capacity) { this.id = id; this.name = name; this.capacity = capacity; } public int getId() { return id; } public String getName() { return name; } public int getCapacity() { return capacity; } public void setCapacity(int capacity) { this.capacity = capacity; } } ``` 3. 创建一个名为Student的Java类,表示学生信息: ```java public class Student { private int id; private String name; private List<Course> courses; public Student(int id, String name) { this.id = id; this.name = name; this.courses = new ArrayList<>(); } public int getId() { return id; } public String getName() { return name; } public List<Course> getCourses() { return courses; } public void addCourse(Course course) { courses.add(course); } public void removeCourse(Course course) { courses.remove(course); } } ``` 4. 创建一个名为DatabaseHelper的类,用于创建和管理SQLite数据库: ```java public class DatabaseHelper extends SQLiteOpenHelper { private static final String DATABASE_NAME = "courses.db"; private static final int DATABASE_VERSION = 1; private static final String TABLE_COURSES = "courses"; private static final String TABLE_STUDENTS = "students"; private static final String TABLE_SELECTIONS = "selections"; private static final String COLUMN_ID = "id"; private static final String COLUMN_NAME = "name"; private static final String COLUMN_CAPACITY = "capacity"; private static final String COLUMN_STUDENT_ID = "student_id"; private static final String COLUMN_COURSE_ID = "course_id"; private static final String CREATE_TABLE_COURSES = "CREATE TABLE " + TABLE_COURSES + "(" + COLUMN_ID + " INTEGER PRIMARY KEY AUTOINCREMENT," + COLUMN_NAME + " TEXT," + COLUMN_CAPACITY + " INTEGER)"; private static final String CREATE_TABLE_STUDENTS = "CREATE TABLE " + TABLE_STUDENTS + "(" + COLUMN_ID + " INTEGER PRIMARY KEY AUTOINCREMENT," + COLUMN_NAME + " TEXT)"; private static final String CREATE_TABLE_SELECTIONS = "CREATE TABLE " + TABLE_SELECTIONS + "(" + COLUMN_ID + " INTEGER PRIMARY KEY AUTOINCREMENT," + COLUMN_STUDENT_ID + " INTEGER," + COLUMN_COURSE_ID + " INTEGER," + "FOREIGN KEY(" + COLUMN_STUDENT_ID + ") REFERENCES " + TABLE_STUDENTS + "(" + COLUMN_ID + ")," + "FOREIGN KEY(" + COLUMN_COURSE_ID + ") REFERENCES " + TABLE_COURSES + "(" + COLUMN_ID + "))"; public DatabaseHelper(Context context) { super(context, DATABASE_NAME, null, DATABASE_VERSION); } @Override public void onCreate(SQLiteDatabase db) { db.execSQL(CREATE_TABLE_COURSES); db.execSQL(CREATE_TABLE_STUDENTS); db.execSQL(CREATE_TABLE_SELECTIONS); } @Override public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) { db.execSQL("DROP TABLE IF EXISTS " + TABLE_SELECTIONS); db.execSQL("DROP TABLE IF EXISTS " + TABLE_STUDENTS); db.execSQL("DROP TABLE IF EXISTS " + TABLE_COURSES); onCreate(db); } } ``` 5. 创建一个名为MainActivity的类,用于实现界面和选课逻辑: ```java public class MainActivity extends AppCompatActivity { private DatabaseHelper dbHelper; private ListView courseListView; private ListView studentListView; private List<Course> courseList; private List<Student> studentList; private CourseAdapter courseAdapter; private StudentAdapter studentAdapter; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); dbHelper = new DatabaseHelper(this); courseListView = findViewById(R.id.course_list_view); studentListView = findViewById(R.id.student_list_view); courseList = new ArrayList<>(); studentList = new ArrayList<>(); courseAdapter = new CourseAdapter(this, courseList); studentAdapter = new StudentAdapter(this, studentList); courseListView.setAdapter(courseAdapter); studentListView.setAdapter(studentAdapter); updateData(); courseListView.setOnItemClickListener(new AdapterView.OnItemClickListener() { @Override public void onItemClick(AdapterView<?> parent, View view, int position, long id) { Course course = courseList.get(position); showCourseDialog(course); } }); studentListView.setOnItemClickListener(new AdapterView.OnItemClickListener() { @Override public void onItemClick(AdapterView<?> parent, View view, int position, long id) { Student student = studentList.get(position); showStudentDialog(student); } }); } private void showCourseDialog(final Course course) { AlertDialog.Builder builder = new AlertDialog.Builder(this); builder.setTitle(course.getName()); View view = LayoutInflater.from(this).inflate(R.layout.dialog_course, null); TextView capacityTextView = view.findViewById(R.id.capacity_text_view); final EditText capacityEditText = view.findViewById(R.id.capacity_edit_text); capacityTextView.setText("Capacity: " + course.getCapacity()); capacityEditText.setText(String.valueOf(course.getCapacity())); builder.setView(view); builder.setPositiveButton("Save", new DialogInterface.OnClickListener() { @Override public void onClick(DialogInterface dialog, int which) { int capacity = Integer.parseInt(capacityEditText.getText().toString()); course.setCapacity(capacity); updateCourse(course); } }); builder.setNegativeButton("Cancel", null); builder.show(); } private void showStudentDialog(final Student student) { AlertDialog.Builder builder = new AlertDialog.Builder(this); builder.setTitle(student.getName()); View view = LayoutInflater.from(this).inflate(R.layout.dialog_student, null); final ListView courseListView = view.findViewById(R.id.course_list_view); List<Course> availableCourses = getAvailableCourses(student); CourseAdapter adapter = new CourseAdapter(this, availableCourses); courseListView.setAdapter(adapter); builder.setView(view); builder.setPositiveButton("Add", new DialogInterface.OnClickListener() { @Override public void onClick(DialogInterface dialog, int which) { int position = courseListView.getCheckedItemPosition(); if (position != ListView.INVALID_POSITION) { Course course = (Course) courseListView.getItemAtPosition(position); addCourse(student, course); } } }); builder.setNegativeButton("Remove", new DialogInterface.OnClickListener() { @Override public void onClick(DialogInterface dialog, int which) { List<Course> selectedCourses = getSelectedCourses(student); Course[] courses = new Course[selectedCourses.size()]; boolean[] checkedItems = new boolean[selectedCourses.size()]; for (int i = 0; i < selectedCourses.size(); i++) { courses[i] = selectedCourses.get(i); checkedItems[i] = false; } AlertDialog.Builder builder = new AlertDialog.Builder(MainActivity.this); builder.setTitle("Remove Courses"); builder.setMultiChoiceItems(courses, checkedItems, new DialogInterface.OnMultiChoiceClickListener() { @Override public void onClick(DialogInterface dialog, int which, boolean isChecked) { checkedItems[which] = isChecked; } }); builder.setPositiveButton("OK", new DialogInterface.OnClickListener() { @Override public void onClick(DialogInterface dialog, int which) { for (int i = 0; i < checkedItems.length; i++) { if (checkedItems[i]) { Course course = courses[i]; removeCourse(student, course); } } } }); builder.setNegativeButton("Cancel", null); builder.show(); } }); builder.show(); } private void updateData() { courseList.clear(); studentList.clear(); SQLiteDatabase db = dbHelper.getReadableDatabase(); Cursor cursor = db.rawQuery("SELECT * FROM " + DatabaseHelper.TABLE_COURSES, null); while (cursor.moveToNext()) { int id = cursor.getInt(cursor.getColumnIndex(DatabaseHelper.COLUMN_ID)); String name = cursor.getString(cursor.getColumnIndex(DatabaseHelper.COLUMN_NAME)); int capacity = cursor.getInt(cursor.getColumnIndex(DatabaseHelper.COLUMN_CAPACITY)); Course course = new Course(id, name, capacity); courseList.add(course); } cursor.close(); cursor = db.rawQuery("SELECT * FROM " + DatabaseHelper.TABLE_STUDENTS, null); while (cursor.moveToNext()) { int id = cursor.getInt(cursor.getColumnIndex(DatabaseHelper.COLUMN_ID)); String name = cursor.getString(cursor.getColumnIndex(DatabaseHelper.COLUMN_NAME)); Student student = new Student(id, name); studentList.add(student); } cursor.close(); for (Student student : studentList) { cursor = db.rawQuery("SELECT * FROM " + DatabaseHelper.TABLE_SELECTIONS + " WHERE " + DatabaseHelper.COLUMN_STUDENT_ID + " = ?", new String[]{String.valueOf(student.getId())}); while (cursor.moveToNext()) { int courseId = cursor.getInt(cursor.getColumnIndex(DatabaseHelper.COLUMN_COURSE_ID)); for (Course course : courseList) { if (course.getId() == courseId) { student.addCourse(course); break; } } } cursor.close(); } courseAdapter.notifyDataSetChanged(); studentAdapter.notifyDataSetChanged(); } private void updateCourse(Course course) { SQLiteDatabase db = dbHelper.getWritableDatabase(); ContentValues values = new ContentValues(); values.put(DatabaseHelper.COLUMN_NAME, course.getName()); values.put(DatabaseHelper.COLUMN_CAPACITY, course.getCapacity()); db.update(DatabaseHelper.TABLE_COURSES, values, DatabaseHelper.COLUMN_ID + " = ?", new String[]{String.valueOf(course.getId())}); updateData(); } private List<Course> getAvailableCourses(Student student) { List<Course> availableCourses = new ArrayList<>(); for (Course course : courseList) { if (!student.getCourses().contains(course) && course.getCapacity() > 0) { availableCourses.add(course); } } return availableCourses; } private List<Course> getSelectedCourses(Student student) { List<Course> selectedCourses = new ArrayList<>(); for (Course course : courseList) { if (student.getCourses().contains(course)) { selectedCourses.add(course); } } return selectedCourses; } private void addCourse(Student student, Course course) { SQLiteDatabase db = dbHelper.getWritableDatabase(); ContentValues values = new ContentValues(); values.put(DatabaseHelper.COLUMN_STUDENT_ID, student.getId()); values.put(DatabaseHelper.COLUMN_COURSE_ID, course.getId()); db.insert(DatabaseHelper.TABLE_SELECTIONS, null, values); updateData(); } private void removeCourse(Student student, Course course) { SQLiteDatabase db = dbHelper.getWritableDatabase(); db.delete(DatabaseHelper.TABLE_SELECTIONS, DatabaseHelper.COLUMN_STUDENT_ID + " = ? AND " + DatabaseHelper.COLUMN_COURSE_ID + " = ?", new String[]{String.valueOf(student.getId()), String.valueOf(course.getId())}); updateData(); } private static class CourseAdapter extends ArrayAdapter<Course> { public CourseAdapter(Context context, List<Course> courses) { super(context, 0, courses); } @NonNull @Override public View getView(int position, @Nullable View convertView, @NonNull ViewGroup parent) { if (convertView == null) { convertView = LayoutInflater.from(getContext()).inflate(android.R.layout.simple_list_item_1, parent, false); } Course course = getItem(position); TextView textView = convertView.findViewById(android.R.id.text1); textView.setText(course.getName()); return convertView; } } private static class StudentAdapter extends ArrayAdapter<Student> { public StudentAdapter(Context context, List<Student> students) { super(context, 0, students); } @NonNull @Override public View getView(int position, @Nullable View convertView, @NonNull ViewGroup parent) { if (convertView == null) { convertView = LayoutInflater.from(getContext()).inflate(android.R.layout.simple_list_item_1, parent, false); } Student student = getItem(position); TextView textView = convertView.findViewById(android.R.id.text1); textView.setText(student.getName()); return convertView; } } } ``` 6. 最后,在布局文件中添加ListView和对话框的布局: ```xml <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" android:orientation="horizontal" android:layout_width="match_parent" android:layout_height="match_parent"> <ListView android:id="@+id/course_list_view" android:layout_width="0dp" android:layout_height="match_parent" android:layout_weight="1"/> <ListView android:id="@+id/student_list_view" android:layout_width="0dp" android:layout_height="match_parent" android:layout_weight="1"/> </LinearLayout> ``` ```xml <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" android:orientation="vertical" android:layout_width="wrap_content" android:layout_height="wrap_content"> <TextView android:id="@+id/capacity_text_view" android:layout_width="wrap_content" android:layout_height="wrap_content"/> <EditText android:id="@+id/capacity_edit_text" android:layout_width="match_parent" android:layout_height="wrap_content"/> </LinearLayout> ``` ```xml <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" android:orientation="vertical" android:layout_width="wrap_content" android:layout_height="wrap_content"> <ListView android:id="@+id/course_list_view" android:layout_width="match_parent" android:layout_height="wrap_content" android:choiceMode="single"/> </LinearLayout> ``` ```xml <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" android:orientation="vertical" android:layout_width="wrap_content" android:layout_height="wrap_content"> <ListView android:id="@+id/course_list_view" android:layout_width="match_parent" android:layout_height="wrap_content" android:choiceMode="multiple"/> </LinearLayout> ``` 这样,一个简单的学生选课系统就完成了。
阅读全文

相关推荐

zip

最新推荐

recommend-type

直接可用的Android studio学生信息管理系统

Android Studio 学生信息管理系统是一个基于 Android Studio 平台开发的学生信息管理系统,旨在提供一个功能完善的学生信息管理解决方案。下面将详细介绍该系统的设计和实现。 一、系统架构设计 Android Studio ...
recommend-type

android studio实现简单考试应用程序实例代码详解

在本文中,我们将介绍如何使用Android Studio实现一个简单的考试应用程序实例代码。 knowledge point 1: Android Studio简介 Android Studio是Google推出的一个集成开发环境(IDE),它提供了一个功能强大且灵活...
recommend-type

解决Android Studio 代码自动提示突然失效的问题

首先,我们要明白Android Studio的代码自动提示功能依赖于一个有效的索引,这个索引是由IDE内部构建的,用于快速访问项目中的类、方法和变量。当省电模式被激活时,Android Studio可能会关闭索引的构建过程,以节省...
recommend-type

解决Android Studio 代码无提示无颜色区分问题

本篇文章将详细阐述如何解决Android Studio中代码无提示无颜色区分的问题。 一、问题描述 1. **颜色区分缺失**:当Android Studio中的Java代码全部显示为黑色,没有颜色差异时,这意味着代码高亮功能可能未启用或...
recommend-type

Android studio创建第一个app

在本文中,我们将深入探讨如何使用Android Studio创建你的第一个应用程序——经典的“Hello World”。Android Studio是Google提供的官方集成开发环境(IDE),专为Android应用开发设计。下面,我们将详细讲解创建项目...
recommend-type

JavaScript实现的高效pomodoro时钟教程

资源摘要信息:"JavaScript中的pomodoroo时钟" 知识点1:什么是番茄工作法 番茄工作法是一种时间管理技术,它是由弗朗西斯科·西里洛于1980年代末发明的。该技术使用一个定时器来将工作分解为25分钟的块,这些时间块之间短暂休息。每个时间块被称为一个“番茄”,因此得名“番茄工作法”。该技术旨在帮助人们通过短暂的休息来提高集中力和生产力。 知识点2:JavaScript是什么 JavaScript是一种高级的、解释执行的编程语言,它是网页开发中最主要的技术之一。JavaScript主要用于网页中的前端脚本编写,可以实现用户与浏览器内容的交云互动,也可以用于服务器端编程(Node.js)。JavaScript是一种轻量级的编程语言,被设计为易于学习,但功能强大。 知识点3:使用JavaScript实现番茄钟的原理 在使用JavaScript实现番茄钟的过程中,我们需要用到JavaScript的计时器功能。JavaScript提供了两种计时器方法,分别是setTimeout和setInterval。setTimeout用于在指定的时间后执行一次代码块,而setInterval则用于每隔一定的时间重复执行代码块。在实现番茄钟时,我们可以使用setInterval来模拟每25分钟的“番茄时间”,使用setTimeout来控制每25分钟后的休息时间。 知识点4:如何在JavaScript中设置和重置时间 在JavaScript中,我们可以使用Date对象来获取和设置时间。Date对象允许我们获取当前的日期和时间,也可以让我们创建自己的日期和时间。我们可以通过new Date()创建一个新的日期对象,并使用Date对象提供的各种方法,如getHours(), getMinutes(), setHours(), setMinutes()等,来获取和设置时间。在实现番茄钟的过程中,我们可以通过获取当前时间,然后加上25分钟,来设置下一个番茄时间。同样,我们也可以通过获取当前时间,然后减去25分钟,来重置上一个番茄时间。 知识点5:实现pomodoro-clock的基本步骤 首先,我们需要创建一个定时器,用于模拟25分钟的工作时间。然后,我们需要在25分钟结束后提醒用户停止工作,并开始短暂的休息。接着,我们需要为用户的休息时间设置另一个定时器。在用户休息结束后,我们需要重置定时器,开始下一个工作周期。在这个过程中,我们需要为每个定时器设置相应的回调函数,以处理定时器触发时需要执行的操作。 知识点6:使用JavaScript实现pomodoro-clock的优势 使用JavaScript实现pomodoro-clock的优势在于JavaScript的轻量级和易学性。JavaScript作为前端开发的主要语言,几乎所有的现代浏览器都支持JavaScript。因此,我们可以很容易地在网页中实现pomodoro-clock,用户只需要打开网页即可使用。此外,JavaScript的灵活性也使得我们可以根据需要自定义pomodoro-clock的各种参数,如工作时间长度、休息时间长度等。
recommend-type

管理建模和仿真的文件

管理Boualem Benatallah引用此版本:布阿利姆·贝纳塔拉。管理建模和仿真。约瑟夫-傅立叶大学-格勒诺布尔第一大学,1996年。法语。NNT:电话:00345357HAL ID:电话:00345357https://theses.hal.science/tel-003453572008年12月9日提交HAL是一个多学科的开放存取档案馆,用于存放和传播科学研究论文,无论它们是否被公开。论文可以来自法国或国外的教学和研究机构,也可以来自公共或私人研究中心。L’archive ouverte pluridisciplinaire
recommend-type

【WebLogic客户端兼容性提升秘籍】:一站式解决方案与实战案例

![WebLogic](https://docs.oracle.com/cd/F28299_01/pt857pbr3/eng/pt/tsvt/img/ia2cf27cn-7b68.png) # 摘要 WebLogic作为一款广泛使用的中间件产品,其客户端兼容性对于企业应用至关重要。本文从基本概念出发,系统地介绍了WebLogic的架构、组件以及兼容性问题的分类和影响。通过深入分析兼容性测试方法和诊断分析技术,探讨了如何有效地识别和解决客户端兼容性问题。进一步,本文提出了提升兼容性的策略,包括代码层面的设计、配置管理、补丁升级以及快速响应流程。最后,结合实战案例,本文详细说明了解决方案的实施过
recommend-type

使用jupyter读取文件“近5年考试人数.csv”,绘制近5年高考及考研人数发展趋势图,数据如下(单位:万人)。

在Jupyter Notebook中读取CSV文件并绘制图表,通常需要几个步骤: 1. 首先,你需要导入必要的库,如pandas用于数据处理,matplotlib或seaborn用于数据可视化。 ```python import pandas as pd import matplotlib.pyplot as plt ``` 2. 使用`pd.read_csv()`函数加载CSV文件: ```python df = pd.read_csv('近5年考试人数.csv') ``` 3. 确保数据已经按照年份排序,如果需要的话,可以添加这一行: ```python df = df.sor
recommend-type

CMake 3.25.3版本发布:程序员必备构建工具

资源摘要信息:"Cmake-3.25.3.zip文件是一个包含了CMake软件版本3.25.3的压缩包。CMake是一个跨平台的自动化构建系统,用于管理软件的构建过程,尤其是对于C++语言开发的项目。CMake使用CMakeLists.txt文件来配置项目的构建过程,然后可以生成不同操作系统的标准构建文件,如Makefile(Unix系列系统)、Visual Studio项目文件等。CMake广泛应用于开源和商业项目中,它有助于简化编译过程,并支持生成多种开发环境下的构建配置。 CMake 3.25.3版本作为该系列软件包中的一个点,是CMake的一个稳定版本,它为开发者提供了一系列新特性和改进。随着版本的更新,3.25.3版本可能引入了新的命令、改进了用户界面、优化了构建效率或解决了之前版本中发现的问题。 CMake的主要特点包括: 1. 跨平台性:CMake支持多种操作系统和编译器,包括但不限于Windows、Linux、Mac OS、FreeBSD、Unix等。 2. 编译器独立性:CMake生成的构建文件与具体的编译器无关,允许开发者在不同的开发环境中使用同一套构建脚本。 3. 高度可扩展性:CMake能够使用CMake模块和脚本来扩展功能,社区提供了大量的模块以支持不同的构建需求。 4. CMakeLists.txt:这是CMake的配置脚本文件,用于指定项目源文件、库依赖、自定义指令等信息。 5. 集成开发环境(IDE)支持:CMake可以生成适用于多种IDE的项目文件,例如Visual Studio、Eclipse、Xcode等。 6. 命令行工具:CMake提供了命令行工具,允许用户通过命令行对构建过程进行控制。 7. 可配置构建选项:CMake支持构建选项的配置,使得用户可以根据需要启用或禁用特定功能。 8. 包管理器支持:CMake可以从包管理器中获取依赖,并且可以使用FetchContent或ExternalProject模块来获取外部项目。 9. 测试和覆盖工具:CMake支持添加和运行测试,并集成代码覆盖工具,帮助开发者对代码进行质量控制。 10. 文档和帮助系统:CMake提供了一个内置的帮助系统,可以为用户提供命令和变量的详细文档。 CMake的安装和使用通常分为几个步骤: - 下载并解压对应平台的CMake软件包。 - 在系统中配置CMake的环境变量,确保在命令行中可以全局访问cmake命令。 - 根据项目需要编写CMakeLists.txt文件。 - 在含有CMakeLists.txt文件的目录下执行cmake命令生成构建文件。 - 使用生成的构建文件进行项目的构建和编译工作。 CMake的更新和迭代通常会带来更好的用户体验和更高效的构建过程。对于开发者而言,及时更新到最新稳定版本的CMake是保持开发效率和项目兼容性的重要步骤。而对于新用户,掌握CMake的使用则是学习现代软件构建技术的一个重要方面。"