2012-12-15 4 views
-1

에뮬레이터에서 응용 프로그램을 실행할 때 제대로 작동하지만 장치에서 충돌이 발생합니다. 내 안드로이드 응용 프로그램이 내 에뮬레이터에서 제대로 작동하지만 장치가 손상되었습니다

내 활동을 열고 나는 Invalidate(); 문제라고 생각 ondraw 메소드를 호출

:

protected void onDraw(Canvas canvas) { 
    // TODO Auto-generated method stub 

    getinfoGFX.open(); 

    String d = ""; 
    semesterNo = getinfoGFX.getDataSemestersNo(s); 
    semestrYear = getinfoGFX.getDataSemestersYear(s); 
    semestrId = getinfoGFX.getDataSemestersID(s); 

    LastGPA = getinfoGFX.getDataLastGPA(s); 
    LastHourse = getinfoGFX.getDataLastHourse(s); 
    Type = getinfoGFX.getGPAType(s); 

    subAllGrades = getinfoGFX.getdataAllSubjectsGrades(semestrId); 
    subAllHourse = getinfoGFX.getdataAllSubjectsHourse(semestrId); 

    pText1.setColor(Color.BLACK); 
    pText1.setTextSize(35); 
    pText1.setTextAlign(Align.CENTER); 
    pText1.setTypeface(font); 
    pText1.setStyle(Paint.Style.STROKE); 
    pText1.setStrokeWidth(5); 

    pText2.setColor(Color.BLACK); 
    pText2.setTextAlign(Align.CENTER); 
    pText2.setTypeface(font); 
    pText2.setTextSize(35); 
    pText2.setColor(Color.WHITE); 
    pText2.setStrokeWidth(0); 

    pText3.setColor(Color.BLACK); 
    pText3.setTextSize(35); 
    pText3.setTextAlign(Align.RIGHT); 
    pText3.setTypeface(font); 
    pText3.setStyle(Paint.Style.STROKE); 
    pText3.setStrokeWidth(5); 

    pText4.setColor(Color.BLACK); 
    pText4.setTextAlign(Align.RIGHT); 
    pText4.setTypeface(font); 
    pText4.setTextSize(35); 
    pText4.setColor(Color.WHITE); 
    pText4.setStrokeWidth(0); 

    rect1.setColor(Color.rgb(79, 129, 189)); 
    rect1.setStrokeWidth(0); 
    rect1.setStyle(Paint.Style.FILL_AND_STROKE); 
    rect2.setColor(Color.BLACK); 
    rect2.setStrokeWidth(0); 
    rect2.setStyle(Paint.Style.FILL_AND_STROKE); 
    int count = 0; 

    canvas.drawColor(Color.alpha(0)); 
    dy-=10; 
    canvas.translate(0, dy); 
    for (int i = 0; i < semesterNo.length; i++) { 
     float height = (getMeasuredHeight()/8); 
     float startY = (getMeasuredHeight()/8) * count; 
     float semYearStartX = getMeasuredWidth()/4, semYearStartY = startY, semYearEndX = semYearStartX 
       + semYearStartX + semYearStartX, semYearEndY = semYearStartY 
       + height; 
     float semNoStartX = 0, semNoStartY = semYearEndY, semNoEndX = getMeasuredWidth(), semNoEndY = semNoStartY 
       + height; 
     float GradeStartX = 0, GradeStartY = semNoEndY, GradeEndX = getMeasuredWidth()/4, GradeEndY = GradeStartY 
       + height; 
     float HourseStartX = GradeEndX, HourseStartY = semNoEndY, HourseEndX = getMeasuredWidth()/2, HourseEndY = GradeStartY 
       + height; 
     float SubNameStartX = HourseEndX, SubNameStartY = semNoEndY, SubNameEndX = getMeasuredWidth(), SubNameEndY = GradeStartY 
       + height; 

     canvas.drawRect(GradeStartX, GradeStartY, GradeEndX, GradeEndY, 
       rect2); 
     canvas.drawRect(GradeStartX + 3, GradeStartY + 3, GradeEndX - 3, 
       GradeEndY - 3, rect1); 
     canvas.drawRect(HourseStartX, HourseStartY, HourseEndX, HourseEndY, 
       rect2); 
     canvas.drawRect(HourseStartX + 3, HourseStartY + 3, HourseEndX - 3, 
       HourseEndY - 3, rect1); 
     canvas.drawRect(SubNameStartX, SubNameStartY, SubNameEndX, 
       SubNameEndY, rect2); 
     canvas.drawRect(SubNameStartX + 3, SubNameStartY + 3, 
       SubNameEndX - 3, SubNameEndY - 3, rect1); 
     canvas.drawRect(semNoStartX, semNoStartY, semNoEndX, semNoEndY, 
       rect2); 
     canvas.drawRect(semNoStartX + 3, semNoStartY + 3, semNoEndX - 3, 
       semNoEndY - 3, rect1); 
     canvas.drawRect(semYearStartX, semYearStartY, semYearEndX, 
       semYearEndY, rect2); 
     canvas.drawRect(semYearStartX + 3, semYearStartY + 3, 
       semYearEndX - 3, semYearEndY - 3, rect1); 


     canvas.drawText("السنة رقم" + semestrYear[i], 
       (semYearEndX + semYearStartX)/2, 
       (semYearEndY + semYearStartY)/2, pText1); 
     canvas.drawText("السنة رقم" + semestrYear[i], 
       (semYearEndX + semYearStartX)/2, 
       (semYearEndY + semYearStartY)/2, pText2); 

     canvas.drawText("الفصل الدراسي " + semesterNo[i], semNoEndX, 
       (semNoStartY + semNoEndY)/2, pText3); 
     canvas.drawText("الفصل الدراسي " + semesterNo[i], semNoEndX, 
       (semNoStartY + semNoEndY)/2, pText4); 

     canvas.drawText("الدرجة", (GradeStartX + GradeEndX)/2, 
       (GradeStartY + GradeEndY)/2 + 15, pText1); 
     canvas.drawText("الدرجة", (GradeStartX + GradeEndX)/2, 
       (GradeStartY + GradeEndY)/2 + 15, pText2); 

     canvas.drawText("الساعات", (HourseEndX + HourseStartX)/2, 
       (HourseEndY + HourseStartY)/2 + 15, pText1); 
     canvas.drawText("الساعات", (HourseEndX + HourseStartX)/2, 
       (HourseEndY + HourseStartY)/2 + 15, pText2); 

     canvas.drawText("اسم المادة", (SubNameEndX + SubNameStartX)/2, 
       (SubNameEndY + SubNameStartY)/2 + 15, pText1); 
     canvas.drawText("اسم المادة", (SubNameEndX + SubNameStartX)/2, 
       (SubNameEndY + SubNameStartY)/2 + 15, pText2); 
     subjectsId = getinfoGFX.getdataSubjectsID(semestrId[i]); 
     semesterF = getinfoGFX.getdataSemesterIdF(semestrId[i]); 
     subName = getinfoGFX.getdataSubjectsName(semestrId[i]); 
     subHourse = getinfoGFX.getdataSubjectsHourse(semestrId[i]); 
     subGrades = getinfoGFX.getdataSubjectsGrades(semestrId[i]); 
     count++; 
     for (int k = 0; k < subName.length; k++) { 


      startY = (getMeasuredHeight()/8) * count; 
      semYearStartX = getMeasuredWidth()/4; 
      semYearStartY = startY; 
      semYearEndX = semYearStartX + semYearStartX + semYearStartX; 
      semYearEndY = semYearStartY + height; 
      semNoStartX = 0; 
      semNoStartY = semYearEndY; 
      semNoEndX = getMeasuredWidth(); 
      semNoEndY = semNoStartY+ height; 
      GradeStartX = 0; 
      GradeStartY = semNoEndY; 
      GradeEndX = getMeasuredWidth()/4; 
      GradeEndY = GradeStartY+ height; 
      HourseStartX = GradeEndX; 
      HourseStartY = semNoEndY; 
      HourseEndX = getMeasuredWidth()/2; 
      HourseEndY = GradeStartY + height; 
      SubNameStartX = HourseEndX; 
      SubNameStartY = semNoEndY; 
      SubNameEndX = getMeasuredWidth(); 
      SubNameEndY = GradeStartY+ height; 

      canvas.drawRect(GradeStartX, GradeStartY, GradeEndX, GradeEndY, 
        rect2); 
      canvas.drawRect(GradeStartX + 3, GradeStartY + 3, GradeEndX - 3, 
        GradeEndY - 3, rect1); 
      canvas.drawRect(HourseStartX, HourseStartY, HourseEndX, HourseEndY, 
        rect2); 
      canvas.drawRect(HourseStartX + 3, HourseStartY + 3, HourseEndX - 3, 
        HourseEndY - 3, rect1); 
      canvas.drawRect(SubNameStartX, SubNameStartY, SubNameEndX, 
        SubNameEndY, rect2); 
      canvas.drawRect(SubNameStartX + 3, SubNameStartY + 3, 
        SubNameEndX - 3, SubNameEndY - 3, rect1); 

      canvas.drawText(subGrades[k], (GradeStartX + GradeEndX)/2, 
        (GradeStartY + GradeEndY)/2 + 15, pText1); 
      canvas.drawText(subGrades[k], (GradeStartX + GradeEndX)/2, 
        (GradeStartY + GradeEndY)/2 + 15, pText2); 

      canvas.drawText(subHourse[k], (HourseEndX + HourseStartX)/2, 
        (HourseEndY + HourseStartY)/2 + 15, pText1); 
      canvas.drawText(subHourse[k], (HourseEndX + HourseStartX)/2, 
        (HourseEndY + HourseStartY)/2 + 15, pText2); 

      canvas.drawText(subName[k], (SubNameEndX + SubNameStartX)/2, 
        (SubNameEndY + SubNameStartY)/2 + 15, pText1); 
      canvas.drawText(subName[k], (SubNameEndX + SubNameStartX)/2, 
        (SubNameEndY + SubNameStartY)/2 + 15, pText2); 
      count++; 
     } 
     count+=subName.length+1; 

    } 
    getinfoGFX.close(); 
    canvas.drawText(LastGPA, getMeasuredWidth()/2, getMeasuredHeight()/2, pText1); 
    canvas.drawText(LastGPA, getMeasuredWidth()/2, getMeasuredHeight()/2, pText2); 
    invalidate(); 

    super.onDraw(canvas); 

} 

