Страница 7 из 9

Re: Урок 12. Логи и всплывающие сообщения

Добавлено: 19 мар 2014, 10:49
Scvex
Хотя что-то мне подсказывает, что кто-то не понимает что делает.[/quote]

да, с логами еще предстоит разобраться :D

Re: Урок 12. Логи и всплывающие сообщения

Добавлено: 19 мар 2014, 17:27
Санёк
Здравствуйте. У меня есть непонятность по этому уроку.

1)Когда я ввожу "Toast.makeText(this, "ххххххххххххххх", Toast.LENGTH_LONG).show();", то мне слово "makeText" подчёркивается красным.

2)А если я введу "Toast.makeText(MainActivity.this, "ххххххххххххххх", Toast.LENGTH_LONG).show();", то ошибок не будет, но при запуске приложения будет написано "Прилоение хххххххххх остановлено"

Прошу помощи. А с логами ПОКА всё понятно и получается)

Re: Урок 12. Логи и всплывающие сообщения

Добавлено: 19 мар 2014, 20:14
Olelucoye
Санёк писал(а):
Когда я ввожу "Toast.makeText(this, "ххххххххххххххх", Toast.LENGTH_LONG).show();", то мне слово "makeText" подчёркивается красным.
Возможно Вы вызываете сообщение внутри объекта, для которого this ссылается на сам объект а не на Activity. Сделайте вызов Toast во внешней функции.

Re: Урок 12. Логи и всплывающие сообщения

Добавлено: 21 мар 2014, 23:56
Mikhail_dev
Возможно стоит почитать первую заметку в моей подписи и решить для себя, стоит ли изначально изучить Java или всё же не стоит?

Re: Урок 12. Логи и всплывающие сообщения

Добавлено: 22 мар 2014, 21:29
Olelucoye
m090050 писал(а):Возможно стоит почитать первую заметку в моей подписи и решить для себя, стоит ли изначально изучить Java или всё же не стоит?
А мне казалось, что форум служит для того, чтобы помогать новичкам, а не указывать им их место. Вместо того, чтобы тыкать носом начинающих в их некомпетентность и показывать палец Лебедева, может быть правильнее было бы разъяснить суть ошибки и рассказать как правильно её исправить?

Re: Урок 12. Логи и всплывающие сообщения

Добавлено: 22 мар 2014, 23:44
Foenix
Olelucoye писал(а):
m090050 писал(а):Возможно стоит почитать первую заметку в моей подписи и решить для себя, стоит ли изначально изучить Java или всё же не стоит?
А мне казалось, что форум служит для того, чтобы помогать новичкам, а не указывать им их место. Вместо того, чтобы тыкать носом начинающих в их некомпетентность и показывать палец Лебедева, может быть правильнее было бы разъяснить суть ошибки и рассказать как правильно её исправить?
вы сказали, что с логами разобрались, а сами при появлении надписи "приложение остановлено" не знаете что делать. Парадокс.

Re: Урок 12. Логи и всплывающие сообщения

Добавлено: 08 апр 2014, 15:57
javajunior
Спасибо за уроки. Все получилось без заморочек и проволочек. Ура! Я люблю Java! :)

Re: Урок 12. Логи и всплывающие сообщения

Добавлено: 11 апр 2014, 15:35
saint7931
При запуске программы эмулятор выдает ошибку "Unfortunately, имя проекта has stopped".
Вот что прописано в Main Activity.java
До присвоения обработчика кнопкам все работало нормально.
В чем может быть проблема?


Код: Выделить всё

package com.example.logandmess;

import android.os.Bundle;
import android.support.v4.app.Fragment;
import android.support.v7.app.ActionBarActivity;
import android.view.LayoutInflater;
import android.view.Menu;
import android.view.MenuItem;
import android.view.View;
import android.view.View.OnClickListener;
import android.view.ViewGroup;
import android.widget.Button;
import android.widget.TextView;


public class MainActivity extends ActionBarActivity implements OnClickListener {

