【发布时间】:2016-11-03 02:21:59
【问题描述】:
我正在尝试调整 Mupdf 1.9 android 以便能够使用它来处理乐谱。此时,我希望能够使用不同的颜色和笔粗细进行注释。 我在 mupdf-1.9a-source/platform/android/viewer/ 工作 基本的墨迹注释是一支大红笔,在PageView.java(绘图部分)和mupdf.c(实际验证绘图时)中硬编码
所以我修改了保存墨水注释的每个函数,以便将墨水颜色和厚度传递给所有函数。 现在我可以在编译时在 MuPDFActivity 中选择颜色和粗细,并将其传递给 mupdf.c 使用它。
显然,我希望能够在执行期间通过 GUI 随时选择颜色和厚度。因此,我在第 318 行修改了 res/layout/buttons.xml 中的相对布局(id:topBar5Accept)并添加了 2 个 edittext 并调整了周围的代码(相对定位),因此我希望在墨水注释期间将这些 edittext 放在顶部栏中。 但是现在 mupdf 在启动时崩溃了。
我无法理解 mupdf for android 如何处理其顶栏。什么是 ViewAnimator topBarSwitcher?如何修改 mupdf 中的顶部栏? 提前感谢您的耐心等待。
这是我编辑到 res/layout/buttons.xml 第 318 行的部分,我在相对布局中添加了 2 个 edittext:
<RelativeLayout
android:id="@+id/topBar5Accept"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:background="@color/toolbar" >
<ImageButton
android:id="@+id/cancelAcceptButton"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_centerVertical="true"
android:layout_alignParentLeft="true"
android:contentDescription="@string/cancel"
android:background="@drawable/button"
android:onClick="OnCancelAcceptButtonClick"
android:src="@drawable/ic_cancel" />
<EditText
android:id="@+id/inkColor"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_centerVertical="true"
android:layout_toRightOf="@+id/cancelAcceptButton"
android:layout_toLeftOf="@+id/annotType"
android:inputType="number"
android:text="0xFFFF0000"
android:hint="0xFF00FF00"
/>
<TextView
android:id="@+id/annotType"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_centerVertical="true"
android:layout_toRightOf="@+id/inkColor"
android:layout_toLeftOf="@+id/inkThickness"
android:gravity="center"
android:singleLine="true"
android:textColor="#FFFFFF"
android:textStyle="bold"
android:textAppearance="?android:attr/textAppearanceMedium" />
<EditText
android:id="@+id/inkThickness"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_centerVertical="true"
android:layout_toRightOf="@+id/annotType"
android:layout_toLeftOf="@+id/acceptButton"
android:inputType="numberDecimal"
android:text="4.0"
android:hint="5.0"
/>
<ImageButton
android:id="@+id/acceptButton"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_centerVertical="true"
android:layout_alignParentRight="true"
android:contentDescription="@string/accept"
android:background="@drawable/button"
android:onClick="OnAcceptButtonClick"
android:src="@drawable/ic_check" />
</RelativeLayout>
这是启动 MuPDF 时的 logcat:
I/Timeline( 877): Timeline: Activity_launch_request id:com.artifex.mupdfdemo time:690956
I/ActivityManager( 548): START u0 {act=android.intent.action.MAIN cat=[android.intent.category.LAUNCHER] flg=0x10200000 cmp=com.artifex.mupdfdemo/.ChoosePDFActivity} from pid 877
V/Zygote ( 2677): Switching descriptor 33 to /dev/null
V/Zygote ( 2677): Switching descriptor 9 to /dev/null
D/dalvikvm( 2677): Late-enabling CheckJNI
I/ActivityManager( 548): Start proc com.artifex.mupdfdemo for activity com.artifex.mupdfdemo/.ChoosePDFActivity: pid=2677 uid=10061 gids={50061, 1028, 1015, 3003}
D/ActivityThread( 2677): handleBindApplication:com.artifex.mupdfdemo
D/ActivityThread( 2677): setTargetHeapUtilization:0.25
D/ActivityThread( 2677): setTargetHeapMinFree:524288
W/Adreno-GSL( 2677): : Android framework reported version 2. So, don't force ES30
I/Adreno-EGL( 2677): : EGL 1.4 QUALCOMM build: AU_LINUX_ANDROID_KK_2.7_RB1.04.04.00.007.018_msm8960_KK_2.7_RB1_CL3869936_release_AU (CL3869936)
I/Adreno-EGL( 2677): OpenGL ES Shader Compiler Version: 17.01.10.SPL
I/Adreno-EGL( 2677): Build Date: 12/09/13 Mon
I/Adreno-EGL( 2677): Local Branch: mybranch2092625
I/Adreno-EGL( 2677): Remote Branch: quic/kk_2.7_rb1.15
I/Adreno-EGL( 2677): Local Patches: NONE
I/Adreno-EGL( 2677): Reconstruct Branch: AU_LINUX_ANDROID_KK_2.7_RB1.04.04.00.007.018 + NOTHING
D/OpenGLRenderer( 2677): Enabling debug mode 0
D/AndroidRuntime( 2677): Shutting down VM
W/dalvikvm( 2677): threadid=1: thread exiting with uncaught exception (group=0x41642ce0)
E/AndroidRuntime( 2677): FATAL EXCEPTION: main
E/AndroidRuntime( 2677): Process: com.artifex.mupdfdemo, PID: 2677
E/AndroidRuntime( 2677): java.lang.NullPointerException
E/AndroidRuntime( 2677): at com.artifex.mupdfdemo.ChoosePDFAdapter.getView(ChoosePDFAdapter.java:60)
E/AndroidRuntime( 2677): at android.widget.AbsListView.obtainView(AbsListView.java:2255)
E/AndroidRuntime( 2677): at android.widget.ListView.makeAndAddView(ListView.java:1790)
E/AndroidRuntime( 2677): at android.widget.ListView.fillDown(ListView.java:691)
E/AndroidRuntime( 2677): at android.widget.ListView.fillFromTop(ListView.java:752)
E/AndroidRuntime( 2677): at android.widget.ListView.layoutChildren(ListView.java:1616)
E/AndroidRuntime( 2677): at android.widget.AbsListView.onLayout(AbsListView.java:2087)
E/AndroidRuntime( 2677): at android.view.View.layout(View.java:14841)
E/AndroidRuntime( 2677): at android.view.ViewGroup.layout(ViewGroup.java:4631)
E/AndroidRuntime( 2677): at android.widget.FrameLayout.layoutChildren(FrameLayout.java:453)
E/AndroidRuntime( 2677): at android.widget.FrameLayout.onLayout(FrameLayout.java:388)
E/AndroidRuntime( 2677): at android.view.View.layout(View.java:14841)
E/AndroidRuntime( 2677): at android.view.ViewGroup.layout(ViewGroup.java:4631)
E/AndroidRuntime( 2677): at android.widget.LinearLayout.setChildFrame(LinearLayout.java:1717)
E/AndroidRuntime( 2677): at android.widget.LinearLayout.layoutVertical(LinearLayout.java:1571)
E/AndroidRuntime( 2677): at android.widget.LinearLayout.onLayout(LinearLayout.java:1480)
E/AndroidRuntime( 2677): at android.view.View.layout(View.java:14841)
E/AndroidRuntime( 2677): at android.view.ViewGroup.layout(ViewGroup.java:4631)
E/AndroidRuntime( 2677): at android.widget.FrameLayout.layoutChildren(FrameLayout.java:453)
E/AndroidRuntime( 2677): at android.widget.FrameLayout.onLayout(FrameLayout.java:388)
E/AndroidRuntime( 2677): at android.view.View.layout(View.java:14841)
E/AndroidRuntime( 2677): at android.view.ViewGroup.layout(ViewGroup.java:4631)
E/AndroidRuntime( 2677): at android.view.ViewRootImpl.performLayout(ViewRootImpl.java:1986)
E/AndroidRuntime( 2677): at android.view.ViewRootImpl.performTraversals(ViewRootImpl.java:1743)
E/AndroidRuntime( 2677): at android.view.ViewRootImpl.doTraversal(ViewRootImpl.java:996)
E/AndroidRuntime( 2677): at android.view.ViewRootImpl$TraversalRunnable.run(ViewRootImpl.java:5603)
E/AndroidRuntime( 2677): at android.view.Choreographer$CallbackRecord.run(Choreographer.java:761)
E/AndroidRuntime( 2677): at android.view.Choreographer.doCallbacks(Choreographer.java:574)
E/AndroidRuntime( 2677): at android.view.Choreographer.doFrame(Choreographer.java:544)
E/AndroidRuntime( 2677): at android.view.Choreographer$FrameDisplayEventReceiver.run(Choreographer.java:747)
E/AndroidRuntime( 2677): at android.os.Handler.handleCallback(Handler.java:733)
E/AndroidRuntime( 2677): at android.os.Handler.dispatchMessage(Handler.java:95)
E/AndroidRuntime( 2677): at android.os.Looper.loop(Looper.java:136)
E/AndroidRuntime( 2677): at android.app.ActivityThread.main(ActivityThread.java:5146)
E/AndroidRuntime( 2677): at java.lang.reflect.Method.invokeNative(Native Method)
E/AndroidRuntime( 2677): at java.lang.reflect.Method.invoke(Method.java:515)
E/AndroidRuntime( 2677): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:732)
E/AndroidRuntime( 2677): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:566)
E/AndroidRuntime( 2677): at dalvik.system.NativeStart.main(Native Method)
W/ActivityManager( 548): Force finishing activity com.artifex.mupdfdemo/.ChoosePDFActivity
I/WindowManager( 548): Screenshot max retries 4 of Token{41db7840 ActivityRecord{41c725f0 u0 com.artifex.mupdfdemo/.ChoosePDFActivity t16 f}} appWin=Window{41e9b980 u0 com.artifex.mupdfdemo/com.artifex.mupdfdemo.ChoosePDFActivity} drawState=1
W/WindowManager( 548): Screenshot failure taking screenshot for (320x480) to layer 21025
W/ActivityManager( 548): Activity pause timeout for ActivityRecord{41c725f0 u0 com.artifex.mupdfdemo/.ChoosePDFActivity t16 f}
I/Timeline( 877): Timeline: Activity_idle id: android.os.BinderProxy@41a6f8f0 time:692593
I/Timeline( 548): Timeline: Activity_windows_visible id: ActivityRecord{41cee998 u0 com.cyanogenmod.trebuchet/org.cyanogenmod.trebuchet.CustomHomeLauncher t1} time:692913
I/Process ( 2677): Sending signal. PID: 2677 SIG: 9
W/InputMethodManagerService( 548): Window already focused, ignoring focus gain of: com.android.internal.view.IInputMethodClient$Stub$Proxy@41e0fd38 attribute=null, token = android.os.BinderProxy@41dff268
I/WindowState( 548): WIN DEATH: Window{41e9b980 u0 com.artifex.mupdfdemo/com.artifex.mupdfdemo.ChoosePDFActivity}
I/ActivityManager( 548): Process com.artifex.mupdfdemo (pid 2677) has died.
【问题讨论】:
-
您可以将崩溃的 logcat 输出编辑到您的问题中吗?
-
60中ChoosePDFAdapter中的一些代码是null,而您正在尝试访问其上的方法或属性。 -
是的,我看到了,但我看不出它与我的问题有什么关系。你手头有源代码吗?这是第 59 和 60 行,它与我所做的修改无关:ChoosePDFItem item = mItems.get(position); ((TextView)v.findViewById(R.id.name)).setText(item.name);
-
Mabe 我应该先标记 mupdf,因为它似乎与这个项目有关,而不是一般的 java 问题。