2011-03-16 9 views
3

私は、textviewを拡張し、フォーマットされたテキストをその内部に表示するカスタムアンドロイドコンポーネントを作成することに興味があります。 これは私が書いたコードです:Android:Html TextView - それは可能ですか?

/** *のTODO */

import android.content.Context; 
import android.graphics.Canvas; 
import android.text.Html; 
import android.util.AttributeSet; 
import android.widget.TextView; 

public class HtmlTextView extends TextView { 

    private static final String tag = "HtmlTextView"; 

    public HtmlTextView(Context context, AttributeSet attrs, 
      int defStyle) { 
     super(context, attrs, defStyle); 
    } 

    public HtmlTextView(Context context, AttributeSet attrs) { 
     super(context, attrs); 
    } 

    public HtmlTextView(Context context) { 
     super(context); 
    } 

    /* 
    * (non-Javadoc) 
    * 
    * @see android.widget.TextView#onDraw(android.graphics.Canvas) 
    */ 
    @Override 
    protected void onDraw(Canvas canvas) { 


       setText(Html.fromHtml((String) getText())); 


     super.onDraw(canvas); 
    } 

} 

とテストレイアウトXMLに私は次のようにあります

<com.package.ui.tools.HtmlTextView 
    android:layout_width="fill_parent" 
    android:layout_height="wrap_content" 
    android:text="@string/elad" 
    android:textSize="28dip" 
    android:padding="10dip" 
    android:gravity="center"/> 

で定義された文字列strings.xmlは:

<!-- testing --> 
<string name="elad">elad <b> elad </b> elad</string> 

このd oesnt仕事、しかし奇妙これは、私は日食でスローされた以下の例外を取得することをされています

