- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
这是我的后台任务代码
import android.app.Activity;
import android.content.Context;
import android.database.Cursor;
import android.database.sqlite.SQLiteDatabase;
import android.os.AsyncTask;
import android.widget.ListView;
import android.widget.Toast;
import java.util.List;
public class BackgroundTask extends AsyncTask<String,Product,String> {
Context ctx;
ProductAdapter productAdapter;
Activity activity;
ListView listView;
BackgroundTask(Context ctx) {
this.ctx = ctx;
activity = (Activity) ctx;
}
@Override
protected void onPreExecute() {
super.onPreExecute();
}
@Override
protected String doInBackground(String... params) {
String method = params[0];
DbOperation dbOperation = new DbOperation(ctx);
if (method.equals("add_info")) {
String Vendor = params[1];
String Product = params[2];
String Pprice = params[3];
String Cprice = params[4];
SQLiteDatabase db = dbOperation.getWritableDatabase();
dbOperation.addInformation(db, Vendor, Product, Pprice, Cprice);
return "One Row Inserted...";
} else if (method.equals("get_info")) {
listView = (ListView) activity.findViewById(R.id.display_listview);
SQLiteDatabase db = dbOperation.getReadableDatabase();
Cursor cursor = dbOperation.getInformation(db);
productAdapter = new ProductAdapter(ctx, R.layout.display_product_row);
String vendor, product,pprice, cprice;
while (cursor.moveToNext()) {
vendor = cursor.getString(cursor.getColumnIndex(ProductContract.ProductEntry.VENDOR));
product = cursor.getString(cursor.getColumnIndex(ProductContract.ProductEntry.PRODUCT));
pprice = cursor.getString(cursor.getColumnIndex(ProductContract.ProductEntry.PPRICE));
cprice = cursor.getString(cursor.getColumnIndex(ProductContract.ProductEntry.CPRICE));
Product product1 = new Product(vendor, product, pprice, cprice);
publishProgress(product1);
}
return "get_info";
}
return null;
}
@Override
protected void onProgressUpdate(Product... values) {
productAdapter.add(values[0]);
}
@Override
protected void onPostExecute(String result) {
if (result.equals("get_info")) {
listView.setAdapter(productAdapter);
} else {
Toast.makeText(ctx, result, Toast.LENGTH_LONG).show();
}
}
}
这是我的 DbOperation.java 类
public class DbOperation extends SQLiteOpenHelper{
private static final int DB_VERSION= 1;
private static final String DB_NAME="product_info.db";
private static final String CREATE_QUERY="create table " +ProductContract.ProductEntry.TABLE_NAME+
"("+ ProductContract.ProductEntry.VENDOR+ " text," + ProductContract.ProductEntry.PRODUCT+ " text," +
ProductContract.ProductEntry.PPRICE+ " text," + ProductContract.ProductEntry.CPRICE+ " text);";
DbOperation(Context ctx)
{
super(ctx,DB_NAME,null,DB_VERSION);
Log.d("Database operation","Database created...");
}
@Override
public void onCreate(SQLiteDatabase db) {
db.execSQL(CREATE_QUERY);
Log.d("Database operation", "Table created...");
}
public void addInformation(SQLiteDatabase db,String vendor,String product,String pprice,String cprice)
{
ContentValues contentValues=new ContentValues();
contentValues.put(ProductContract.ProductEntry.VENDOR,vendor);
contentValues.put(ProductContract.ProductEntry.PRODUCT,product);
contentValues.put(ProductContract.ProductEntry.PPRICE,pprice);
contentValues.put(ProductContract.ProductEntry.CPRICE,cprice);
db.insert(ProductContract.ProductEntry.TABLE_NAME, null, contentValues);
Log.d("Database operation", "One Row Inserted...");
}
public Cursor getInformation(SQLiteDatabase db)
{
String[] projections={ProductContract.ProductEntry.VENDOR,ProductContract.ProductEntry.PRODUCT,ProductContract.ProductEntry.PPRICE,ProductContract.ProductEntry.CPRICE};
Cursor cursor=db.query(ProductContract.ProductEntry.TABLE_NAME,projections,
null,null,null,null,null);
return cursor;
}
@Override
public void onUpgrade(SQLiteDatabase db, int i, int i1) {
}
}
这是我的 DisplayProduct.java 类
public class DisplayProduct extends Activity {
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.display_product_layout);
BackgroundTask backgroundTask=new BackgroundTask(this);
backgroundTask.execute("get_info");
}
}
这是我的 ProductAdapter.java 类
public class ProductAdapter extends ArrayAdapter {
List list=new ArrayList();
public ProductAdapter(Context context, int resource) {
super(context, resource);
}
public void add(Product object){
list.add(object);
super.add(object);
}
@Override
public int getCount(){
return list.size();
}
@Override
public Object getItem(int position){
return list.get(position);
}
@Override
public View getView(int position,View convertView,ViewGroup parent){
View row=convertView;
ProductHolder productHolder;
if(row==null)
{
LayoutInflater layoutInflater= (LayoutInflater)this.getContext().getSystemService(Context.LAYOUT_INFLATER_SERVICE);
row=layoutInflater.inflate(R.layout.display_product_row,parent,false);
productHolder=new ProductHolder();
productHolder.tx_vendor=(TextView)row.findViewById(R.id.t_vendor);
productHolder.tx_product=(TextView)row.findViewById(R.id.t_product);
productHolder.tx_pprice=(TextView)row.findViewById(R.id.t_pprice);
productHolder.tx_cprice=(TextView)row.findViewById(R.id.t_cprice);
row.setTag(productHolder);
}
else
{
productHolder=(ProductHolder)row.getTag();
}
Product product=(Product)getItem(position);
productHolder.tx_vendor.setText(product.getVendor().toString());
productHolder.tx_product.setText(product.getProduct().toString());
productHolder.tx_pprice.setText(product.getPprice().toString());
productHolder.tx_cprice.setText(product.getCprice().toString());
return row;
}
static class ProductHolder
{
TextView tx_vendor,tx_product,tx_pprice,tx_cprice;
}
}
最后一个是我的 ProductContract.java 类
public final class ProductContract {
ProductContract(){}
public static abstract class ProductEntry
{
public static final String VENDOR="vendor";
public static final String PRODUCT="product";
public static final String PPRICE="pprice";
public static final String CPRICE="cprice";
public static final String TABLE_NAME ="product_table";
}
}
如何将数据从 listview
传递到 cartlist
?是使用 i.putextra
函数还是其他函数?
最佳答案
使用Intent
通过putExtra()
方法在2个 Activity 之间传递数据,它重载了从原始数据类型到Array
的许多内容
Intent intent = new Intent(CurrentActivity.this, NewActivity.class);
intent.putExtra("Key1", "Hello");
intent.putExtra("Key2", 2016);
startActivity(intent);
在您的NewActivity
中,例如onCreate()
Intent intent = getIntent();
String value1 = intent.getStringExtra("key1");
// zero here is default value that will be returned if no value found to "key2" key
int value2 = intente.getIntExtra("key2", 0);
您还可以将ArrayList
放入 Intent 中,检查documentation了解更多信息。
关于java - 如何通过单击按钮将 ListView 中的数据传递到购物车列表(新 Activity )。我插入 ListView 的数据使用 SQLite,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/34856499/
我们都在流行的网站上看到,购物车图标的右上角有一个小图标!我必须在我的 ASP .NET 网页中使用类似的东西。 如何让这个图标位于购物车图标的右上角.. 购物车的图标是一个普通的 bootstrap
Closed. This question does not meet Stack Overflow guidelines 。它目前不接受答案。 想改善这个问题吗?更新问题,使其成为 Stack Ov
可以使用 REST 架构约束来实现购物车吗? 我想把我的问题集中在 session 状态上。在实现购物车的典型 MVC 应用程序中,很可能 session 对象将在 session 中管理,购物车作为
我的网上商店使用自己的模板,但在我的网站上我使用货币欧元而不是美元。哪里可以编辑啊。 http://i50.tinypic.com/67rvhc.png 最佳答案 进入系统>配置。 然后在“通用”>“
我想在我的门户中使用购物车。我可以获得 jquery 的购物车插件吗? 格纳尼亚尔·祖贝尔 最佳答案 http://simplecartjs.com/不是 JQuery,但如果 PayPal 或 Go
关闭。这个问题需要更多 focused .它目前不接受答案。 想改进这个问题?更新问题,使其仅关注一个问题 editing this post . 4年前关闭。 Improve this questi
我正在尝试将产品添加到我的购物车。 我收到一条错误消息: 警告:为 foreach() 提供的参数无效 它告诉我以下代码出现错误: function isInCart($id) { if (!empt
我目前正在使用 PHP 开发购物车,我正在尝试弄清楚如何使用我编写的代码将商品添加到购物车本身。我的数据库中的项目显示正确,但只有 $item 下的最后一个数组被添加到购物车。以下显示项目。 $res
在我的laravel购物车上,我创建了一个delete函数,使用json或dd函数进行测试时似乎还可以,但是尝试返回路线购物车 View Route [cart] not defined.时,这是一个
就目前情况而言,这个问题不太适合我们的问答形式。我们希望答案得到事实、引用资料或专业知识的支持,但这个问题可能会引发辩论、争论、民意调查或扩展讨论。如果您觉得这个问题可以改进并可能重新开放,visit
将相同的产品添加到购物车时,它正在添加新行,但如果相同的产品 ID 已在购物车中,则需要更新数量。 我需要它与数量更新保持一致。 最佳答案 您需要覆盖 app/code/core/Mage/Sales
你好, 我正在创建一个用于培训目的的 PHP 商店。我希望用户能够查看他最后下的订单 - 但我很难意识到这一点。 我的数据库中有这些表: 客户( child 、姓名、地址...) 产品(pid、pro
我正在考虑建立一个迷你购物网站。不涉及支付方式,只是显示和维护的所选产品的总数。这将由商店中的一个人操作以进行和监控销售。 概念是:产品应该在页面中显示为大图像,通过点击它们我将它们存储在购物车中。然
我有以下产品和购物车表格: //产品表 Products: id | Product_value ----------------------- 1 | Product
我尝试使用 php ang mysql 在 google 中搜索购物车中的代码。当我单击“添加到购物车”按钮时,我的 cart.php 中没有显示任何内容。请帮助我。 这是我的产品.php ">ADD
我正在为摄影业务创建 PHP 购物车。这是我尝试的第一个电子商务网站(新手) 我已成功将产品添加到购物车(存储在 session 中)(产品:打印品、 key 圈、磁铁等) 但是我还需要将 image
变量被添加到从另一个页面传递的 session 数组 此处为详细信息页面 string(4) "3911" [1]=> string(4) "5005" [2]=> NULL [3]=> strin
我的模型中设置了以下核心数据关系。 类别 -> 产品 -> 购物车产品 1)) { // handle error } else if (![cartProducts count]) {
我已经根据示例实现了jQuery的购物卡:http://jsfiddle.net/RR6z5/1/ 但是有一个小错误。当我将一个元素从产品拖到购物卡,然后无拖放,我从购物卡拖到产品时,产品中的原始元素
大家好,就 css 和 javascript 而言,我是个新手。我正在使用的新主题是让我的 paypal minicart 显示在内容下方,因此您不能单击它,也不能从中删除内容,但您可以看到购物车稍微
我是一名优秀的程序员,十分优秀!