	TextView tvOut;
	  Button btnOk;
	  Button btnCancel;
	  
	  
	@Override
	protected void onCreate(Bundle savedInstanceState) {
		super.onCreate(savedInstanceState);
		setContentView(R.layout.main);
		
		tvOut = (TextView) findViewById(R.id.tvOut);
	    btnOk = (Button) findViewById(R.id.btnOk);
	    btnCancel = (Button) findViewById(R.id.btnCancel);

	    btnOk.setOnClickListener(this);
	    btnCancel.setOnClickListener(this);

		if (savedInstanceState == null) {
			getSupportFragmentManager().beginTransaction()
					.add(R.id.container, new PlaceholderFragment()).commit();
			
		}
	}

	@Override
	public boolean onCreateOptionsMenu(Menu menu) {

		// Inflate the menu; this adds items to the action bar if it is present.
		getMenuInflater().inflate(R.menu.main, menu);
		return true;
	}

	@Override
	public boolean onOptionsItemSelected(MenuItem item) {
		// Handle action bar item clicks here. The action bar will
		// automatically handle clicks on the Home/Up button, so long
		// as you specify a parent activity in AndroidManifest.xml.
		int id = item.getItemId();
		if (id == R.id.action_settings) {
			return true;
		}
		return super.onOptionsItemSelected(item);
	}

	/**
	 * A placeholder fragment containing a simple view.
	 */
	public static class PlaceholderFragment extends Fragment {

		public PlaceholderFragment() {
		}

		@Override
		public View onCreateView(LayoutInflater inflater, ViewGroup container,
				Bundle savedInstanceState) {
			View rootView = inflater.inflate(R.layout.fragment_main, container,
					false);
			return rootView;
			
		}
	}

	@Override
	  public void onClick(View v) {
	    // по id определяем кнопку, вызвавшую этот обработчик
	    switch (v.getId()) {
	    case R.id.btnOk:
	      // кнопка ОК
	      tvOut.setText("Нажата кнопка ОК");
	      break;
	    case R.id.btnCancel:
	      // кнопка Cancel
	      tvOut.setText("Нажата кнопка Cancel");
	      break;
	      
	    }
	  }

		
	}

Re: Урок 12. Логи и всплывающие сообщения

Добавлено: 11 апр 2014, 16:01
Mikhail_dev
Посмотрите этот вебинар viewtopic.php?f=60&t=3198 , чтобы понимать как искать ошибку. Там про logcat рассказывается. Также вкладывайте код в теги. Такой код нечитабелен без текста.

Re: Урок 12. Логи и всплывающие сообщения

Добавлено: 11 апр 2014, 16:13
saint7931
m090050 писал(а):Посмотрите этот вебинар viewtopic.php?f=60&t=3198 , чтобы понимать как искать ошибку. Там про logcat рассказывается. Также вкладывайте код в теги. Такой код нечитабелен без текста.
Обязательно посмотрю, но попозже. Просто интернет у меня сейчас всего 3Г с лимитом в 1 гиг/мес. А уроки читаю в оффлайн режиме. Поэтому прошу помочь сейчас.

Re: Урок 12. Логи и всплывающие сообщения

Добавлено: 11 апр 2014, 16:36
Mikhail_dev
Так тут нет телепатов. "Unfortunately, имя проекта has stopped". - это в переводе говорит о том, что программа к сожалению остановилась. Таковое бывает из-за ошибки. А вот какая ошибка - мы ведь не в курсе. Как её отыскать, я написал.

Re: Урок 12. Логи и всплывающие сообщения

Добавлено: 11 апр 2014, 17:04
saint7931
m090050 писал(а):Так тут нет телепатов. "Unfortunately, имя проекта has stopped". - это в переводе говорит о том, что программа к сожалению остановилась. Таковое бывает из-за ошибки. А вот какая ошибка - мы ведь не в курсе. Как её отыскать, я написал.
Вроде как смог посмотреть этот вебинар. Вот выкладываю лог и сам код.

Код: Выделить всё