java.lang.NoClassDefFoundError: org/ccil/cowan/tagsoup/Parser 
at android.text.Html.fromHtml(Html.java:125) 
at android.text.Html.fromHtml(Html.java:102) 
at com.package.ui.tools.HtmlTextView.onDraw(HtmlTextView.java:39) 
at android.view.View.draw(View.java:6740) 
at android.view.ViewGroup.drawChild(ViewGroup.java:1640) 
at android.view.ViewGroup.dispatchDraw(ViewGroup.java:1367) 
at android.view.ViewGroup.drawChild(ViewGroup.java:1638) 
at android.view.ViewGroup.dispatchDraw(ViewGroup.java:1367) 
at android.view.View.draw(View.java:6743) 
at android.widget.FrameLayout.draw(FrameLayout.java:352) 
at com.android.layoutlib.bridge.Bridge.computeLayout(Bridge.java:452) 
at com.android.ide.common.rendering.LayoutLibrary.createLegacySession(LayoutLibrary.java:404) 
at com.android.ide.common.rendering.LayoutLibrary.createSession(LayoutLibrary.java:285) 
at com.android.ide.eclipse.adt.internal.editors.layout.gle2.GraphicalEditorPart.renderWithBridge(GraphicalEditorPart.java:1506) 
at com.android.ide.eclipse.adt.internal.editors.layout.gle2.GraphicalEditorPart.renderWithBridge(GraphicalEditorPart.java:1312) 
at com.android.ide.eclipse.adt.internal.editors.layout.gle2.GraphicalEditorPart.recomputeLayout(GraphicalEditorPart.java:1043) 
at com.android.ide.eclipse.adt.internal.editors.layout.gle2.GraphicalEditorPart.activated(GraphicalEditorPart.java:870) 
at com.android.ide.eclipse.adt.internal.editors.layout.LayoutEditor.partActivated(LayoutEditor.java:378) 
at com.android.ide.eclipse.adt.internal.editors.layout.LayoutEditor.partBroughtToTop(LayoutEditor.java:387) 
at org.eclipse.ui.internal.PartListenerList$2.run(PartListenerList.java:87) 
at org.eclipse.core.runtime.SafeRunner.run(SafeRunner.java:42) 
at org.eclipse.core.runtime.Platform.run(Platform.java:888) 
at org.eclipse.ui.internal.PartListenerList.fireEvent(PartListenerList.java:57) 
at org.eclipse.ui.internal.PartListenerList.firePartBroughtToTop(PartListenerList.java:85) 
at org.eclipse.ui.internal.PartService.firePartBroughtToTop(PartService.java:208) 
at org.eclipse.ui.internal.WorkbenchPagePartList.firePartBroughtToTop(WorkbenchPagePartList.java:76) 
at org.eclipse.ui.internal.WorkbenchPagePartList.fireActiveEditorChanged(WorkbenchPagePartList.java:52) 
at org.eclipse.ui.internal.PartList.setActiveEditor(PartList.java:162) 
at org.eclipse.ui.internal.WorkbenchPage.makeActiveEditor(WorkbenchPage.java:1281) 
at org.eclipse.ui.internal.WorkbenchPage.setActivePart(WorkbenchPage.java:3530) 
at org.eclipse.ui.internal.WorkbenchPage.requestActivation(WorkbenchPage.java:3077) 
at org.eclipse.ui.internal.PartPane.requestActivation(PartPane.java:279) 
at org.eclipse.ui.internal.EditorPane.requestActivation(EditorPane.java:98) 
at org.eclipse.ui.internal.PartPane.setFocus(PartPane.java:325) 
at org.eclipse.ui.internal.EditorPane.setFocus(EditorPane.java:127) 
at org.eclipse.ui.internal.PartStack.presentationSelectionChanged(PartStack.java:844) 
at org.eclipse.ui.internal.PartStack.access$1(PartStack.java:827) 
at org.eclipse.ui.internal.PartStack$1.selectPart(PartStack.java:137) 
at org.eclipse.ui.internal.presentations.util.TabbedStackPresentation$1.handleEvent(TabbedStackPresentation.java:133) 
at org.eclipse.ui.internal.presentations.util.AbstractTabFolder.fireEvent(AbstractTabFolder.java:269) 
at org.eclipse.ui.internal.presentations.util.AbstractTabFolder.fireEvent(AbstractTabFolder.java:278) 
at org.eclipse.ui.internal.presentations.defaultpresentation.DefaultTabFolder.access$1(DefaultTabFolder.java:1) 
at org.eclipse.ui.internal.presentations.defaultpresentation.DefaultTabFolder$2.handleEvent(DefaultTabFolder.java:88) 
at org.eclipse.swt.widgets.EventTable.sendEvent(EventTable.java:84) 
at org.eclipse.swt.widgets.Widget.sendEvent(Widget.java:1053) 
at org.eclipse.swt.widgets.Widget.sendEvent(Widget.java:1077) 
at org.eclipse.swt.widgets.Widget.sendEvent(Widget.java:1062) 
at org.eclipse.swt.widgets.Widget.notifyListeners(Widget.java:774) 
at org.eclipse.swt.custom.CTabFolder.setSelection(CTabFolder.java:2743) 
at org.eclipse.swt.custom.CTabFolder.onMouse(CTabFolder.java:1429) 
at org.eclipse.swt.custom.CTabFolder$1.handleEvent(CTabFolder.java:257) 
at org.eclipse.swt.widgets.EventTable.sendEvent(EventTable.java:84) 
at org.eclipse.swt.widgets.Widget.sendEvent(Widget.java:1053) 
at org.eclipse.swt.widgets.Display.runDeferredEvents(Display.java:4066) 
at org.eclipse.swt.widgets.Display.readAndDispatch(Display.java:3657) 
at org.eclipse.ui.internal.Workbench.runEventLoop(Workbench.java:2640) 
at org.eclipse.ui.internal.Workbench.runUI(Workbench.java:2604) 
at org.eclipse.ui.internal.Workbench.access$4(Workbench.java:2438) 
at org.eclipse.ui.internal.Workbench$7.run(Workbench.java:671) 
at org.eclipse.core.databinding.observable.Realm.runWithDefault(Realm.java:332) 
at org.eclipse.ui.internal.Workbench.createAndRunWorkbench(Workbench.java:664) 
at org.eclipse.ui.PlatformUI.createAndRunWorkbench(PlatformUI.java:149) 
at org.eclipse.ui.internal.ide.application.IDEApplication.start(IDEApplication.java:115) 
at org.eclipse.equinox.internal.app.EclipseAppHandle.run(EclipseAppHandle.java:196) 
at org.eclipse.core.runtime.internal.adaptor.EclipseAppLauncher.runApplication(EclipseAppLauncher.java:110) 
at org.eclipse.core.runtime.internal.adaptor.EclipseAppLauncher.start(EclipseAppLauncher.java:79) 
at org.eclipse.core.runtime.adaptor.EclipseStarter.run(EclipseStarter.java:369) 
at org.eclipse.core.runtime.adaptor.EclipseStarter.run(EclipseStarter.java:179) 
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) 
at sun.reflect.NativeMethodAccessorImpl.invoke(Unknown Source) 
at sun.reflect.DelegatingMethodAccessorImpl.invoke(Unknown Source) 
at java.lang.reflect.Method.invoke(Unknown Source) 
at org.eclipse.equinox.launcher.Main.invokeFramework(Main.java:619) 
at org.eclipse.equinox.launcher.Main.basicRun(Main.java:574) 
at org.eclipse.equinox.launcher.Main.run(Main.java:1407) 

