uidesigner/com.nokia.sdt.series60.componentlibrary/components/controls/CEikLabel_visual.js
changeset 0 fb279309251b
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/uidesigner/com.nokia.sdt.series60.componentlibrary/components/controls/CEikLabel_visual.js	Fri Apr 03 23:33:03 2009 +0100
@@ -0,0 +1,245 @@
+/*
+* Copyright (c) 2006 Nokia Corporation and/or its subsidiary(-ies).
+* All rights reserved.
+* This component and the accompanying materials are made available
+* under the terms of the License "Eclipse Public License v1.0"
+* which accompanies this distribution, and is available
+* at the URL "http://www.eclipse.org/legal/epl-v10.html".
+*
+* Initial Contributors:
+* Nokia Corporation - initial contribution.
+*
+* Contributors:
+*
+* Description: 
+*
+*/
+
+
+include("../renderLibrary.js")
+include("../implLibrary.js")
+
+function CEikLabelVisual() {
+}
+
+function isDialog(inst) {
+	return inst.componentId == "com.nokia.sdt.series60.CAknDialog";
+}
+
+CEikLabelVisual.prototype.draw = function(instance, laf, graphics) {
+	draw(instance, laf, graphics, false);
+}
+
+CEikLabelVisual.prototype.getPreferredSize = function(instance, laf, wHint, hHint) {
+	return getPreferredSize(instance, laf, wHint, hHint, !isDialog(instance.parent));
+}
+
+
+setupCommonDirectLabelEditing(CEikLabelVisual.prototype, 
+	"text", 
+	null,
+	function(instance, laf) { return laf.getFont(instance.properties.font); } 
+	)
+
+function draw(instance, laf, graphics, wrap) {
+	var properties = instance.properties
+	var flags = 0;
+	
+	if (wrap)
+		flags |= Font.WRAPPING_ENABLED;
+	else
+		flags |= Font.WRAPPING_NONE;
+		
+	switch (properties.alignment) {
+	case "EEikLabelAlignHCenter":
+		flags |= Font.ALIGN_CENTER; break;
+	case "EEikLabelAlignHLeft":
+		flags |= Font.ALIGN_LEFT; break;
+	case "EEikLabelAlignHRight":
+		flags |= Font.ALIGN_RIGHT; break;
+	}
+	if (properties.strikethrough != false)
+		flags |= Font.OPTIONS_STRIKETHROUGH;
+	if (properties.underline != false)
+		flags |= Font.OPTIONS_UNDERLINE;
+
+/*
+	switch (properties.emphasis) {
+	case "EPartialEmphasis":
+		flags |= Font.OPTIONS_BOLD;
+		break;
+	case "EFullEmphasis":
+		flags |= Font.OPTIONS_EXTRABOLD;
+	}
+*/
+	
+	var font = laf.getFont(properties.font);
+	graphics.setFont(font);
+		
+	var pattern = null;
+	var drawBg = false;
+	graphics.setBackground(getBackgroundColor(instance, laf))
+
+	switch (properties.emphasis) {
+	case "EPartialEmphasis":
+		drawBg = true;
+		graphics.setBackground(laf.getColor("EEikColorLabelBackgroundPartialEmphasis"));
+		break;
+	case "EFullEmphasis":
+		drawBg = true;
+		graphics.setBackground(laf.getColor("EEikColorLabelBackgroundFullEmphasis"));
+	}
+
+	// get bounding rect
+	var rect = instance.getRenderingBounds();
+	var text = chooseScalableText(properties.text, font, rect.width);
+
+	if (drawBg) {
+		graphics.fillRectangle(rect);
+	}
+	
+	if (properties.brushStyle != "ENullBrush") {
+		pattern = getPattern(graphics, properties.brushStyle);
+		graphics.setBackgroundPattern(pattern);
+		graphics.fillRectangle(rect);
+	}
+	
+		
+	// Series 60 draws left justified if the extent is at least the bounds
+	oversize = new Point(rect.width * 2, rect.height);
+	size = graphics.formattedStringExtent(text, oversize, flags | Font.WRAPPING_NONE);
+	if (size.x >= rect.width) {
+		flags &= ~Font.ALIGN_MASK;
+		flags |= Font.ALIGN_LEFT;
+	}
+	
+	text = text.replace(/\u2028|\u2029/,"\u7fff");
+	graphics.drawFormattedString(text,
+			rect,
+			flags,
+			properties.pixelGapBetweenLines);
+	
+	if (pattern != null)
+		pattern.dispose();
+}
+
+// N.B.: we must define this function outside the prototype
+// in order for strings to persist as such.  Otherwise they
+// are converted to Object and switch() no longer works!
+
+function getPattern(graphics, patt) {
+
+	if (this.image3 == null) {
+		this.image3 = Images.newImage(graphics.getDevice(), 3, 3)
+	}
+	if (this.image4 == null) {
+		this.image4 = Images.newImage(graphics.getDevice(), 4, 4)
+	}
+
+	//println("brush type: " +typeof(patt));
+	
+	var img;
+	if (patt != "EDiamondCrossHatchBrush" 
+	&& patt != "EVerticalHatchBrush" 
+	&& patt != "EHorizontalHatchBrush")
+		img = this.image3
+	else
+		img = this.image4
+		
+	var gc = new GC(graphics.getDevice(), img)
+
+	//gc.setBackground(Colors.getColor(255, 255, 255))
+	gc.setBackground(graphics.getBackground())
+	gc.fillRectangle(0, 0, 4, 4);
+	gc.setBackground(Colors.getColor(255, 255,255))
+	gc.setForeground(Colors.getColor(0, 0, 0))
+	
+	switch (patt) {
+	case "EVerticalHatchBrush":
+		gc.drawLine(1, 0, 1, 3); 
+		gc.drawLine(3, 0, 3, 3); 
+		break;
+	case "EForwardDiagonalHatchBrush":
+		gc.drawLine(0, 2, 2, 0); 
+		break;
+	case "EHorizontalHatchBrush":
+		gc.drawLine(0, 1, 3, 1);
+		gc.drawLine(0, 3, 3, 3);
+		break;
+	case "ERearwardDiagonalHatchBrush":
+		gc.drawLine(0, 0, 2, 2);
+		break;
+	case "ESquareCrossHatchBrush":
+		gc.drawLine(1, 0, 1, 3);
+		gc.drawLine(0, 1, 3, 1);
+		break;
+	case "EDiamondCrossHatchBrush":
+		gc.drawLine(0, 0, 3, 3); 
+		gc.drawLine(2, 0, 0, 2);
+		break;
+	case "ESolidBrush":
+	default:
+		// note: if all cases come here, it's because switch(string)
+		// only makes sense with actual string types.  
+		// If this function is part of a prototype that's wrapped
+		// into JS by UI Designer, then Rhino tends to coerce the arguments
+		// to Object.
+		
+		//println("default brush type: " +patt);
+		gc.setBackground(Colors.getColor(0, 0, 0))
+		gc.fillRectangle(0, 0, 5, 5); 
+		break;
+	}
+	
+	gc.dispose()
+	
+	try {
+		return new Pattern(graphics.getDevice(), img)
+	} catch (e) {
+		// not GDI+
+		return null;
+	}
+}
+
+function getPreferredSize(instance, laf, wHint, hHint, wrap) {
+	var properties = instance.properties;
+	var flags = 0;
+	
+	if (wrap)
+		flags |= Font.WRAPPING_ENABLED;
+	else
+		flags |= Font.WRAPPING_NONE;
+		
+	font = laf.getFont(properties.font);
+	switch (properties.alignment) {
+	case "EEikLabelAlignHCenter":
+		flags |= Font.ALIGN_CENTER; break;
+	case "EEikLabelAlignHLeft":
+		flags |= Font.ALIGN_LEFT; break;
+	case "EEikLabelAlignHRight":
+		flags |= Font.ALIGN_RIGHT; break;
+	}
+	
+	// get bounding rect
+	var layoutBounds = instance.getLayoutBounds();
+	width = layoutBounds.width;
+	height = layoutBounds.height;
+	// if either of these are empty, use the parent's bounds as starting point
+	if ((width == 0) || (height == 0)) {
+		layoutBounds = instance.parent.getLayoutBounds();
+		width = layoutBounds.width;
+		height = layoutBounds.height;
+	}
+	
+	if (wHint >= 0)
+		width = wHint;
+	if (hHint >= 0)
+		height = hHint;
+	var bounds = new Point(width, height);
+	
+	var text = chooseScalableText(properties.text.toString(), font, width);
+	if (text.length == 0)
+		text = " ";
+	return font.formattedStringExtent(text, bounds, flags, properties.pixelGapBetweenLines);
+}
+