package com.example.p0121_logandmess;

import android.app.Activity;
import android.app.Fragment;
import android.os.Bundle;
import android.view.LayoutInflater;
import android.view.Menu;
import android.view.MenuItem;
import android.view.View;
import android.view.View.OnClickListener;
import android.view.ViewGroup;
import android.widget.Button;
import android.widget.TextView;

public class MainActivity extends Activity implements OnClickListener {
	
	TextView tvOut;
	  Button btnOk;
	  Button btnCancel;
	  
	@Override
	protected void onCreate(Bundle savedInstanceState) {
		super.onCreate(savedInstanceState);
		setContentView(R.layout.activity_main);

		// найдем View-элементы
	    tvOut = (TextView) findViewById(R.id.tvOut);
	    btnOk = (Button) findViewById(R.id.btnOk);
	    btnCancel = (Button) findViewById(R.id.btnCancel);

	    // присваиваем обработчик кнопкам
	    btnOk.setOnClickListener(this);
	    btnCancel.setOnClickListener(this);
		
		if (savedInstanceState == null) {
			getFragmentManager().beginTransaction()
					.add(R.id.container, new PlaceholderFragment()).commit();
		}
	}

	@Override
	public boolean onCreateOptionsMenu(Menu menu) {

		// Inflate the menu; this adds items to the action bar if it is present.
		getMenuInflater().inflate(R.menu.main, menu);
		return true;
	}

	@Override
	public boolean onOptionsItemSelected(MenuItem item) {
		// Handle action bar item clicks here. The action bar will
		// automatically handle clicks on the Home/Up button, so long
		// as you specify a parent activity in AndroidManifest.xml.
		int id = item.getItemId();
		if (id == R.id.action_settings) {
			return true;
		}
		return super.onOptionsItemSelected(item);
	}

	/**
	 * A placeholder fragment containing a simple view.
	 */
	public static class PlaceholderFragment extends Fragment {

		public PlaceholderFragment() {
		}

		@Override
		public View onCreateView(LayoutInflater inflater, ViewGroup container,
				Bundle savedInstanceState) {
			View rootView = inflater.inflate(R.layout.fragment_main, container,
					false);
			return rootView;
		}
	}

	@Override
	  public void onClick(View v) {
	    // по id определяем кнопку, вызвавшую этот обработчик
	    switch (v.getId()) {
	    case R.id.btnOk:
	      // кнопка ОК
	      tvOut.setText("Нажата кнопка ОК");
	      break;
	    case R.id.btnCancel:
	      // кнопка Cancel
	      tvOut.setText("Нажата кнопка Cancel");
	      break;
	    }
	  }

}

ЛОГ

04-11 13:56:48.843: E/AndroidRuntime(536): FATAL EXCEPTION: main
04-11 13:56:48.843: E/AndroidRuntime(536): java.lang.RuntimeException: Unable to start activity ComponentInfo{com.example.p0121_logandmess/com.example.p0121_logandmess.MainActivity}: java.lang.NullPointerException
04-11 13:56:48.843: E/AndroidRuntime(536): at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:1955)
04-11 13:56:48.843: E/AndroidRuntime(536): at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:1980)
04-11 13:56:48.843: E/AndroidRuntime(536): at android.app.ActivityThread.access$600(ActivityThread.java:122)
04-11 13:56:48.843: E/AndroidRuntime(536): at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1146)
04-11 13:56:48.843: E/AndroidRuntime(536): at android.os.Handler.dispatchMessage(Handler.java:99)
04-11 13:56:48.843: E/AndroidRuntime(536): at android.os.Looper.loop(Looper.java:137)
04-11 13:56:48.843: E/AndroidRuntime(536): at android.app.ActivityThread.main(ActivityThread.java:4340)
04-11 13:56:48.843: E/AndroidRuntime(536): at java.lang.reflect.Method.invokeNative(Native Method)
04-11 13:56:48.843: E/AndroidRuntime(536): at java.lang.reflect.Method.invoke(Method.java:511)
04-11 13:56:48.843: E/AndroidRuntime(536): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:784)
04-11 13:56:48.843: E/AndroidRuntime(536): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:551)
04-11 13:56:48.843: E/AndroidRuntime(536): at dalvik.system.NativeStart.main(Native Method)
04-11 13:56:48.843: E/AndroidRuntime(536): Caused by: java.lang.NullPointerException
04-11 13:56:48.843: E/AndroidRuntime(536): at com.example.p0121_logandmess.MainActivity.onCreate(MainActivity.java:32)
04-11 13:56:48.843: E/AndroidRuntime(536): at android.app.Activity.performCreate(Activity.java:4465)
04-11 13:56:48.843: E/AndroidRuntime(536): at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1049)
04-11 13:56:48.843: E/AndroidRuntime(536): at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:1919)
04-11 13:56:48.843: E/AndroidRuntime(536): ... 11 more