を誰もが、私はこのエラーを取得しています理由として任意のアイデアを持っていますか? 達成しようとしていることは可能ですか?ありがとう、 e。 e。

+0

TextViewはすでにいくつかのHTML要素をサポートしていますが、なぜホイールを再開発したいのですか?ちょうど使用:mTextSample.setText(Html.fromHtml(text)); – Pentium10

+0

答えてくれてありがとう、私はアプリケーションが国際化可能であることを言及することを忘れていたので、特定の言語のstrings.xmlファイルからリソースを使い、レイアウトがxmlで完全であり、アプリケーションを実行してテキストビューの内容を表示する – ekatz

答えて

4

TextViewクラスは、Html.fromHtmlを使用して基本的なhtmlタグをサポートしていますので、HtmlTextViewを作成する必要はありません。

内部的にSDKは、HTML(解析されていないクラス)を解析するためにTagSoupを使用します。デザインモードでレイアウトを表示しようとすると、Eclipse例外が発生していると仮定しています。 Eclipseビューでカスタムビューを正しくレンダリングするには、いくつか特別な作業が必要です。

どちらの方法でも、必要に応じて基本的なTextViewを使用できます。

更新:のstrings.xmlで

文字列はTextViewので使用するためのHTMLを含めることができます。

+0

基本的なテキストビューでは、strings.xmlに太字で表示されているテキストは、デザインモードで太字で表示されません。 <文字列名=「ELAD」> elad1 elad2 elad3 のみデザインビューでelad1 elad2を示し、elad2は大胆ではありません...: は実際には、いくつかの奇妙な理由のために何が起こるか、として定義された文字列があることです – ekatz

+0

デザインモードでどのように見えるのか、実際のデバイスでどのように見えるのか、さらに気になりますか? –

+0

実際のデバイスでは正常に機能し、私が見ている問題はデザインビューにしかないと言っていますか? – ekatz

2

だけ試してください:あなたはthis answerのように特定の文字をエスケープする必要がstrings.xmlに対処するための

normalTextView.setText(Html.fromHtml("<bold>Hello World!</bold>")); 

を。例があります与えられた:あなたは、文字列エディタを使用する場合

<resources> 
    <string name="somestring"> 
     &lt;B&gt;Title&lt;/B&gt;&lt;BR/&gt; 
     Content 
    </string> 
</resources> 

ロビーには言及したように、これは自動的に行われます。

+2

と、エディタを使用して文字列を追加し、手動でファイルを編集するだけではなく、あなたのためにエスケープします。 –

+0

それは便利です!ありがとうございました。 ]]> <文字列名=「myBoldText」>マイ太字テキスト: –

+0

また、のような文字列要素の内容としてマイ太字テキスト]]>を使用することができます –