Soru & Cevap

Listview içerisindeki sayıların toplamını yazdırma

27.07.2014 - 12:14

Merhaba aranıza yeni katıldım.Takıldığım konu şu;

1.sorum :Fotodaki gibi Test3 deki girilen değerlerin toplamını nasıl bulabilirim.

2.sorum :Listedeki değerlere basılı tutduğumda o değeri databaseden nasıl silerim.

[code]

package com.student;

import java.util.ArrayList;
import java.util.List;

import android.app.Activity;
import android.content.ContentValues;
import android.content.Context;
import android.database.Cursor;
import android.database.sqlite.SQLiteDatabase;
import android.os.Bundle;
import android.util.Log;
import android.view.LayoutInflater;
import android.view.View;
import android.view.View.OnClickListener;
import android.view.ViewGroup;
import android.widget.BaseAdapter;
import android.widget.Button;
import android.widget.EditText;
import android.widget.ListView;
import android.widget.TextView;
import android.widget.Toast;

public class Main extends Activity implements OnClickListener {
    EditText et_name, et_t1, et_t2, et_t3;
    Button btn_save;
    ListView listView;
    String name, t1, t2, t3;

    List<String> list_name = new ArrayList<String>();
    List<Integer> list_t1 = new ArrayList<Integer>();
    List<Integer> list_t2 = new ArrayList<Integer>();
    List<Integer> list_t3 = new ArrayList<Integer>();
    static String[] arr_name;
    static Integer[] arr_t1;
    static Integer[] arr_t2;
    static Integer[] arr_t3;

    @Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.main);

        et_name = (EditText) findViewById(R.id.et_name);
        et_t1 = (EditText) findViewById(R.id.et_t1);
        et_t2 = (EditText) findViewById(R.id.et_t2);
        et_t3 = (EditText) findViewById(R.id.et_t3);
        btn_save = (Button) findViewById(R.id.btn_save);
        btn_save.setOnClickListener(this);
        
        
        //deleteDatabase();
        readDBdata();
        listView = (ListView) findViewById(R.id.lv_Marks);
        listView.setAdapter(new EfficientAdapter(this));
    
    }

    @Override
    public void onClick(View v) {

        if (v == btn_save) {
            if (et_name.length() <= 0 || et_t1.length() <= 0
                    || et_t2.length() <= 0 || et_t3.length() <= 0) {
                Toast.makeText(this, "Please fill each field",
                        Toast.LENGTH_SHORT).show();
                return;
            }
            name = et_name.getText().toString();
            t1 = et_t1.getText().toString();
            t2 = et_t2.getText().toString();
            t3 = et_t3.getText().toString();
            
            DatabaseHelper dbh = new DatabaseHelper(this);
            SQLiteDatabase db = dbh.getWritableDatabase();
            ContentValues cv = new ContentValues();
            cv.put(dbh.name, name);
            cv.put(dbh.t1, t1);
            cv.put(dbh.t2, t2);
            cv.put(dbh.t3, t3);
            try {
                // db.insert(dbh.tbl_student, null, cv); or
                db.insertOrThrow(dbh.tbl_student, null, cv);
            } catch (Exception ex) {
                Toast.makeText(this,
                        "Sorry data can't be saved. error:" + ex.toString(),
                        Toast.LENGTH_SHORT).show();
            } finally {
                db.close();
            }
            Toast.makeText(this, "Data has been saved.", Toast.LENGTH_SHORT)
                    .show();
            readDBdata();
            listView.setAdapter(new EfficientAdapter(this));
        }
    }

    public void readDBdata() {
        DatabaseHelper dbh = new DatabaseHelper(this);
        SQLiteDatabase db = dbh.getWritableDatabase();
        list_name.clear();
        list_t1.clear();
        list_t2.clear();
        list_t3.clear();
        Cursor cursor = db.rawQuery("Select " + dbh.name + "," + dbh.t1 + ","
                + dbh.t2 + "," + dbh.t3 + " from tbl_student;", null);

        if (cursor.moveToFirst()) {
            do {
                list_name.add(cursor.getString(0));
                list_t1.add(cursor.getInt(1));
                list_t2.add(cursor.getInt(2));
                list_t3.add(cursor.getInt(3));
            } while (cursor.moveToNext());
        }
        if (cursor != null && !cursor.isClosed()) {
            cursor.close();
        }
        db.close();
        arr_name = new String[list_name.size()];
        arr_t1 = new Integer[list_t1.size()];
        arr_t2 = new Integer[list_t2.size()];
        arr_t3 = new Integer[list_t3.size()];

        for (int i = 0; i < list_name.size(); i++) {
            arr_name[i] = list_name.get(i);
            arr_t1[i] = list_t1.get(i);
            arr_t2[i] = list_t2.get(i);
            arr_t3[i] = list_t3.get(i);
            
        }
        
        
        Toast.makeText(this, list_t3.toString(), Toast.LENGTH_SHORT).show();
    }

    

    private static class EfficientAdapter extends BaseAdapter {
        private LayoutInflater mInflater;

        public EfficientAdapter(Context context) {
            mInflater = LayoutInflater.from(context);
        }

        public int getCount() {
            return arr_name.length;
        }

        public Object getItem(int position) {
            return position;
        }

        public long getItemId(int position) {
            return position;
        }

        public View getView(int position, View convertView, ViewGroup parent) {
            ViewHolder holder;
            if (convertView == null) {
                convertView = mInflater.inflate(R.layout.three_col_row, null);
                holder = new ViewHolder();
                holder.text1 = (TextView) convertView
                        .findViewById(R.id.TextView01);
                holder.text2 = (TextView) convertView
                        .findViewById(R.id.TextView02);
                holder.text3 = (TextView) convertView
                        .findViewById(R.id.TextView03);

                convertView.setTag(holder);
            } else {
                holder = (ViewHolder) convertView.getTag();
            }

            holder.text1.setText(arr_name[position]);
            holder.text2.setText(String.valueOf(arr_t1[position] + ", "
                    + arr_t2[position] + ", " + arr_t3[position]));
            holder.text3.setText(String.valueOf(4555555));
            
            return convertView;
        }

        static class ViewHolder {
            TextView text1;
            TextView text2;
            TextView text3;
        }
    }
    public void deleteDatabase() {
        DatabaseHelper dbh = new DatabaseHelper(this);
        SQLiteDatabase SQLDb = dbh.getWritableDatabase();
        dbh.close();
        SQLDb.close();
        if (this.deleteDatabase(dbh.db_demo)) {
            Log.d("Droped", "deleteDatabase(): database deleted.");
        } else {
            Log.d("Cant Drop", "deleteDatabase(): database NOT deleted.");
        }
    }
}

