本文整理匯總了Java中org.xmlpull.v1.XmlPullParser.CDSECT屬性的典型用法代碼示例。如果您正苦於以下問題:Java XmlPullParser.CDSECT屬性的具體用法?Java XmlPullParser.CDSECT怎麽用?Java XmlPullParser.CDSECT使用的例子?那麽, 這裏精選的屬性代碼示例或許可以為您提供幫助。您也可以進一步了解該屬性所在類org.xmlpull.v1.XmlPullParser
的用法示例。
在下文中一共展示了XmlPullParser.CDSECT屬性的2個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。
示例1: captureElement
/**
* Serializes the current element and all child nodes as a String.
* @param parser The parser to pull from.
* @return The composed element string.
* @throws XmlPullParserException
* @throws IOException
*/
public static String captureElement(XmlPullParser parser)
throws XmlPullParserException, IOException
{
int event = parser.getEventType();
if (event != XmlPullParser.START_TAG) {
throw new XmlPullParserException("Expected call to begin at START_TAG");
}
int depth = 0;
StringWriter sw = new StringWriter();
XmlSerializer serializer = PARSER_FACTORY.newSerializer();
serializer.setOutput(sw);
String namespace, prefix;
while (event != XmlPullParser.END_DOCUMENT) {
switch (event) {
case XmlPullParser.START_TAG:
++depth;
namespace = parser.getNamespace();
prefix = parser.getPrefix();
if (namespace != null && prefix != null) {
serializer.setPrefix(prefix, namespace);
}
serializer.startTag(namespace, parser.getName());
int attrCount = parser.getAttributeCount();
for (int i = 0; i < attrCount; ++i) {
namespace = parser.getAttributeNamespace(i);
prefix = parser.getAttributePrefix(i);
if (namespace != null && prefix != null) {
serializer.setPrefix(prefix, namespace);
}
serializer.attribute(namespace, parser.getAttributeName(i),
parser.getAttributeValue(i));
}
break;
case XmlPullParser.TEXT:
case XmlPullParser.IGNORABLE_WHITESPACE:
serializer.text(parser.getText());
break;
case XmlPullParser.CDSECT:
serializer.cdsect(parser.getText());
break;
case XmlPullParser.END_TAG:
namespace = parser.getNamespace();
if (namespace != null) {
serializer.setPrefix(parser.getPrefix(), namespace);
}
serializer.endTag(namespace, parser.getName());
--depth;
break;
}
if (depth <= 0) {
serializer.flush();
return sw.toString();
}
event = parser.next();
}
throw new IOException("Unexpected end of document.");
}
示例2: readFromXml
public void readFromXml(XmlPullParser parser)
{
clear();
try
{
// On android version < 11, the standard XmlPullParser implementation has a bug:
// it throws a UnsupportedOperationException at getting CDSECT using nextToken().
// Therefore, XmlPullParserFactory.newInstance().newPullParser() shall be used
// to create parser instance in order to get it worked on Android versions 8-10.
final String type = parser.getAttributeValue(null, XML_PROP_IMAGE_TYPE);
if (type == null)
{
throw new Exception("image type is unknown");
}
final int event = parser.nextToken();
if (event == XmlPullParser.CDSECT)
{
final String imageText = parser.getText();
if (imageText == null || imageText.length() == 0)
{
throw new Exception("empty CDSECT");
}
byte[] imageDecoded = Base64.decode(imageText, BASE64_OPTIONS);
if (imageDecoded == null)
{
throw new Exception("cannot decode image, string lenght = " + imageText.length());
}
if (XML_PROP_IMAGE_PNG.equalsIgnoreCase(type))
{
ByteArrayInputStream imageStream = new ByteArrayInputStream(imageDecoded);
setBitmap(BitmapFactory.decodeStream(imageStream));
imageStream.close();
}
else if (XML_PROP_IMAGE_SVG.equalsIgnoreCase(type))
{
setSvg(new String(imageDecoded));
}
}
else
{
throw new Exception("CDSECT is not found");
}
}
catch (Exception e)
{
ViewUtils.Debug(this, e.getLocalizedMessage());
}
}