Re: Урок 12. Логи и всплывающие сообщения

Добавлено: 11 апр 2014, 17:21
saint7931
Вроде понял как сделать чтобы приложение заработало. Но причину понять не смог. Я писал в fragment_main.xml код для кнопок. А когда переписал тот же код в activity_main.xml приложение заработало.

Re: Урок 12. Логи и всплывающие сообщения

Добавлено: 11 апр 2014, 18:02
Mikhail_dev
at com.example.p0121_logandmess.MainActivity.onCreate(MainActivity.java:32)
Ошибка в 32 строке.
Вроде понял как сделать чтобы приложение заработало. Но причину понять не смог. Я писал в fragment_main.xml код для кнопок. А когда переписал тот же код в activity_main.xml приложение заработало.
Может просто кнопки ищете во фрагменте, а они на самом деле не в самом фрагменте?

Re: Урок 12. Логи и всплывающие сообщения

Добавлено: 08 июл 2014, 01:00
betirsolt
У меня не работает фильтр в LogCat, в DDMS тоже пусто, виртуальный девайс у меня только один, без фильтра все показывает а в фильтре пусто, перезапускал среду, тоже не помогло, в чем может быть проблема?

Re: Урок 12. Логи и всплывающие сообщения

Добавлено: 25 июл 2014, 14:38
Rodina77
Всем привет!
Вот такой MainActivity.

package rus.example.p0121_logandmess;

import android.os.Bundle;
import android.support.v4.app.Fragment;
import android.support.v7.app.ActionBarActivity;
import android.util.Log;
import android.view.LayoutInflater;
import android.view.Menu;
import android.view.MenuItem;
import android.view.View;
import android.view.View.OnClickListener;
import android.view.ViewGroup;
import android.widget.Button;
import android.widget.TextView;
import android.widget.Toast;

public class MainActivity extends ActionBarActivity {

@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);

if (savedInstanceState == null) {
getSupportFragmentManager().beginTransaction()
.add(R.id.container, new PlaceholderFragment())
.commit();
}
}


@Override
public boolean onCreateOptionsMenu(Menu menu) {

// Inflate the menu; this adds items to the action bar if it is present.
getMenuInflater().inflate(R.menu.main, menu);
return true;
}

@Override
public boolean onOptionsItemSelected(MenuItem item) {
// Handle action bar item clicks here. The action bar will
// automatically handle clicks on the Home/Up button, so long
// as you specify a parent activity in AndroidManifest.xml.
int id = item.getItemId();
if (id == R.id.action_settings) {
return true;
}
return super.onOptionsItemSelected(item);
}

