Android——SQLite笔记本

package com.example.notebook;


import android.content.ContentValues;
import android.content.Context;
import android.database.Cursor;
import android.database.sqlite.SQLiteDatabase;
import android.database.sqlite.SQLiteOpenHelper;

public class ToDoDB extends SQLiteOpenHelper
{
	  private final static String DATABASE_NAME = "todo_db";
	  private final static int DATABASE_VERSION = 1;
	  private final static String TABLE_NAME = "todo_table";
	  public final static String FIELD_id = "_id";
	  public final static String FIELD_TEXT = "todo_text";
	  
	  public ToDoDB(Context context)
	  {
	    super(context, DATABASE_NAME, null, DATABASE_VERSION);
	  }

	@Override
	public void onCreate(SQLiteDatabase db) {
		// TODO Auto-generated method stub
		String sql = "CREATE TABLE " + TABLE_NAME + " (" + FIELD_id
		        + " INTEGER primary key autoincrement, " + " " + FIELD_TEXT + " text)";
		    db.execSQL(sql);
	}

	@Override
	public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
		// TODO Auto-generated method stub
		String sql = "DROP TABLE IF EXISTS " + TABLE_NAME;
	    db.execSQL(sql);
	    onCreate(db);
	}

	
	
	public Cursor select()
	  {
	    SQLiteDatabase db = this.getReadableDatabase();
	    Cursor cursor = db.query(TABLE_NAME, null, null, null, null, null, null);
	    return cursor;
	  }

	  public long insert(String text)
	  {
	    SQLiteDatabase db = this.getWritableDatabase();

	    ContentValues cv = new ContentValues();
	    cv.put(FIELD_TEXT, text);
	    long row = db.insert(TABLE_NAME, null, cv);
	    return row;
	  }

	  public void delete(int id)
	  {
	    SQLiteDatabase db = this.getWritableDatabase();
	    String where = FIELD_id + " = ?";
	    String[] whereValue =
	    { Integer.toString(id) };
	    db.delete(TABLE_NAME, where, whereValue);
	  }

	  public void update(int id, String text)
	  {
	    SQLiteDatabase db = this.getWritableDatabase();
	    String where = FIELD_id + " = ?";
	    String[] whereValue =
	    { Integer.toString(id) };

	    ContentValues cv = new ContentValues();
	    cv.put(FIELD_TEXT, text);
	    db.update(TABLE_NAME, cv, where, whereValue);
	  }
}
package com.example.notebook;




import cn.waps.AdView;
import cn.waps.AppConnect;
import cn.waps.MiniAdView;

import android.os.Bundle;
import android.app.Activity;
import android.view.Menu;
import android.database.Cursor;
import android.database.sqlite.SQLiteCursor;
import android.view.MenuItem;
import android.view.View;
import android.widget.AdapterView;
import android.widget.EditText;
import android.widget.LinearLayout;
import android.widget.ListView;
import android.widget.SimpleCursorAdapter;
import android.widget.TextView;

import android.media.MediaPlayer;

public class MainActivity extends Activity {

	  private ToDoDB myToDoDB;
	  private Cursor myCursor;
	  private ListView myListView;
	  private EditText myEditText;
	  private MediaPlayer sound,sound1;
	  private TextView showmore;
	  
	  private int _id;
	  protected final static int MENU_ADD = Menu.FIRST;
	  protected final static int MENU_EDIT = Menu.FIRST + 1;
	  protected final static int MENU_DELETE = Menu.FIRST + 2;
	  

	  
	@Override
	public boolean onOptionsItemSelected(MenuItem item) {
		// TODO Auto-generated method stub
		super.onOptionsItemSelected(item);
		switch(item.getItemId()){		
		case MENU_ADD:
	        this.addTodo();
	        break;
	      case MENU_EDIT:
	        this.editTodo();
	        break;
	      case MENU_DELETE:
	        this.deleteTodo();
	        break;
		}
		return super.onOptionsItemSelected(item);
	}