나는 그것이 충돌하지 않는 invalidate(); 줄을 삭제하지만 난 내 응용 프로그램에 필요합니다.

UPDATE

: 여기 오류 로그

12-15 13:25:17.765: E/AndroidRuntime(4096): FATAL EXCEPTION: main 
12-15 13:25:17.765: E/AndroidRuntime(4096): android.database.CursorWindowAllocationException: Cursor window allocation of 2048 kb failed. # Open Cursors=752 (# cursors opened by this proc=752) 
12-15 13:25:17.765: E/AndroidRuntime(4096):  at android.database.CursorWindow.<init>(CursorWindow.java:108) 
12-15 13:25:17.765: E/AndroidRuntime(4096):  at android.database.CursorWindow.<init>(CursorWindow.java:100) 
12-15 13:25:17.765: E/AndroidRuntime(4096):  at android.database.AbstractWindowedCursor.clearOrCreateWindow(AbstractWindowedCursor.java:198) 
12-15 13:25:17.765: E/AndroidRuntime(4096):  at android.database.sqlite.SQLiteCursor.clearOrCreateWindow(SQLiteCursor.java:289) 
12-15 13:25:17.765: E/AndroidRuntime(4096):  at android.database.sqlite.SQLiteCursor.fillWindow(SQLiteCursor.java:139) 
12-15 13:25:17.765: E/AndroidRuntime(4096):  at android.database.sqlite.SQLiteCursor.getCount(SQLiteCursor.java:133) 
12-15 13:25:17.765: E/AndroidRuntime(4096):  at android.database.AbstractCursor.moveToPosition(AbstractCursor.java:196) 
12-15 13:25:17.765: E/AndroidRuntime(4096):  at android.database.AbstractCursor.moveToFirst(AbstractCursor.java:236) 
12-15 13:25:17.765: E/AndroidRuntime(4096):  at com.example.gpa.dataBase.getdataSemesterIdF(dataBase.java:453) 
12-15 13:25:17.765: E/AndroidRuntime(4096):  at com.example.gpa.semestersGFX.onDraw(semestersGFX.java:162) 
12-15 13:25:17.765: E/AndroidRuntime(4096):  at android.view.View.draw(View.java:13767) 
12-15 13:25:17.765: E/AndroidRuntime(4096):  at android.view.View.getDisplayList(View.java:12718) 
12-15 13:25:17.765: E/AndroidRuntime(4096):  at android.view.View.getDisplayList(View.java:12762) 
12-15 13:25:17.765: E/AndroidRuntime(4096):  at android.view.ViewGroup.dispatchGetDisplayList(ViewGroup.java:3151) 
12-15 13:25:17.765: E/AndroidRuntime(4096):  at android.view.View.getDisplayList(View.java:12654) 
12-15 13:25:17.765: E/AndroidRuntime(4096):  at android.view.View.getDisplayList(View.java:12762) 
12-15 13:25:17.765: E/AndroidRuntime(4096):  at android.view.ViewGroup.dispatchGetDisplayList(ViewGroup.java:3151) 
12-15 13:25:17.765: E/AndroidRuntime(4096):  at android.view.View.getDisplayList(View.java:12654) 
12-15 13:25:17.765: E/AndroidRuntime(4096):  at android.view.View.getDisplayList(View.java:12762) 
12-15 13:25:17.765: E/AndroidRuntime(4096):  at android.view.ViewGroup.dispatchGetDisplayList(ViewGroup.java:3151) 
12-15 13:25:17.765: E/AndroidRuntime(4096):  at android.view.View.getDisplayList(View.java:12654) 
12-15 13:25:17.765: E/AndroidRuntime(4096):  at android.view.View.getDisplayList(View.java:12762) 
12-15 13:25:17.765: E/AndroidRuntime(4096):  at android.view.ViewGroup.dispatchGetDisplayList(ViewGroup.java:3151) 
12-15 13:25:17.765: E/AndroidRuntime(4096):  at android.view.View.getDisplayList(View.java:12654) 
12-15 13:25:17.765: E/AndroidRuntime(4096):  at android.view.View.getDisplayList(View.java:12762) 
12-15 13:25:17.765: E/AndroidRuntime(4096):  at android.view.HardwareRenderer$GlRenderer.draw(HardwareRenderer.java:1144) 
12-15 13:25:17.765: E/AndroidRuntime(4096):  at android.view.ViewRootImpl.draw(ViewRootImpl.java:2275) 
12-15 13:25:17.765: E/AndroidRuntime(4096):  at android.view.ViewRootImpl.performDraw(ViewRootImpl.java:2147) 
12-15 13:25:17.765: E/AndroidRuntime(4096):  at android.view.ViewRootImpl.performTraversals(ViewRootImpl.java:1958) 
12-15 13:25:17.765: E/AndroidRuntime(4096):  at android.view.ViewRootImpl.doTraversal(ViewRootImpl.java:1112) 
12-15 13:25:17.765: E/AndroidRuntime(4096):  at android.view.ViewRootImpl$TraversalRunnable.run(ViewRootImpl.java:4518) 
12-15 13:25:17.765: E/AndroidRuntime(4096):  at android.view.Choreographer$CallbackRecord.run(Choreographer.java:725) 
12-15 13:25:17.765: E/AndroidRuntime(4096):  at android.view.Choreographer.doCallbacks(Choreographer.java:555) 
12-15 13:25:17.765: E/AndroidRuntime(4096):  at android.view.Choreographer.doFrame(Choreographer.java:525) 
12-15 13:25:17.765: E/AndroidRuntime(4096):  at android.view.Choreographer$FrameDisplayEventReceiver.run(Choreographer.java:711) 
12-15 13:25:17.765: E/AndroidRuntime(4096):  at android.os.Handler.handleCallback(Handler.java:615) 
12-15 13:25:17.765: E/AndroidRuntime(4096):  at android.os.Handler.dispatchMessage(Handler.java:92) 
12-15 13:25:17.765: E/AndroidRuntime(4096):  at android.os.Looper.loop(Looper.java:137) 
12-15 13:25:17.765: E/AndroidRuntime(4096):  at android.app.ActivityThread.main(ActivityThread.java:4898) 
12-15 13:25:17.765: E/AndroidRuntime(4096):  at java.lang.reflect.Method.invokeNative(Native Method) 
12-15 13:25:17.765: E/AndroidRuntime(4096):  at java.lang.reflect.Method.invoke(Method.java:511) 
12-15 13:25:17.765: E/AndroidRuntime(4096):  at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1008) 
12-15 13:25:17.765: E/AndroidRuntime(4096):  at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:775) 
12-15 13:25:17.765: E/AndroidRuntime(4096):  at dalvik.system.NativeStart.main(Native Method) 
+0

