zoukankan      html  css  js  c++  java
  • 购物车

    <?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:padding="16dp" >
    
        <LinearLayout
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            android:layout_marginTop="20dp" >
    
            <TextView
                android:layout_width="wrap_content"
                android:layout_height="wrap_content"
                android:text="商品名称 :"
                android:textSize="18sp" />
    
            <EditText
                android:id="@+id/et_name"
                android:layout_width="match_parent"
                android:layout_height="wrap_content"
                android:hint="请输入商品名称"
                android:textSize="16sp" />
        </LinearLayout>
    
        <LinearLayout
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            android:layout_marginBottom="10dp" >
    
            <TextView
                android:layout_width="wrap_content"
                android:layout_height="wrap_content"
                android:text="价格:"
                android:textSize="18sp" />
    
            <EditText
                android:id="@+id/et_price"
                android:layout_width="match_parent"
                android:layout_height="wrap_content"
                android:hint="输入价格"
                android:textSize="16sp" />
        </LinearLayout>
    
        <LinearLayout
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
    
            android:layout_marginBottom="10dp" >
    
            <TextView
                android:layout_width="wrap_content"
                android:layout_height="wrap_content"
                android:text="数量:"
                android:textSize="18sp" />
    
            <EditText
                android:id="@+id/et_num"
                android:layout_width="match_parent"
                android:layout_height="wrap_content"
                android:hint="输入数量"
                android:textSize="16sp" />
        </LinearLayout>
        <LinearLayout
            android:layout_width="match_parent"
            android:layout_height="wrap_content" >
    
            <Button
                android:id="@+id/btn_add"
                android:layout_width="0dp"
                android:layout_height="wrap_content"
                android:layout_marginRight="2dp"
                android:layout_weight="1"
                android:background="#B9B9FF"
                android:onClick="add"
                android:text="添加"
                android:textSize="18sp" />
    
            <Button
                android:id="@+id/btn_query"
                android:layout_width="0dp"
                android:layout_height="wrap_content"
                android:layout_marginRight="2dp"
                android:layout_weight="1"
                android:background="#DCB5FF"
                android:onClick="search"
                android:text="查询"
                android:textSize="18sp" />
    
            <Button
                android:id="@+id/btn_update"
                android:layout_width="0dp"
                android:layout_height="wrap_content"
                android:layout_marginRight="2dp"
                android:layout_weight="1"
                android:background="#E6CAFF"
                android:onClick="update"
                android:text="修改"
                android:textSize="18sp" />
    
            <Button
                android:id="@+id/btn_delete"
                android:layout_width="0dp"
                android:layout_height="wrap_content"
                android:layout_weight="1"
                android:background="#ACD6FF"
                android:onClick="delete"
                android:text="删除"
                android:textSize="18sp" />
        </LinearLayout>
    
    
    
            <ListView
                android:id="@+id/tv_show"
                android:layout_width="match_parent"
                android:layout_height="wrap_content"
                android:layout_marginTop="25dp"
                android:textSize="20sp"
                />
    
    
    </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="wrap_content"
        android:orientation="horizontal"
        android:padding="10dp">
        <ImageView
            android:layout_width="100dp"
            android:layout_height="120dp"
            android:src="@drawable/ic_launcher_background"/>
        <LinearLayout
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            android:layout_gravity="center"
            android:orientation="vertical">
            <TextView
                android:id="@+id/tv_id"
                android:layout_marginLeft="20dp"
                android:layout_width="match_parent"
                android:layout_height="wrap_content"
                android:textSize="20sp"/>
            <TextView
                android:id="@+id/tv_name"
                android:layout_marginLeft="20dp"
                android:layout_width="match_parent"
                android:layout_height="wrap_content"
                android:textSize="20sp"/>
            <TextView
                android:id="@+id/tv_price"
                android:layout_marginLeft="20dp"
                android:layout_width="match_parent"
                android:layout_height="wrap_content"
                android:layout_marginTop="3dp"
                android:textSize="20sp"/>
            <TextView
                android:id="@+id/tv_num"
                android:layout_marginLeft="20dp"
                android:layout_width="match_parent"
                android:layout_height="wrap_content"
                android:layout_marginTop="3dp"
                android:textSize="20sp"/>
        </LinearLayout>
    
    
    
    </LinearLayout>
    package com.example.myapplication;
    
    import android.os.Bundle;
    import android.app.Activity;
    import android.content.ContentValues;
    import android.database.Cursor;
    import android.database.sqlite.SQLiteDatabase;
    import android.view.Menu;
    import android.view.View;
    import android.view.ViewGroup;
    import android.widget.ArrayAdapter;
    import android.widget.BaseAdapter;
    import android.widget.EditText;
    import android.widget.ListView;
    import android.widget.TextView;
    import android.widget.Toast;
    
    import java.util.ArrayList;
    import java.util.List;
    
    public class MainActivity extends Activity {
        List<Shopping> list  = new ArrayList<Shopping>();
        @Override
        protected void onCreate(Bundle savedInstanceState) {
            super.onCreate(savedInstanceState);
            setContentView(R.layout.activity_main);
        }
    
        public void add(View v) {
            StuOpenHelper helper = new StuOpenHelper(this);
            SQLiteDatabase db = helper.getWritableDatabase();
            String name = ((EditText) findViewById(R.id.et_name)).getText()
                    .toString();
            int price = Integer.parseInt(((EditText) findViewById(R.id.et_price))
                    .getText().toString());
            int num = Integer.parseInt(((EditText) findViewById(R.id.et_num))
                    .getText().toString());
            // 原生sql操作,
            // db.execSQL("insert into stuinfo (name,age) values('lisi',22)");
            // db.execSQL("insert into stuinfo (name,age) values(?,?)",new
            // Object[]{"kitty",30});
            db.execSQL("insert into shoppinfo (name,price,num) values(?,?,?)", new Object[] {
                    name, price,num });
            Toast.makeText(this, "ok", 0).show();
    
        }
    
        public void delete(View view) {
            StuOpenHelper helper = new StuOpenHelper(this);
            SQLiteDatabase db = helper.getWritableDatabase();
            String name = ((EditText) findViewById(R.id.et_name)).getText()
                    .toString();
            db.execSQL("delete from shoppinfo where name=?", new Object[] { name });
            Toast.makeText(this, "删除成功", 0).show();
    
        }
    
        public void update(View view) {
            StuOpenHelper helper = new StuOpenHelper(this);
            SQLiteDatabase db = helper.getWritableDatabase();
            String name = ((EditText) findViewById(R.id.et_name)).getText()
                    .toString();
    
            int price = Integer.parseInt(((EditText) findViewById(R.id.et_price))
                    .getText().toString());
            int num = Integer.parseInt(((EditText) findViewById(R.id.et_num))
                    .getText().toString());
            db.execSQL("update shoppinfo set price=?,num=? where name=?", new Object[] {
                    price,num,name });
            Toast.makeText(this, "修改成功", 0).show();
    
        }
    
        public void search(View view) {
            StuOpenHelper helper = new StuOpenHelper(this);
            SQLiteDatabase db = helper.getWritableDatabase();
    //        String s = "";
            Cursor cursor = db.rawQuery("select * from shoppinfo", null);
            if (cursor.getCount() != 0) {
                while (cursor.moveToNext()) {
                    list.add(new Shopping(cursor.getInt(0),cursor.getString(1),cursor.getInt(2),cursor.getInt(3)));
                }
            }
    
            // Toast.makeText(this, s, 0).show();
    //        ((TextView) (findViewById(R.id.tv_show))).setText(s);
            ListView li = (ListView) findViewById(R.id.tv_show);
            li.setAdapter(new shopAdapter());
        }
        class  shopAdapter  extends BaseAdapter{
    
    
            @Override
            public int getCount() {
                return list.size();
            }
    
            @Override
            public Object getItem(int i) {
                return null;
            }
    
            @Override
            public long getItemId(int i) {
                return 0;
            }
    
            @Override
            public View getView(int position, View converView, ViewGroup parent) {
                View view = View.inflate(MainActivity.this,R.layout.list_item,null);
                TextView id = (TextView) view.findViewById(R.id.tv_id);
                TextView name = (TextView) view.findViewById(R.id.tv_name);
                TextView price = (TextView) view.findViewById(R.id.tv_price);
                TextView num = (TextView) view.findViewById(R.id.tv_num);
                id.setText(list.get(position).getId()+"   ");
                name.setText(list.get(position).getName()+"   ");
                price.setText(list.get(position).getPrice()+"   ");
                num.setText(list.get(position).getNum()+"   ");
                return view;
            }
    
            }
        }
    package com.example.myapplication;
    
    public class Shopping {
        private  int id;
        private  String name;
        private  int price;
        private  int num;
    
        public Shopping(){
    
        }
        public Shopping(int id,String name,int price,int num){
            this.id=id;
            this.name=name;
            this.price=price;
            this.num=num;
        }
        public void setId(int id) {
            this.id = id;
        }
    
        public void setName(String name) {
            this.name = name;
        }
    
        public void setPrice(int price) {
            this.price = price;
        }
    
        public void setNum(int num) {
            this.num = num;
        }
    
        public int getNum() {
            return num;
        }
    
        public String getName() {
            return name;
        }
    
        public int getPrice() {
            return price;
        }
    
        public int getId() {
            return id;
        }
    }
    package com.example.myapplication;
    
    import android.content.Context;
    import android.database.sqlite.SQLiteDatabase;
    import android.database.sqlite.SQLiteDatabase.CursorFactory;
    import android.database.sqlite.SQLiteOpenHelper;
    
    public class StuOpenHelper extends SQLiteOpenHelper {
    
        public StuOpenHelper(Context context) {
            super(context, "shop.db", null, 1);
            // TODO Auto-generated constructor stub
        }
    
        @Override
        public void onCreate(SQLiteDatabase db) {
            // TODO Auto-generated method stub
            db.execSQL("create table shoppinfo(_id integer primary key autoincrement,name varchar(20),price integer,num integer)");
    
        }
    
        @Override
        public void onUpgrade(SQLiteDatabase arg0, int arg1, int arg2) {
            // TODO Auto-generated method stub
    
        }
    
    }

    内容提供者读取信息

    package com.example.test;
    
    import android.content.ContentProvider;
    import android.content.ContentValues;
    import android.content.UriMatcher;
    import android.database.Cursor;
    import android.database.sqlite.SQLiteDatabase;
    import android.net.Uri;
    
    public class MyProvider extends ContentProvider {
        
        public static UriMatcher um=new UriMatcher(-1);
        static{
            //添加uri匹配规则
            um.addURI("com.gd.db.infodb", "query", 1);
            um.addURI("com.gd.db.infodb", "delete", 2);
            um.addURI("com.gd.db.infodb", "update", 3);
            um.addURI("com.gd.db.infodb", "add", 4);
            //content://com.gd.db.infodb/query  查询
            //content://com.gd.db.infodb/delete  删除
            //content://com.gd.db.infodb/update  修改
            //content://com.gd.db.infodb/add  添加
        }
        
    
        @Override
        public int delete(Uri arg0, String arg1, String[] arg2) {
            // TODO Auto-generated method stub
            return 0;
        }
    
        @Override
        public String getType(Uri arg0) {
            // TODO Auto-generated method stub
            return null;
        }
    
        @Override
        public Uri insert(Uri arg0, ContentValues arg1) {
            // TODO Auto-generated method stub
            return null;
        }
    
        @Override
        public boolean onCreate() {
            // TODO Auto-generated method stub
            return false;
        }
    
        @Override
        public Cursor query(Uri uri, String[] a, String b, String[] c,
                String d) {
            //uri:用户操作的路径
            int i=um.match(uri);
            if(i==1){
                MyHelper helper=new MyHelper(getContext());
                SQLiteDatabase db=helper.getWritableDatabase();
                return db.query("cart", a, b, c, null,null,d);
                
                
            }else{
                throw new RuntimeException("uri路径错误");
            }
            
        }
    
        @Override
        public int update(Uri arg0, ContentValues arg1, String arg2, String[] arg3) {
            // TODO Auto-generated method stub
            return 0;
        }
    
    }
    package com.example.other;
    
    import android.net.Uri;
    import android.os.Bundle;
    import android.app.Activity;
    import android.content.ContentResolver;
    import android.database.Cursor;
    import android.view.Menu;
    
    public class MainActivity extends Activity {
    
        @Override
        protected void onCreate(Bundle savedInstanceState) {
            super.onCreate(savedInstanceState);
            setContentView(R.layout.activity_main);        
            //使用内容提供者去访问数据
            ContentResolver resolver=getContentResolver();
            //利用解析器去获取数据
            
            Uri uri=Uri.parse("content://com.gd.db.infodb/query");
            Cursor cursor=resolver.query(uri, null, null, null, null);
            while(cursor.moveToNext()){
                int id=cursor.getInt(cursor.getColumnIndex("_id"));
                String name=cursor.getString(cursor.getColumnIndex("name"));
                System.out.println(id+"-"+name);
            }
            cursor.close();
        }
    
    
    
    }
  • 相关阅读:
    System.Collections.Generic.KeyValuePair.cs
    物理-三菱镜-三菱镜效应:三菱镜效应 百科
    物理-光学仪器-三菱镜:三菱镜 百科
    公司-IT-Mercari:Mercari 百科
    公司-IT-SanSan:SanSan
    汉语-词汇:资源
    Inside GDALAllRegister之三: 注册指定驱动
    android-文字的处理-随心
    source insight中{}自动缩进的调整
    IOS效率提升工具
  • 原文地址:https://www.cnblogs.com/qq-77/p/14132522.html
Copyright © 2011-2022 走看看