GamesClient
을 사용하여 Google Play 게임 서비스의 리더 보드를 사용하려고합니다. 지금은 importbutton
을 클릭하면 GamesClient
이 약간의 점수를 제출하는 데 사용됩니다. 아래에서 볼 수 있듯이 오류가 발생합니다. connect() and wait for onConnectd() to be called.
게임 클라이언트가 연결되지 않습니다. 오류 : "connect()를 호출하고 onConnected()가 호출되기를 기다립니다."
무엇이 잘못 되었나요? 어떤 자습서에서는 PlusClient
이라는 것을 볼 수 있습니다. 나는 그것을 어떤 방식으로 필요로 하는가? 필요한 경우 더 많은 코드를 제공 할 수 있습니다.
이 새로운 Google Play 게임 서비스에 대한 많은 질문이 StackOverflow에 있지만 거기에는 많은 답변이없는 것으로 보입니다. 사람들이 아직도 배우고있는 것처럼 보입니다 - 나와 같이. :)
로그 캣
06-12 00:40:40.173: E/AndroidRuntime(1685): java.lang.IllegalStateException: Not connected. Call connect() and wait for onConnected() to be called.
06-12 00:40:40.173: E/AndroidRuntime(1685): at com.google.android.gms.internal.p.n(Unknown Source)
06-12 00:40:40.173: E/AndroidRuntime(1685): at com.google.android.gms.internal.p.o(Unknown Source)
06-12 00:40:40.173: E/AndroidRuntime(1685): at com.google.android.gms.internal.bj.a(Unknown Source)
06-12 00:40:40.173: E/AndroidRuntime(1685): at com.google.android.gms.games.GamesClient.submitScore(Unknown Source)
06-12 00:40:40.173: E/AndroidRuntime(1685): at matt.lyons.bibletrivia.lite.MainMenu$8.onClick(MainMenu.java:173)
06-12 00:40:40.173: E/AndroidRuntime(1685): at android.view.View.performClick(View.java:4204)
06-12 00:40:40.173: E/AndroidRuntime(1685): at android.view.View$PerformClick.run(View.java:17355)
06-12 00:40:40.173: E/AndroidRuntime(1685): at android.os.Handler.handleCallback(Handler.java:725)
06-12 00:40:40.173: E/AndroidRuntime(1685): at android.os.Handler.dispatchMessage(Handler.java:92)
06-12 00:40:40.173: E/AndroidRuntime(1685): at android.os.Looper.loop(Looper.java:137)
06-12 00:40:40.173: E/AndroidRuntime(1685): at android.app.ActivityThread.main(ActivityThread.java:5041)
06-12 00:40:40.173: E/AndroidRuntime(1685): at java.lang.reflect.Method.invokeNative(Native Method)
06-12 00:40:40.173: E/AndroidRuntime(1685): at java.lang.reflect.Method.invoke(Method.java:511)
06-12 00:40:40.173: E/AndroidRuntime(1685): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:793)
06-12 00:40:40.173: E/AndroidRuntime(1685): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:560)
06-12 00:40:40.173: E/AndroidRuntime(1685): at dalvik.system.NativeStart.main(Native Method)
MainMenu.java
public class MainMenu extends BaseGameActivity {
DatabaseHelper dh;
GamesClient client;
Context c;
@Override
public void onCreate(Bundle savedInstanceState) {
requestWindowFeature(Window.FEATURE_NO_TITLE);
super.onCreate(savedInstanceState);
setContentView(R.layout.mainmenu);
client = getGamesClient();
client.connect();
c = this;
dh = new DatabaseHelper(this);
dh.openDB();
importbutton = (Button)findViewById(R.id.importbutton);
importbutton.setOnClickListener(new OnClickListener() {
public void onClick(View v) {
importScores();
}
});
}
public void importScores() {
final Dialog dialog = new Dialog(c);
dialog.setContentView(R.layout.importlayout);
dialog.setTitle(R.string.importtitle);
TextView question = (TextView)dialog.findViewById(R.id.question);
Button save = (Button)dialog.findViewById(R.id.save);
Button scratch = (Button)dialog.findViewById(R.id.scratch);
question.setText(c.getResources().getString(R.string.importquestion));
save.setText(c.getResources().getString(R.string.savebtn));
scratch.setText(c.getResources().getString(R.string.scratchbtn));
save.setOnClickListener(new OnClickListener() {
public void onClick(View v) {
long highestJC = dh.getHighestJC();
client.submitScore(c.getResources().getString(R.string.leaderboardjc), highestJC);
long highestTenC = dh.getHighestTenC();
client.submitScore(c.getResources().getString(R.string.leaderboardtenc), highestTenC);
long highestExodus = dh.getHighestExodus();
client.submitScore(c.getResources().getString(R.string.leaderboardexodus), highestExodus);
long highestGenesis = dh.getHighestGenesis();
client.submitScore(c.getResources().getString(R.string.leaderboardgenesis), highestGenesis);
long highestHolydays = dh.getHighestHolydays();
client.submitScore(c.getResources().getString(R.string.leaderboardholydays), highestHolydays);
long highestFacts = dh.getHighestFacts();
client.submitScore(c.getResources().getString(R.string.leaderboardfacts), highestFacts);
long highestActs = dh.getHighestActs();
client.submitScore(c.getResources().getString(R.string.leaderboardacts), highestActs);
long highestRandom = dh.getHighestRandom();
client.submitScore(c.getResources().getString(R.string.leaderboardrandom), highestRandom);
long highestAll = dh.getHighestAll();
client.submitScore(c.getResources().getString(R.string.leaderboardallcats), highestAll);
dialog.dismiss();
}
});
scratch.setOnClickListener(new OnClickListener() {
public void onClick(View v) {
dh.deleteAll();
for(int i = 0; i < 15; i++) {
dh.insert(0, 0, "-");
}
dialog.dismiss();
dh.closeDB();
}
});
dialog.show();
}
}