按照StopWatch GDK示例中的指南和约定,我无法打开MenuOption。
我的应用程序编译并能够输出“@@@@ TEST”的嵌入式日志语句,但不会出现OptionsMenu。
https://developers.google.com/glass/develop/gdk/ui/immersion-menus
这是Android API中用于菜单的方法。
openOptionsMenu();
我的代码基于秒表的惯例:
/*
*
* Menu Code
*/
protected void onCreate(Bundle savedInstanceState){
super.onCreate(savedInstanceState);
}
@Override
public boolean onKeyDown(int keycode, KeyEvent event) {
if (keycode == KeyEvent.KEYCODE_DPAD_CENTER) {
openOptionsMenu();
Log.v("@@@@","TEST");
return true;
}
return false;
}
@Override
public boolean onCreateOptionsMenu(Menu menu) {
MenuInflater inflater = getMenuInflater();
inflater.inflate(R.menu.menu, menu);
return true;
}
@Override
public boolean onPrepareOptionsMenu(Menu menu) {
// Implement if needed
return false;
}
@Override
public boolean onOptionsItemSelected(MenuItem item) {
// Handle item selection. Menu items typically start another
// activity, start a service, or broadcast another intent.
switch (item.getItemId()) {
case R.id.stop:
//startActivity(new Intent(this, StopStopWatchActivity.class));
Log.v("@@@@","HI");
return true;
case R.id.read_aloud:
Log.v("@@@@","READ_ALOUD");
return true;
default:
return super.onOptionsItemSelected(item);
}
}
//open the optionsMenu to make sure
@Override
public void openOptionsMenu() {
super.openOptionsMenu();
}
菜单的XML
<?xml version="1.0" encoding="utf-8"?>
<menu xmlns:android="http://schemas.android.com/apk/res/android">
<item
android:id="@+id/read_aloud"
android:title="@string/read_aloud"
android:icon="@drawable/ic_launcher"/>
<item
android:id="@+id/stop"
android:title="@string/stop"
android:icon="@drawable/ic_launcher"/>
</menu>
答案 0 :(得分:3)
编辑:我发现了我的问题。我注释掉了准备好的选项,该选项返回false,这导致我的选择没有参与。
这里参考是一个很好的例子来正确地做到这一点。
感谢@ w9jds的帮助。
我无法在我的代码中找到问题,但这里有一个工作示例解决方案,正确的菜单创建和一个点击。
https://github.com/w9jds/GlassMenuExample
该程序的功能是显示一个呈现hello世界卡的玻璃应用程序。点按该卡片会创建一个具有“共享”选项的选项菜单。
此功能与卡片在时间轴上的工作方式非常相似。
菜单 - Main.Xml
<menu xmlns:android="http://schemas.android.com/apk/res/android" >
<item
android:id="@+id/share_menu_item"
android:title="@string/share_label"
android:icon="@drawable/ic_share_50"/>
</menu>
主要活动
package com.example.glassmenuexample;
import com.google.android.glass.app.Card;
import com.google.android.glass.media.Sounds;
import com.google.android.glass.touchpad.Gesture;
import com.google.android.glass.touchpad.GestureDetector;
import android.media.AudioManager;
import android.os.Bundle;
import android.app.Activity;
import android.content.Context;
import android.view.KeyEvent;
import android.view.Menu;
import android.view.MenuItem;
import android.view.MotionEvent;
public class MainActivity extends Activity
{
private GestureDetector mGestureDetector;
private AudioManager maManager;
@Override
protected void onCreate(Bundle savedInstanceState)
{
super.onCreate(savedInstanceState);
//initialize the audio manager
maManager = (AudioManager) getSystemService(this.AUDIO_SERVICE);
//create gesture listener
mGestureDetector = createGestureDetector(this);
//create a new card for the view
Card cView = new Card(this);
//set the text of the card to the hello world string
cView.setText(R.string.hello_world);
//set the card as the content view
setContentView(cView.toView());
}
@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;
}
private GestureDetector createGestureDetector(Context context)
{
GestureDetector gdDetector = new GestureDetector(context);
//Create a base listener for generic gestures
gdDetector.setBaseListener( new GestureDetector.BaseListener()
{
@Override
public boolean onGesture(Gesture gesture)
{
if (gesture == Gesture.TAP)
{
//play the tap sound
maManager.playSoundEffect(Sounds.TAP);
//open the menu
openOptionsMenu();
return true;
}
return false;
}
});
return gdDetector;
}
@Override
public boolean onGenericMotionEvent(MotionEvent event)
{
if (mGestureDetector != null)
return mGestureDetector.onMotionEvent(event);
return false;
}
@Override
public boolean onOptionsItemSelected(MenuItem item)
{
// Handle item selection. Menu items typically start another
// activity, start a service, or broadcast another intent.
switch (item.getItemId())
{
case R.id.share_menu_item:
//do something on menu item click
return true;
default:
return super.onOptionsItemSelected(item);
}
}
}