logcat에서 오류 로그를 게시 할 수 있다면 도움이 될 것입니다. – iagreen

+0

Wonder!! 그것의 개선. –

+0

내 에뮬레이터 내 장치에서 문제가 올바르게 실행됩니다. 내 장치에서 오류 로그를 감지하는 방법 –

답변

2

편집이다 : 당신의 문제는 getinfoGFX 클래스처럼 오류 로그를 보면에게, 그것은 보인다. getdata... 메서드에서는 SQL 쿼리에 대한 커서를 만드는 것처럼 보입니다. 종료하기 전에 커서에서 close() 메소드를 호출하는지 확인하십시오.


Invalidate()를 호출하면 문제가 발생합니다. 로그를 볼 때까지 충돌을 일으키는 지 확실하지 않지만 기본적으로 다시 그려주기 위해 설정하고 있습니다. 안드로이드 문서에서 무효화는 다음을 수행합니다. -

전체보기를 무효화합니다. 보기가 표시되면 onDraw (android.graphics.Canvas)가 미래의 어느 시점에서 호출됩니다. 이것은 UI 스레드에서 호출해야합니다.

onDraw 루틴의 내부에서 호출 할 때 onDraw 함수가 항상 실행되도록 유지합니다.

+0

나는 마지막으로 오류 로그를 얻었습니다. –

+0

오류 로그를 고려하여 대답을 업데이트했습니다. – iagreen

+0

예 아주 고맙습니다. –

관련 문제