	@Override
	public void onCreate(Bundle savedInstanceState) {
		super.onCreate(savedInstanceState);
		setContentView(R.layout.qq);
		setTitle("微型记事本");
		//06e8abfabdbcb8f90a16d24e54fe5653
		//AppConnect.getInstance("06e8abfabdbcb8f90a16d24e54fe5653", "mmw", this);
		 
		AppConnect.getInstance(this);
		 
	    AppConnect.getInstance(this).setCrashReport(false);
	    
		myListView = (ListView) this.findViewById(R.id.myListView);
	    myEditText = (EditText) this.findViewById(R.id.myEditText);
	    showmore = (TextView)findViewById(R.id.showmore);
	    
	    	// 初始化自定义广告数据
	 		AppConnect.getInstance(this).initAdInfo();	
	 		
	 		// 初始化插屏广告数据
	 		AppConnect.getInstance(this).initPopAd(this);	 
	 		

	 		// 迷你广告调用方式    //定时的更新,点击后进入链接页面 送金币哦
	 		// AppConnect.getInstance(this).setAdBackColor(Color.argb(50, 120, 240, 120));//设置迷你广告背景颜色
	 		// AppConnect.getInstance(this).setAdForeColor(Color.YELLOW);//设置迷你广告文字颜色
	 		LinearLayout miniLayout = (LinearLayout) findViewById(R.id.miniAdLinearLayout);
	 		new MiniAdView(this, miniLayout).DisplayAd(15);// 10秒刷新一次		
	 		
	 		LinearLayout miniLayout2 = (LinearLayout) findViewById(R.id.miniAdLinearLayout2);
	 		new MiniAdView(this, miniLayout2).DisplayAd(15);// 10秒刷新一次	
	 		
	 		// 互动广告调用方式  在窗口固定位置显示一条广告 点击然后就直接下载了
	 		LinearLayout container = (LinearLayout) findViewById(R.id.AdLinearLayout);
	 		new AdView(this, container).DisplayAd();
	 		
	 		//显示插屏广告 窗口一样跳出来的那种  有个叉叉点了就关闭了 有时候第一次打开没有 第二次打开才会出现
	 		//也许是还没有下载 到缓存中,没有准备好
			//判断插屏广告是否已初始化完成,用于确定是否能成功调用插屏广告
			boolean hasPopAd = AppConnect.getInstance(this).hasPopAd(this);
			if(hasPopAd){
				AppConnect.getInstance(this).showPopAd(this);
				//根据指定的theme样式展示插屏广告,theme主要为系统样式id
				//AppConnect.getInstance(this).showPopAd(this, android.R.style.Theme_Translucent);
			}	
			
	    
		  sound  = new MediaPlayer();
		  sound = MediaPlayer.create(this,R.raw.welcome111);
		  
		  sound1  = new MediaPlayer();
		  sound1 = MediaPlayer.create(this,R.raw.welcome121);
	    
	    myToDoDB = new ToDoDB(this);
	    sound.start();
	    /*取得DataBase里的数据*/
	    myCursor = myToDoDB.select();

	    /* new SimpleCursorAdapter,并传入myCursor.显示的字段为todo_text */
	    SimpleCursorAdapter adapter = new SimpleCursorAdapter(this, R.layout.mylist,
	        myCursor, new String[] { ToDoDB.FIELD_TEXT }, new int[]
	        { R.id.myTextView1 });
	    myListView.setAdapter(adapter);
	    
	  //显示推荐列表
	    showmore.setOnClickListener(new TextView.OnClickListener()
	    {

			@Override
			public void onClick(View arg0) {
				// TODO Auto-generated method stub
				//显示推荐列表(综合)
				AppConnect.getInstance(MainActivity.this).showOffers(MainActivity.this);
				
			}

		     
		    });
	    
	    
	    
	    /*myListViewOnItemClickListener */
	    myListView.setOnItemClickListener(new AdapterView.OnItemClickListener()
	    {

	      @Override
	      public void onItemClick(AdapterView<?> arg0, View arg1, int arg2,
	          long arg3)
	      {
	        /*将myCursor移动到单机的值*/
	        myCursor.moveToPosition(arg2);
	        /* 获取字段_id的值 */
	        _id = myCursor.getInt(0);
	        /*取得字段todo_text的值*/
	        myEditText.setText(myCursor.getString(1));
	      }

	    });
	    
	    myListView
	        .setOnItemSelectedListener(new AdapterView.OnItemSelectedListener()
	        {

	          @Override
	          public void onItemSelected(AdapterView<?> arg0, View arg1, int arg2,
	              long arg3)
	          {
	            /* getSelectedItem所取得的是SQLiteCursor */
	            SQLiteCursor sc = (SQLiteCursor) arg0.getSelectedItem();
	            _id = sc.getInt(0);
	            myEditText.setText(sc.getString(1));
	          }

	          @Override
	          public void onNothingSelected(AdapterView<?> arg0)
	          {

	          }

	        });
	    
	  
		    
	}
	