/**
* A placeholder fragment containing a simple view.
*/
public static class PlaceholderFragment extends Fragment implements OnClickListener{

TextView tvOut;
Button btnOk;
Button btnCancel;

private static final String TAG = "myLogs";

public PlaceholderFragment() {
}


@Override
public View onCreateView(LayoutInflater inflater, ViewGroup container,
Bundle savedInstanceState) {
View rootView = inflater.inflate(R.layout.fragment_main, container, false);

// найдем View-элементы
Log.d(TAG, "найдем View-элементы");
tvOut = (TextView) rootView.findViewById(R.id.tvOut);
btnOk = (Button) rootView.findViewById(R.id.btnOk);
btnCancel = (Button) rootView.findViewById(R.id.btnCancel);

// присваиваем обработчик кнопкам
Log.d(TAG, "присваиваем обработчик кнопкам");
btnOk.setOnClickListener(this);
btnCancel.setOnClickListener(this);

return rootView;
}

@Override
public void onClick(View v) {
// по id определеяем кнопку, вызвавшую этот обработчик
Log.d(TAG, "по id определяем кнопку, вызвавшую этот обработчик");
switch (v.getId()) {
case R.id.btnOk:
// кнопка ОК
Log.d(TAG, "кнопка ОК");
tvOut.setText("Нажата кнопка ОК");
Toast.makeText(this, "Нажата кнопка ОК", Toast.LENGTH_LONG).show();
break;
case R.id.btnCancel:
// кнопка Cancel
Log.d(TAG, "кнопка Cancel");
tvOut.setText("Нажата кнопка Cancel");
Toast.package rus.example.p0121_logandmess;

import android.os.Bundle;
import android.support.v4.app.Fragment;
import android.support.v7.app.ActionBarActivity;
import android.util.Log;
import android.view.LayoutInflater;
import android.view.Menu;
import android.view.MenuItem;
import android.view.View;
import android.view.View.OnClickListener;
import android.view.ViewGroup;
import android.widget.Button;
import android.widget.TextView;
import android.widget.Toast;

public class MainActivity extends ActionBarActivity {

@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);

if (savedInstanceState == null) {
getSupportFragmentManager().beginTransaction()
.add(R.id.container, new PlaceholderFragment())
.commit();
}
}


@Override
public boolean onCreateOptionsMenu(Menu menu) {

// Inflate the menu; this adds items to the action bar if it is present.
getMenuInflater().inflate(R.menu.main, menu);
return true;
}

@Override
public boolean onOptionsItemSelected(MenuItem item) {
// Handle action bar item clicks here. The action bar will
// automatically handle clicks on the Home/Up button, so long
// as you specify a parent activity in AndroidManifest.xml.
int id = item.getItemId();
if (id == R.id.action_settings) {
return true;
}
return super.onOptionsItemSelected(item);
}

/**
* A placeholder fragment containing a simple view.
*/
public static class PlaceholderFragment extends Fragment implements OnClickListener{

TextView tvOut;
Button btnOk;
Button btnCancel;

private static final String TAG = "myLogs";

public PlaceholderFragment() {
}


@Override
public View onCreateView(LayoutInflater inflater, ViewGroup container,
Bundle savedInstanceState) {
View rootView = inflater.inflate(R.layout.fragment_main, container, false);

// найдем View-элементы
Log.d(TAG, "найдем View-элементы");
tvOut = (TextView) rootView.findViewById(R.id.tvOut);
btnOk = (Button) rootView.findViewById(R.id.btnOk);
btnCancel = (Button) rootView.findViewById(R.id.btnCancel);

// присваиваем обработчик кнопкам
Log.d(TAG, "присваиваем обработчик кнопкам");
btnOk.setOnClickListener(this);
btnCancel.setOnClickListener(this);

return rootView;
}

@Override
public void onClick(View v) {
// по id определеяем кнопку, вызвавшую этот обработчик
Log.d(TAG, "по id определяем кнопку, вызвавшую этот обработчик");
switch (v.getId()) {
case R.id.btnOk:
// кнопка ОК
Log.d(TAG, "кнопка ОК");
tvOut.setText("Нажата кнопка ОК");
Toast.makeText(this, "Нажата кнопка ОК", Toast.LENGTH_LONG).show();
break;
case R.id.btnCancel:
// кнопка Cancel
Log.d(TAG, "кнопка Cancel");
tvOut.setText("Нажата кнопка Cancel");
Toast.makeText(this, "Нажата кнопка ОК", Toast.LENGTH_LONG).show();
break;
}

}

}

}

В обоих случаях "makeText" подчеркнуто красным и при наведении написано:"The method makeText(Context, CharSequence, int) in the type Toast is not applicable for the arguments (MainActivity.PlaceholderFragment, String, int)"

Может кто подскажет как с этим бороться? :roll:

Re: Урок 12. Логи и всплывающие сообщения

Добавлено: 25 июл 2014, 15:42
Viewer
В обоих случаях "makeText" подчеркнуто красным и при наведении написано:"The method makeText(Context, CharSequence, int) in the type Toast is not applicable for the arguments (MainActivity.PlaceholderFragment, String, int)"

Может кто подскажет как с этим бороться?
Он в качестве первого аргумента требуется Context, а вы ему даете MainActivity.PlaceholderFragment
во фрагментах контекст нужно получать из Activity в которой он создается.
Вместо this используйте getActivity()

Re: Урок 12. Логи и всплывающие сообщения

Добавлено: 25 июл 2014, 17:59
Rodina77
Спасибо. Приду с работы, попробую.

Re: Урок 12. Логи и всплывающие сообщения

Добавлено: 20 авг 2014, 10:25
Dreamer
В моей версии Eclipse "фокус" с фильтрами получился, когда выбрала не LogСat, а LogСat (deprecated).
Может, кому-то это поможет.
Если выбирать LogCat, логи пустые даже при выборе виртуального устройства в DDMS.

Eclipse v4.2.2.x, ADT 23.0.2.x

Re: Урок 12. Логи и всплывающие сообщения

Добавлено: 10 сен 2014, 20:21
duddeniska
Всем привет ! Проблема с всплывающими сообщения. Если реализовывать через отдельный итерфейс вот так.

Код: Выделить всё

