Java 对话框警报编辑文本为空,需要填充

Java 对话框警报编辑文本为空,需要填充,java,android,xml,Java,Android,Xml,我正在试着把所有警报框放在我的代码中。。但还是跑不动。。。当编辑文本为空或空时。它将显示一个需要用户填写的对话框。我已经尝试了所有步骤和所有对话框警报。但它仍然可以正常工作。但就我而言。。。这是超过3个编辑文本涉及。只是需要一个意见,我应该把错误的代码空编辑文本,需要用户填写之前,他们按下按钮 JSONParser jsonParser = new JSONParser(); EditText inputName; EditText inputPrice; EditText inputDesc;

我正在试着把所有警报框放在我的代码中。。但还是跑不动。。。当
编辑文本
为空或空时。它将显示一个需要用户填写的对话框。我已经尝试了所有步骤和所有对话框警报。但它仍然可以正常工作。但就我而言。。。这是超过3个编辑文本涉及。只是需要一个意见,我应该把错误的代码空编辑文本,需要用户填写之前,他们按下按钮

JSONParser jsonParser = new JSONParser();
EditText inputName;
EditText inputPrice;
EditText inputDesc;

// url to create new product
private static String url_create_product = "http://192.168.0.102/android_connect/create_product.php";

// JSON Node names
private static final String TAG_SUCCESS = "success";

//private static final CharSequence TITLE_DIALOG = null;

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

    // Edit Text
    inputName = (EditText) findViewById(R.id.inputName);
    inputPrice = (EditText) findViewById(R.id.inputPrice);
    inputDesc = (EditText) findViewById(R.id.inputDesc);



    // Create button
    Button btnCreateProduct = (Button) findViewById(R.id.btnCreateProduct);

    // button click event
    btnCreateProduct.setOnClickListener(new View.OnClickListener() {

        public void onClick(View view) {


            // creating new product in background thread
            new CreateNewProduct().execute();
        }
    });
}

/**
 * Background Async Task to Create new product
 * */
class CreateNewProduct extends AsyncTask<String, String, String> {

    /**
     * Before starting background thread Show Progress Dialog
     * */
    @Override
    protected void onPreExecute() {
        super.onPreExecute();
        ProgressDialog pDialog = new ProgressDialog(NewProductActivity.this);
        pDialog.setMessage("Creating Product..");
        pDialog.setIndeterminate(false);
        pDialog.setCancelable(true);
        pDialog.show();
    }
     /**
     * Creating product
     * */
    protected String doInBackground(String... args) {
        List<EditText> editTextList = new ArrayList<EditText>();
        //editTextList.add(myEditText);
        String name = inputName.getText().toString();
        String price = inputPrice.getText().toString();
        String description = inputDesc.getText().toString();
        for(EditText inputName : editTextList)
        {

        if (name == null || inputName.getText().toString().length() == 0)
        {   

            Context context = getApplicationContext();
            CharSequence error = "Please enter a track name" + name;
            int duration = Toast.LENGTH_LONG;

            Toast toast = Toast.makeText(context, error, duration);
            toast.show();


        }
        else {
        // Building Parameters
        List<NameValuePair> params = new ArrayList<NameValuePair>();
        params.add(new BasicNameValuePair("name", name));
        params.add(new BasicNameValuePair("price", price));
        params.add(new BasicNameValuePair("description", description));

        // getting JSON Object
        // Note that create product url accepts POST method
        JSONObject json = jsonParser.makeHttpRequest(url_create_product,
                "POST", params);

        // check log cat fro response
        Log.d("Create Response", json.toString());

        // check for success tag
        try {
            int success = json.getInt(TAG_SUCCESS);

            if (success == 1) {
                // successfully created product
                Intent i = new Intent(getApplicationContext(), AllProductsActivity.class);
                startActivity(i);

                // closing this screen
                finish();
            } else {
                // failed to create product
            }
        } catch (JSONException e) {
            e.printStackTrace();
        }
        }
        }
        return null;

    }
    /**
     * After completing background task Dismiss the progress dialog
     * **/
    protected void onPostExecute(String file_url) {
        // dismiss the dialog once done
        pDialog.dismiss();
    }

}
JSONParser-JSONParser=new-JSONParser();
编辑文本输入名;
编辑文本输入价格;
编辑文本输入描述;
//创建新产品的url
私有静态字符串url\u创建\u产品=”http://192.168.0.102/android_connect/create_product.php";
//JSON节点名称
私有静态最终字符串标记_SUCCESS=“SUCCESS”;
//私有静态final CharSequence TITLE_DIALOG=null;
@凌驾
创建时的公共void(Bundle savedInstanceState){
super.onCreate(savedInstanceState);
setContentView(R.layout.add_产品);
//编辑文本
inputName=(EditText)findViewById(R.id.inputName);
inputPrice=(EditText)findViewById(R.id.inputPrice);
inputDesc=(EditText)findViewById(R.id.inputDesc);
//创建按钮
按钮btnCreateProduct=(按钮)findViewById(R.id.btnCreateProduct);
//按钮点击事件
btnCreateProduct.setOnClickListener(新视图.OnClickListener(){
公共void onClick(视图){
//在后台线程中创建新产品
新建CreateNewProduct().execute();
}
});
}
/**
*创建新产品的后台异步任务
* */
类CreateNewProduct扩展了AsyncTask{
/**
*在启动后台线程显示进度对话框之前
* */
@凌驾
受保护的void onPreExecute(){
super.onPreExecute();
ProgressDialog pDialog=新建ProgressDialog(NewProductActivity.this);
pDialog.setMessage(“创建产品…”);
pDialog.setUndeterminate(假);
pDialog.setCancelable(真);
pDialog.show();
}
/**
*创造产品
* */
受保护的字符串doInBackground(字符串…args){
List editTextList=新建ArrayList();
//editTextList.add(myEditText);
字符串名称=inputName.getText().toString();
字符串价格=inputPrice.getText().toString();
字符串描述=inputDesc.getText().toString();
用于(EditText输入名称:editTextList)
{
if(name==null | | inputName.getText().toString().length()==0)
{   
Context=getApplicationContext();
CharSequence error=“请输入曲目名称”+名称;
int duration=Toast.LENGTH\u LONG;
Toast Toast=Toast.makeText(上下文、错误、持续时间);
toast.show();
}
否则{
//建筑参数
List params=new ArrayList();
参数添加(新的BasicNameValuePair(“名称”),名称);
参数添加(新的BasicNameValuePair(“价格”,价格));
参数添加(新的BasicNameValuePair(“说明”,说明));
//获取JSON对象
//请注意,创建产品url接受POST方法
JSONObject json=jsonParser.makeHttpRequest(url\u create\u product,
“POST”,params);
//检查cat fro响应日志
d(“创建响应”,json.toString());
//检查成功标签
试一试{
int success=json.getInt(TAG_success);
如果(成功==1){
//已成功创建产品
Intent i=新Intent(getApplicationContext(),AllProductsActivity.class);
星触觉(i);
//关闭此屏幕
完成();
}否则{
//未能创建产品
}
}捕获(JSONException e){
e、 printStackTrace();
}
}
}
返回null;
}
/**
*完成后台任务后,关闭“进度”对话框
* **/
受保护的void onPostExecute(字符串文件\u url){
//完成后关闭对话框
pDialog.disclose();
}
}

}