[/code]

121 Görüntülenme

3 Cevap

Sitedeki sorulara cevap verebilmek için giriş yapın ya da üye olun.

Profile picture for user olgunerkan
olgunerkan
27.07.2014 - 02:53

3 tane text den test bilgileri giriliyor bu test değerlerinini toplamı 1,2,3 şeklinde 1.sutunda yazıyor 2. sutunda iste normalde bu değerlerin çarpımı bölü 3 şeklinde testin ortalaması bulunuyor.Ben bunu çarpmadım 45455 yazan kısma sadece 3.test den gelen değerlerin toplamını yazdırmak istiyorum bunu daha sonra değiştirecem amacım o verileri nasıl toplatacağımı nasıl bir kod kullanmam gerektiğini öğrenmek.

Ahmet Burak Demirkoparan
27.07.2014 - 02:50
bu test verileri databasede saklanıyorsa yukarda query yollayıp array'a yüklediğin yerde toplatıp yükletmen lazım bir arraya.
Profile picture for user olgunerkan
olgunerkan
27.07.2014 - 02:48

45555 yazan kısma test3 den girilen değerlerin toplamını alacağım o değerler tablodann mı toplatık yazdırmam lazım yoksa nasıl?

 

picture-1372-1408467635.jpg
ahmtbrk
27.07.2014 - 02:15

Kodu kim yazmış bilmiyorum ama malesef çorba yapmış.Test3'ten girilen değerler listview'de hangi hücrede gösteriliyor mesela?Sen adapterde default olarak sadece 45555 tarzı bir değer atmışsın oraya onların toplamlarını mı istiyorsun o kısmı tam anlayamadım.

Tıklayınca nameye göre databaseden sildireceğini düşünelim.

return convertView kısmından önce convertView.setOnLongClickListener yazacaksın ve uzun tıklama olduğunda program bu blogun içerisine gelecek.

bu kısımdada nameyi şöyle alıyorsun zaten

String name = arr_name[position];

daha sonra direk bi query atacaksın şu şekilde mesela.

db.delete(DATABASE_TABLE, "name=?",name, null);

bu sorgu ile db den o kaydı isme göre sildirmiş olursun.