gpt4 book ai didi

java - 将 Spinner 选择保存到 SQLite 数据库中

转载 作者:行者123 更新时间:2023-11-30 08:40:55 25 4
gpt4 key购买 nike

我查看了所有与将微调器保存到数据库相关的问题,但似乎没有任何效果。

我已经开始着手添加 ItemSelectedListener 但它会返回一个错误,

这是我的代码

OnItemSelectedListener 是我为表格的其余部分插入的地方

public class OnClickListenerCreateMenuItem implements View.OnClickListener {
@Override
public void onClick(View view) {


final Context context = view.getContext();
LayoutInflater inflater = (LayoutInflater) context.getSystemService(Context.LAYOUT_INFLATER_SERVICE);
final View formElementsView = inflater.inflate(R.layout.menuitem_input_form, null, false);

final EditText editTextItemName = (EditText) formElementsView.findViewById(R.id.editTextItemName);
final EditText editTextItemDesc = (EditText) formElementsView.findViewById(R.id.editTextItemDesc);
final EditText editTextItemPrice = (EditText) formElementsView.findViewById(R.id.editTextItemPrice);
final EditText editTextItemCost = (EditText) formElementsView.findViewById(R.id.editTextItemCost);
final Spinner itemCategory = (Spinner) formElementsView.findViewById(R.id.spinnerCategory);

itemCategory.setAdapter(
((SettingsMenuItem) context).loadSpinnerData()
);

itemCategory.setOnItemSelectedListener(
((SettingsMenuItem) context).loadSpinnerData()
);


new AlertDialog.Builder(context)
.setView(formElementsView)
.setTitle("Create Item")
.setPositiveButton("Add",
new DialogInterface.OnClickListener() {
public void onClick(DialogInterface dialog, int id) {


String itemName = editTextItemName.getText().toString();
String itemDescription = editTextItemDesc.getText().toString();
String itemPrice = editTextItemPrice.getText().toString();
String itemCost = editTextItemCost.getText().toString();
String valueOfSelectedCat= itemCategory.getSelectedItem().toString();


ObjectMenuItem objectMenuItem = new ObjectMenuItem();
objectMenuItem.name = itemName;
objectMenuItem.description = itemDescription;
objectMenuItem.price = Float.parseFloat(itemPrice);
objectMenuItem.cost = Float.parseFloat(itemCost);
objectMenuItem.cat = valueOfSelectedCat;

boolean createSuccessful = new TableControllerMenuItem(context).create(objectMenuItem);


if(createSuccessful){
Toast.makeText(context, "Item was saved.", Toast.LENGTH_SHORT).show();
}else{
Toast.makeText(context, "Unable to save item.", Toast.LENGTH_SHORT).show();
}
((SettingsMenuItem) context).readRecords();
((SettingsMenuItem) context).countRecords();



dialog.cancel();

}

}).show();




}

我实际的微调器是在这里设置和填充的

public class SettingsMenuItem extends AppCompatActivity {

Spinner spinner;
Context context;
String id;

@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_settings_menu_item);
Toolbar toolbar = (Toolbar) findViewById(R.id.toolbar);
setSupportActionBar(toolbar);

countRecords();
readRecords();

FloatingActionButton fab = (FloatingActionButton) findViewById(R.id.fab);
fab.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View view) {
Snackbar.make(view, "Replace with your own action", Snackbar.LENGTH_LONG)
.setAction("Action", null).show();
}
});

Button buttonCreateLocation = (Button) findViewById(R.id.btnAdd);
buttonCreateLocation.setOnClickListener(new OnClickListenerCreateMenuItem());
}

public void countRecords() {

int recordCount = new TableControllerMenuItem(this).count();
TextView textViewRecordCount = (TextView) findViewById(R.id.textViewRecordCount);
textViewRecordCount.setText(recordCount + " records found.");

}

public void readRecords() {

LinearLayout linearLayoutRecords = (LinearLayout) findViewById(R.id.linearLayoutRecords);
linearLayoutRecords.removeAllViews();

List<ObjectMenuItem> menuitem = new TableControllerMenuItem(this).read();

if (menuitem.size() > 0) {

for (ObjectMenuItem obj : menuitem) {

int id = obj.id;
String menuitemName = obj.name;
String menuitemDescription = obj.description;
Float menuitemPrice = obj.price;
Float menuitemCost = obj.cost;
String itemCategory = obj.cat;

String textViewContents = menuitemName;

TextView textViewMenuItem = new TextView(this);
textViewMenuItem.setPadding(0, 10, 0, 10);
textViewMenuItem.setText(textViewContents);
textViewMenuItem.setTag(Integer.toString(id));
textViewMenuItem.setTextSize(20.0f);

textViewMenuItem.setOnLongClickListener(new OnLongClickListenerMenuItem());


linearLayoutRecords.addView(textViewMenuItem);
}

} else {

TextView locationItem = new TextView(this);
locationItem.setPadding(8, 8, 8, 8);
locationItem.setText("No records yet.");

linearLayoutRecords.addView(locationItem);
}

}

public ArrayAdapter loadSpinnerData() {

Log.d("CON", "setting spinner data");

Spinner s = (Spinner) findViewById(R.id.spinnerCategory);
DatabaseHandler h = new DatabaseHandler(getApplicationContext());

List<String> names = h.getAllNames();

ArrayAdapter<String> dataAdapter = new ArrayAdapter<String>(this, android.R.layout.simple_spinner_item, names);

dataAdapter.setDropDownViewResource(android.R.layout.simple_spinner_dropdown_item);




return dataAdapter;


}





}

这是我的崩溃日志

--------- beginning of crash 02-14 08:29:07.627 14332-14332/com.jenovaprojects.restaurant E/AndroidRuntime: FATAL EXCEPTION: main Process: com.jenovaprojects.restaurant, PID: 14332 java.lang.ClassCastException: android.widget.ArrayAdapter cannot be cast to android.widget.AdapterView$OnItemSelectedListener at com.jenovaprojects.restaurant.OnClickListenerCreate.OnClickListenerCreateMenuItem.onClick(OnClickListenerCreateMenuItem.java:41) at android.view.View.performClick(View.java:5204) at android.view.View$PerformClick.run(View.java:21156) at android.os.Handler.handleCallback(Handler.java:739) at android.os.Handler.dispatchMessage(Handler.java:95) at android.os.Looper.loop(Looper.java:148) at android.app.ActivityThread.main(ActivityThread.java:5466) at java.lang.reflect.Method.invoke(Native Method) at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:726) at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:616)

最佳答案

请放置您的 LogCat 以查看这些错误,如果可能,请显示您的数据库查询和您要插入所选数据的表结构。

简单的过程是将 onItemSelected 的一个监听器放在您的情况下的微调器上

itemCategory.setOnItemSelectedListener(replce your context here);

然后做spinner接口(interface)的必要实现

实现 OnItemSelectedListener

当您从微调器中选择任何项目时,将调用此方法 onItemSelected。它会返回您点击的项目的位置,您可以从中轻松找出点击的项目。

adapter.getItemAtPosition(pos).toString()

通过它您将获得项目的文本。

第二部分 - 将数据插入 sqlite 数据库

创建一个 db 对象并初始化它,然后调用适当的方法来插入您选择的选择数据。

关于java - 将 Spinner 选择保存到 SQLite 数据库中,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/35380478/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com