/*
* This file is part of the LibreOffice project.
*
* This Source Code Form is subject to the terms of the Mozilla Public
* License, v. 2.0. If a copy of the MPL was not distributed with this
* file, You can obtain one at http://mozilla.org/MPL/2.0/.
*
* This file incorporates work covered by the following license notice:
*
* Licensed to the Apache Software Foundation (ASF) under one or more
* contributor license agreements. See the NOTICE file distributed
* with this work for additional information regarding copyright
* ownership. The ASF licenses this file to you under the Apache
* License, Version 2.0 (the "License"); you may not use this file
* except in compliance with the License. You may obtain a copy of
* the License at http://www.apache.org/licenses/LICENSE-2.0 .
*/
package ifc.text;
import com.sun.star.awt.Point;
import com.sun.star.container.XIndexContainer;
import com.sun.star.uno.UnoRuntime;
import java.util.Random;
import lib.MultiPropertyTest;
import util.utils;
/**
* Testing com.sun.star.text.TextGraphicObject
* service properties :
*
ImageMap
ContentProtected
SurroundContour
ContourOutside
ContourPolyPolygon
GraphicCrop
HoriMirroredOnEvenPages
HoriMirroredOnOddPages
VertMirrored
GraphicURL
GraphicFilter
ActualSize
AdjustLuminance
AdjustContrast
AdjustRed
AdjustGreen
AdjustBlue
Gamma
GraphicIsInverted
Transparency
GraphicColorMode
* This test needs the following object relations : *
'ImageMap'
(an implementation of
* com.sun.star.image.ImageMapObject
):
* is used to insert a new Map into collection
* from 'ImageMap' property.
* Properties testing is automated by lib.MultiPropertyTest
.
* @see com.sun.star.text.TextGraphicObject
*/
public class _TextGraphicObject extends MultiPropertyTest {
public Random rdm = new Random();
/**
* The tester which can change a sequence of Point
's
* or create a new one if necessary.
*/
protected PropertyTester PointTester = new PropertyTester() {
@Override
protected Object getNewValue(String propName, Object oldValue)
throws java.lang.IllegalArgumentException {
if (utils.isVoid(oldValue)) {
return newPoint();
} else {
return changePoint((Point[][]) oldValue);
}
}
};
/**
* Tested with custom PointTester
.
*/
public void _ContourPolyPolygon() {
log.println("Testing with custom Property tester");
testProperty("ContourPolyPolygon", PointTester);
}
/**
* Retrieves an ImageMap from relation and inserts it to the collection
* obtained as property value. Then this collection is set back.
* After that property value is get again. The number of elements
* in the old collection and in just gotten collection is checked.
*
* Has OK status if the number of elements in the new obtained
* collection is greater than in old one.
*/
public void _ImageMap() {
boolean result = true;
try {
XIndexContainer imgMap = UnoRuntime.queryInterface(
XIndexContainer.class,
oObj.getPropertyValue("ImageMap"));
int previous = imgMap.getCount();
log.println("Count (previous) " + previous);
Object im = tEnv.getObjRelation("IMGMAP");
imgMap.insertByIndex(0, im);
oObj.setPropertyValue("ImageMap", imgMap);
imgMap = UnoRuntime.queryInterface(
XIndexContainer.class,
oObj.getPropertyValue("ImageMap"));
int after = imgMap.getCount();
log.println("Count (after) " + after);
result = previous < after;
} catch (Exception ex) {
result = false;
}
tRes.tested("ImageMap", result);
}
/**
* Creates a new random points sequence.
*/
public Point[][] newPoint() {
Point[][] res = new Point[1][185];
for (int i = 0; i < res[0].length; i++) {
res[0][i] = new Point();
res[0][i].X = rd() * rd() * rd();
res[0][i].Y = rd() * rd() * rd();
}
return res;
}
public int rd() {
return rdm.nextInt(6);
}
/**
* Changes the existing point sequence.
*/
public Point[][] changePoint(Point[][] oldPoint) {
Point[][] res = oldPoint;
for (int i = 0; i < res[0].length; i++) {
res[0][i].X += 1;
res[0][i].Y += 1;
}
return res;
}
} // finish class _TextGraphicObject