事实上,我会做得有点不同。。。错误检查代码应该是对话框onClick按钮的一部分。检查是否输入了所有值,如果未输入,则在对话框中输入一个用户需要填写的指示符,同时不结束对话框。下面是我的一个程序中的一个例子,在本例中,为高分例程添加一个名称

EditText input;
input=new EditText(this.getApplicationContext());
final int index=i;
new AlertDialog.Builder(this)
     .setTitle("Update Status")
     .setMessage(R.string.getName)
     .setView(input)
     .setPositiveButton(sayings_array[rnum], new DialogInterface.OnClickListener() {
         public void onClick(DialogInterface dialog, int whichButton) {
             Editable value = input.getText();
             String name=value.toString();
             if (name!=null)
             {
                 addToHighScore(name,level,score,index);
                 dialog.dismiss();
             }
        }
 }).show();

在开始执行
AsyncTask
之前,检查Edittext是否为null。只需首先在按钮上检查EditText是否为空,然后单击开始
CreateNewProduct
AsyncTask
。将代码更改为:

 // button click event
    btnCreateProduct.setOnClickListener(new View.OnClickListener() {

        public void onClick(View view) {

       String name = inputName.getText().toString();
        String price = inputPrice.getText().toString();
        String description = inputDesc.getText().toString();

        if (name != null || inputName.getText().toString().length() != 0)
        {   

           if (price != null || price.getText().toString().length() != 0)
            {  
              if (description != null || description.getText().toString().length() != 0)
                { 
                  // creating new product in background thread
                  new CreateNewProduct().execute();
                }
               else{
                      //show alert here
                }

           }else{
         //show alert here
           }


        }else{
         //show alert here
        }

        }
    });

实际上我需要把它放在哪里??在onclickListener或else中,请注意,我在
onClick
例程中获取了值,验证它们是否正确,然后将它们传递给另一个用于处理对话框输出的函数,然后再将其取消。关键是最里面的
if
语句。对于警报,请创建一个公共方法,并在整个类中要显示警报的每个位置调用它。我已经使用了您的代码,但在运行时仍会显示我的对话框。。。你能给我一个链接或其他代码来显示对话框提示吗。。我的代码不能使用它。@user1906140:你能把你最新的有问题的代码贴到我的邮箱吗suggestion@user1906140:查看我的答案为什么要使用if(name==null)use name=无效的