	@Override
	public boolean onCreateOptionsMenu(Menu menu) {
		// Inflate the menu; this adds items to the action bar if it is present.
		//getMenuInflater().inflate(R.menu.main, menu);
		super.onCreateOptionsMenu(menu);
	    /* 添加三个 MENU */
	    menu.add(Menu.NONE, MENU_ADD, 0, R.string.strAddButton);
	    menu.add(Menu.NONE, MENU_EDIT, 0, R.string.strEditButton);
	    menu.add(Menu.NONE, MENU_DELETE, 0, R.string.strDeleteButton);
		return true;
	}

public void addTodo(){
	if (myEditText.getText().toString().equals(""))
	      return;
	    /*将数据添加到数据库*/
	    myToDoDB.insert(myEditText.getText().toString());
	    /* 重新查询 */
	    myCursor.requery();
	    
	    /*刷新myListView */
	    myListView.invalidateViews();
	    myEditText.setText("");
	    _id = 0;
	}

public void deleteTodo(){
	if(_id == 0)return;
	myToDoDB.delete(_id);
    myCursor.requery();
    myListView.invalidateViews();
    myEditText.setText("");
	_id=0;
}

public void editTodo(){
	if (myEditText.getText().toString().equals(""))
	      return;
	    /*将数据添加到数据库*/
	    myToDoDB.update(_id,myEditText.getText().toString());
	    /* 重新查询 */
	    myCursor.requery();
	    
	    /*刷新myListView */
	    myListView.invalidateViews();
	    myEditText.setText("");
	    _id = 0;
}


@Override
protected void onDestroy() {
	// TODO Auto-generated method stub			
	sound1.start();
	super.onDestroy();
}

}

 

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:orientation="vertical" 
    android:background="@drawable/bg">
 	<LinearLayout
            android:id="@+id/miniAdLinearLayout"
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            android:orientation="vertical" >
    </LinearLayout>
    <EditText
        android:id="@+id/myEditText"
        android:layout_width="match_parent"
        android:layout_height="56dp"
        android:text=""
        android:textAppearance="?android:attr/textAppearanceLarge" />
    <LinearLayout
            android:id="@+id/miniAdLinearLayout2"
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            android:orientation="vertical" >
    </LinearLayout>
    <ListView
        android:id="@+id/myListView"
        android:layout_width="match_parent"
        android:layout_height="wrap_content" 
        >
    </ListView>
     <LinearLayout
        android:id="@+id/AdLinearLayout"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:orientation="vertical" >
    </LinearLayout>

     <TextView
         android:id="@+id/showmore"
         android:layout_width="wrap_content"
         android:layout_height="wrap_content"
         android:text="更多应用下载~~" />

</LinearLayout>

 

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:orientation="vertical" >

    <CheckedTextView
        android:id="@+id/myTextView1"
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:text=" " />

</LinearLayout>

 

 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论
android开发期末大作业(项目源码,任务书,实验大报告,apk文件) 大作业的要求和内容:(包括题目选择范围、技术要求、递交时间、考核方法等) 一、实验项目名称 Android手机应用开发课程大作业 二、实验目的 1.通过本课程设计的实践及其前后的准备与总结,复习、领会、巩固和运用课堂上所学的Android手机应用开发知识。 2.为学生综合应用本专业所学习的多门课程知识(例如,软件工程、数据库、Java语言、Java Web开发等)创造实践机会。为学生提供主动学习、积极探索与大胆创新的机会。 3.掌握Android手机应用设计的方法与技巧。 三、实验内容及要求 1、设计内容 题目、设计内容自拟,工作量适中,要求学生应用课程所学知识,采用JAVA语言和Android手机应用开发技术实现一个完整的系统。 ①完成大作业报告。 ②实现各系统功能,并完成调试运行。 2、主要技术 采用Java语言并不仅限于Java语言实现系统。 开发环境与工具:Android Studio 3.2以上版本; 操作系统:Win7/Win10或其他; 4、设计成果: 材料上交:电子文档(大作业任务书+大作业报告+源代码,电子稿请刻在光盘上)、打印稿(大作业任务书+大作业报告)。 四、成绩评定: 考核标准包括: 1、选题的工作量,难度和新颖程度 2、系统架构设计是否良好,运行过程是否报错 3、界面设计的合理性和美观程度 4、基本功能的实现 分值60 (包括布局、组件、Activity、Intent等使用) 数据存储的使用 分值10 网络功能 分值10 Service、ContentProvider或BroadCastReceiver等的使用 分值10 附加分: 图形图像处理、多媒体处理等 分值10 5、考核方式为面对面答辩,在课程的后两周内集中进行。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

爆板流

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值