		OnClickListener oCickBtnOk = new OnClickListener() {
			@Override
			public void onClick(View v) {
				getId = v.getId();
				if (getId==R.id.btnPlus) {
					tvOut.setText(""+ ++count);	
					Toast.makeText(this, "Нажата кнопка ОК", Toast.LENGTH_LONG).show();
				}
				if (getId==R.id.btnMinus) {
					tvOut.setText(""+ --count);
				}
			}
		};
То подчеркивается строка makeText с ошибкой "The method makeText(Context, CharSequence, int) in the type Toast is not applicable for the arguments (new View.OnClickListener(){}, String, int)"

Если реализовывть клик через активити вот так:

Код: Выделить всё

public class MainActivity extends ActionBarActivity implements OnClickListener {
	 TextView tvOut;
	  Button btnOk;
	  Button btnCancel;
	  int test;
	  private static final String TAG = "myLogs";

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

	    // найдем View-элементы
	    Log.d(TAG, "найдем View-элементы");
	    tvOut = (TextView) findViewById(R.id.tvOut);
	    btnOk = (Button) findViewById(R.id.btnOk);
	    btnCancel = (Button) findViewById(R.id.btnCancel);

	    // присваиваем обработчик кнопкам
	    Log.d(TAG, "присваиваем обработчик кнопкам");
	    btnOk.setOnClickListener(this);
	    btnCancel.setOnClickListener(this);
	  }

	  @Override
	  public void onClick(View v) {
	    // по id определяем кнопку, вызвавшую этот обработчик
	    Log.d(TAG, "по id определяем кнопку, вызвавшую этот обработчик");
	    test = v.getId();
	    if (test==R.id.btnOk) {
	    	tvOut.setText("Нажата кнопка ОК");
		      Toast.makeText(this, "Нажата кнопка ОК", Toast.LENGTH_LONG).show();
	    }
	    if (test==R.id.btnCancel) {
	    	tvOut.setText("Нажата кнопка Cancel");
		    Toast.makeText(this, "Нажата кнопка Cancel", Toast.LENGTH_LONG).show();
	    }

	  }
То вспылвающие сообщения работают нормально. В чем может быть причина?