uidesigner/com.nokia.sdt.series60.componentlibrary/components/navipane/NaviTabs_visual.js
author fturovic <frank.turovich@nokia.com>
Tue, 07 Apr 2009 13:55:47 -0500
branchRCL_2_0
changeset 69 cab50ba61335
parent 2 d760517a8095
permissions -rw-r--r--
added info on IAD custom rules
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
2
cawthron
parents:
diff changeset
     1
/*
cawthron
parents:
diff changeset
     2
* Copyright (c) 2006 Nokia Corporation and/or its subsidiary(-ies).
cawthron
parents:
diff changeset
     3
* All rights reserved.
cawthron
parents:
diff changeset
     4
* This component and the accompanying materials are made available
cawthron
parents:
diff changeset
     5
* under the terms of the License "Eclipse Public License v1.0"
cawthron
parents:
diff changeset
     6
* which accompanies this distribution, and is available
cawthron
parents:
diff changeset
     7
* at the URL "http://www.eclipse.org/legal/epl-v10.html".
cawthron
parents:
diff changeset
     8
*
cawthron
parents:
diff changeset
     9
* Initial Contributors:
cawthron
parents:
diff changeset
    10
* Nokia Corporation - initial contribution.
cawthron
parents:
diff changeset
    11
*
cawthron
parents:
diff changeset
    12
* Contributors:
cawthron
parents:
diff changeset
    13
*
cawthron
parents:
diff changeset
    14
* Description: 
cawthron
parents:
diff changeset
    15
*
cawthron
parents:
diff changeset
    16
*/
cawthron
parents:
diff changeset
    17
cawthron
parents:
diff changeset
    18
cawthron
parents:
diff changeset
    19
include("../containers/containerLibrary.js")
cawthron
parents:
diff changeset
    20
include("../renderLibrary.js")
cawthron
parents:
diff changeset
    21
include("../srcgenLibrary.js")
cawthron
parents:
diff changeset
    22
cawthron
parents:
diff changeset
    23
function NaviTabsVisual() {
cawthron
parents:
diff changeset
    24
}
cawthron
parents:
diff changeset
    25
cawthron
parents:
diff changeset
    26
function getNaviSize(instance, laf) {
cawthron
parents:
diff changeset
    27
	var properties = instance.properties;
cawthron
parents:
diff changeset
    28
	return new Point(properties.size.width, properties.size.height);
cawthron
parents:
diff changeset
    29
}
cawthron
parents:
diff changeset
    30
cawthron
parents:
diff changeset
    31
function isLongTabs(instance) {
cawthron
parents:
diff changeset
    32
	var property = instance.properties.tabWidth;
cawthron
parents:
diff changeset
    33
	return ((property == "EAknTabWidthWithTwoLongTabs") || 
cawthron
parents:
diff changeset
    34
		(property == "EAknTabWidthWithThreeLongTabs"));
cawthron
parents:
diff changeset
    35
}
cawthron
parents:
diff changeset
    36
cawthron
parents:
diff changeset
    37
function isOneTab(property) {
cawthron
parents:
diff changeset
    38
	return (property == "EAknTabWidthWithOneTab"); 
cawthron
parents:
diff changeset
    39
}
cawthron
parents:
diff changeset
    40
cawthron
parents:
diff changeset
    41
function getNumVisualTabs(property) {
cawthron
parents:
diff changeset
    42
	if ((property == "EAknTabWidthWithTwoTabs") ||
cawthron
parents:
diff changeset
    43
		(property == "EAknTabWidthWithTwoLongTabs"))
cawthron
parents:
diff changeset
    44
		return 2;
cawthron
parents:
diff changeset
    45
	else if ((property == "EAknTabWidthWithThreeTabs") ||
cawthron
parents:
diff changeset
    46
		(property == "EAknTabWidthWithThreeLongTabs"))
cawthron
parents:
diff changeset
    47
		return 3;
cawthron
parents:
diff changeset
    48
	else if (isOneTab(property))
cawthron
parents:
diff changeset
    49
		return 1;
cawthron
parents:
diff changeset
    50
		
cawthron
parents:
diff changeset
    51
	return 4;
cawthron
parents:
diff changeset
    52
}
cawthron
parents:
diff changeset
    53
cawthron
parents:
diff changeset
    54
function getHorizontalInset(laf) {
cawthron
parents:
diff changeset
    55
	return laf.getDimension("navi.indicator.size").x;
cawthron
parents:
diff changeset
    56
}
cawthron
parents:
diff changeset
    57
cawthron
parents:
diff changeset
    58
function getTabOffset(totalWidth, longTabs, numVisualTabs, laf) {
cawthron
parents:
diff changeset
    59
	if (longTabs)
cawthron
parents:
diff changeset
    60
		return totalWidth / 18;
cawthron
parents:
diff changeset
    61
	
cawthron
parents:
diff changeset
    62
	var width = totalWidth - (2 * getHorizontalInset(laf));
cawthron
parents:
diff changeset
    63
	return (width / numVisualTabs) - (2 * laf.getInteger("tab.corner", 3));
cawthron
parents:
diff changeset
    64
}
cawthron
parents:
diff changeset
    65
cawthron
parents:
diff changeset
    66
function getTabWidth(totalWidth, numVisualTabs, longTabs, laf) {
cawthron
parents:
diff changeset
    67
	var sideInset = getHorizontalInset(laf);
cawthron
parents:
diff changeset
    68
	return totalWidth - (2 * sideInset) - ((numVisualTabs - 1) * getTabOffset(totalWidth, longTabs, numVisualTabs, laf));
cawthron
parents:
diff changeset
    69
}
cawthron
parents:
diff changeset
    70
cawthron
parents:
diff changeset
    71
function getNumTabs(instance) {
cawthron
parents:
diff changeset
    72
	var appUi = instance.parent.parent;
cawthron
parents:
diff changeset
    73
	var numTabs = 0;
cawthron
parents:
diff changeset
    74
	for (var i in appUi.children) {
cawthron
parents:
diff changeset
    75
		if (appUi.children[i].isInstanceOf("com.nokia.sdt.series60.AvkonViewReference")) {
cawthron
parents:
diff changeset
    76
			if (appUi.children[i].properties.inTabGroup)
cawthron
parents:
diff changeset
    77
				numTabs++;
cawthron
parents:
diff changeset
    78
		}
cawthron
parents:
diff changeset
    79
	}
cawthron
parents:
diff changeset
    80
	
cawthron
parents:
diff changeset
    81
	return numTabs;
cawthron
parents:
diff changeset
    82
}
cawthron
parents:
diff changeset
    83
cawthron
parents:
diff changeset
    84
function drawTab(r, laf, graphics, isActive) {
cawthron
parents:
diff changeset
    85
	var offset = laf.getInteger("tab.corner", 3);
cawthron
parents:
diff changeset
    86
	
cawthron
parents:
diff changeset
    87
	var intArray = [	
cawthron
parents:
diff changeset
    88
					r.x,
cawthron
parents:
diff changeset
    89
					r.y + r.height,
cawthron
parents:
diff changeset
    90
					r.x + offset,
cawthron
parents:
diff changeset
    91
					r.y + r.height - offset,
cawthron
parents:
diff changeset
    92
					r.x + (4 * offset),
cawthron
parents:
diff changeset
    93
					r.y + offset, 
cawthron
parents:
diff changeset
    94
					r.x + (5 * offset),
cawthron
parents:
diff changeset
    95
					r.y,
cawthron
parents:
diff changeset
    96
					r.x + r.width - (5 * offset),
cawthron
parents:
diff changeset
    97
					r.y,
cawthron
parents:
diff changeset
    98
					r.x + r.width - (4 * offset),
cawthron
parents:
diff changeset
    99
					r.y + offset,
cawthron
parents:
diff changeset
   100
					r.x + r.width - offset,
cawthron
parents:
diff changeset
   101
					r.y + r.height - offset,
cawthron
parents:
diff changeset
   102
					r.x + r.width,
cawthron
parents:
diff changeset
   103
					r.y + r.height,
cawthron
parents:
diff changeset
   104
					];
cawthron
parents:
diff changeset
   105
cawthron
parents:
diff changeset
   106
	if (laf.getBoolean("is.landscape", false)) {
cawthron
parents:
diff changeset
   107
		for (var i = 0; i < intArray.length; i++) {
cawthron
parents:
diff changeset
   108
			if ((i % 2) != 0) {
cawthron
parents:
diff changeset
   109
				var yval = intArray[i];
cawthron
parents:
diff changeset
   110
				intArray[i] = r.height - yval;
cawthron
parents:
diff changeset
   111
			}
cawthron
parents:
diff changeset
   112
		}
cawthron
parents:
diff changeset
   113
	}
cawthron
parents:
diff changeset
   114
cawthron
parents:
diff changeset
   115
	var faceColor = isActive ? laf.getColor("navi.tab.face") : laf.getColor("navi.tab.back");
cawthron
parents:
diff changeset
   116
	graphics.setBackground(faceColor);
cawthron
parents:
diff changeset
   117
	graphics.fillPolygon(intArray);
cawthron
parents:
diff changeset
   118
	graphics.setForeground(laf.getColor("navi.tab.shade"));
cawthron
parents:
diff changeset
   119
	graphics.drawPolyline(intArray);
cawthron
parents:
diff changeset
   120
}
cawthron
parents:
diff changeset
   121
cawthron
parents:
diff changeset
   122
function getViewRefFromIndex(instance, index) {
cawthron
parents:
diff changeset
   123
	var appUiChildren = instance.parent.parent.children;
cawthron
parents:
diff changeset
   124
	var tabIndex = -1;
cawthron
parents:
diff changeset
   125
	for (var i in appUiChildren) {
cawthron
parents:
diff changeset
   126
		var child = appUiChildren[i];
cawthron
parents:
diff changeset
   127
		if ((child.componentId == "com.nokia.sdt.series60.AvkonViewReference") && child.properties.inTabGroup)
cawthron
parents:
diff changeset
   128
			tabIndex++;
cawthron
parents:
diff changeset
   129
		if (tabIndex == index)
cawthron
parents:
diff changeset
   130
			return child;
cawthron
parents:
diff changeset
   131
	}
cawthron
parents:
diff changeset
   132
	
cawthron
parents:
diff changeset
   133
	return null;
cawthron
parents:
diff changeset
   134
}
cawthron
parents:
diff changeset
   135
cawthron
parents:
diff changeset
   136
function getText(instance, index) {
cawthron
parents:
diff changeset
   137
	var viewRef = getViewRefFromIndex(instance, index);
cawthron
parents:
diff changeset
   138
	if (viewRef != null)
cawthron
parents:
diff changeset
   139
		return viewRef.properties.tabText;
cawthron
parents:
diff changeset
   140
	
cawthron
parents:
diff changeset
   141
	return "";
cawthron
parents:
diff changeset
   142
}
cawthron
parents:
diff changeset
   143
cawthron
parents:
diff changeset
   144
function hasTabText(instance, index) {
cawthron
parents:
diff changeset
   145
	return getText(instance, index).length > 0;
cawthron
parents:
diff changeset
   146
}
cawthron
parents:
diff changeset
   147
cawthron
parents:
diff changeset
   148
function drawText(instance, rect, font, graphics, index) {
cawthron
parents:
diff changeset
   149
	var text = getText(instance, index);
cawthron
parents:
diff changeset
   150
	text = chooseScalableText(text, font, rect.width);
cawthron
parents:
diff changeset
   151
	var extent = font.stringExtent(text);
cawthron
parents:
diff changeset
   152
	var newrect = new Rectangle(rect.x, (rect.height - extent.y) / 2, rect.width, rect.height)
cawthron
parents:
diff changeset
   153
	graphics.drawFormattedString(text, newrect, Font.ALIGN_CENTER | Font.ANTIALIAS_OFF | Font.OVERFLOW_ELLIPSIS, 0);
cawthron
parents:
diff changeset
   154
}
cawthron
parents:
diff changeset
   155
cawthron
parents:
diff changeset
   156
function hasTabImage(instance, index) {
cawthron
parents:
diff changeset
   157
	var viewRef = getViewRefFromIndex(instance, index);
cawthron
parents:
diff changeset
   158
	if (viewRef != null) {
cawthron
parents:
diff changeset
   159
		return isImagePropertySet(viewRef.properties.tabImage);
cawthron
parents:
diff changeset
   160
	}
cawthron
parents:
diff changeset
   161
		
cawthron
parents:
diff changeset
   162
	return false;
cawthron
parents:
diff changeset
   163
}
cawthron
parents:
diff changeset
   164
cawthron
parents:
diff changeset
   165
function getUnmaskedFillColor(isOneTab, isActiveMulti, laf) {
cawthron
parents:
diff changeset
   166
	if (isOneTab)
cawthron
parents:
diff changeset
   167
		return laf.getColor("navi.pane.text");
cawthron
parents:
diff changeset
   168
	else if (isActiveMulti)
cawthron
parents:
diff changeset
   169
		return laf.getColor("navi.tab.face")
cawthron
parents:
diff changeset
   170
	else
cawthron
parents:
diff changeset
   171
		return laf.getColor("navi.tab.backText");
cawthron
parents:
diff changeset
   172
}
cawthron
parents:
diff changeset
   173
cawthron
parents:
diff changeset
   174
function renderTabImage(viewRef, isOneTab, isActiveMulti, laf, graphics, rect, color) {
cawthron
parents:
diff changeset
   175
cawthron
parents:
diff changeset
   176
	var imagePropertyRendering = createImagePropertyRendering();
cawthron
parents:
diff changeset
   177
	imagePropertyRendering.setImageProperty(viewRef, "tabImage", laf);
cawthron
parents:
diff changeset
   178
cawthron
parents:
diff changeset
   179
	var imageProperty = viewRef.properties.tabImage.editableValue;
cawthron
parents:
diff changeset
   180
	
cawthron
parents:
diff changeset
   181
	// Different behavior for masked and unmasked images, in terms of the size
cawthron
parents:
diff changeset
   182
	// of renderable area, the way the bitmap and mask are treated, etc.
cawthron
parents:
diff changeset
   183
	 
cawthron
parents:
diff changeset
   184
	if (imageProperty.isMasked()) {
cawthron
parents:
diff changeset
   185
		// set the color used for monochrome rendering
cawthron
parents:
diff changeset
   186
		graphics.setForeground(color);
cawthron
parents:
diff changeset
   187
	} 
cawthron
parents:
diff changeset
   188
	else {
cawthron
parents:
diff changeset
   189
		graphics.setBackground(getUnmaskedFillColor(isOneTab, isActiveMulti, laf));
cawthron
parents:
diff changeset
   190
		var fillRect = new Rectangle(rect.x, rect.y, rect.width, rect.height);
cawthron
parents:
diff changeset
   191
		var hShrink = 0;
cawthron
parents:
diff changeset
   192
		if (isOneTab)
cawthron
parents:
diff changeset
   193
			hShrink = rect.width / 3;
cawthron
parents:
diff changeset
   194
		else
cawthron
parents:
diff changeset
   195
			hShrink = 4 * laf.getInteger("tab.corner", 3);
cawthron
parents:
diff changeset
   196
		shrinkRect(fillRect, hShrink, 0);
cawthron
parents:
diff changeset
   197
		graphics.fillRectangle(fillRect.x, fillRect.y, fillRect.width, fillRect.height);
cawthron
parents:
diff changeset
   198
	}
cawthron
parents:
diff changeset
   199
cawthron
parents:
diff changeset
   200
	imagePropertyRendering.setViewableSize(new Point(rect.width, rect.height));
cawthron
parents:
diff changeset
   201
	imagePropertyRendering.setAlignmentWeights(new Point(ImageUtils.ALIGN_CENTER, ImageUtils.ALIGN_CENTER_OR_TOP));
cawthron
parents:
diff changeset
   202
	imagePropertyRendering.setScaling(isScalingIcons());
cawthron
parents:
diff changeset
   203
	imagePropertyRendering.setPreservingAspectRatio(true);
cawthron
parents:
diff changeset
   204
	
cawthron
parents:
diff changeset
   205
	imagePropertyRendering.setTransparencyHandling(imagePropertyRendering.TRANSPARENCY_FLATTEN);
cawthron
parents:
diff changeset
   206
	
cawthron
parents:
diff changeset
   207
	// use this model in S60ImagePropertyRendering to handle the weird (mis-)use of
cawthron
parents:
diff changeset
   208
	// bitmap and mask in the navi pane
cawthron
parents:
diff changeset
   209
	imagePropertyRendering.setRenderingModel(imagePropertyRendering.MODEL_NAVI_PANE_TABS);
cawthron
parents:
diff changeset
   210
cawthron
parents:
diff changeset
   211
	imagePropertyRendering.render(graphics.getWrappedGC(), rect.x, rect.y);
cawthron
parents:
diff changeset
   212
cawthron
parents:
diff changeset
   213
}
cawthron
parents:
diff changeset
   214
cawthron
parents:
diff changeset
   215
function shrinkRect(rect, h, v) {
cawthron
parents:
diff changeset
   216
	rect.x += h; 
cawthron
parents:
diff changeset
   217
	rect.width -= (2 * h);
cawthron
parents:
diff changeset
   218
	rect.y += v; 
cawthron
parents:
diff changeset
   219
	rect.height -= (2 * v);
cawthron
parents:
diff changeset
   220
}
cawthron
parents:
diff changeset
   221
cawthron
parents:
diff changeset
   222
function drawTabImage(isOneTab, isActiveMulti, rect, instance, laf, graphics, index) {
cawthron
parents:
diff changeset
   223
	var viewRef = getViewRefFromIndex(instance, index);
cawthron
parents:
diff changeset
   224
	var color = getTextColor(isOneTab, isActiveMulti, laf);
cawthron
parents:
diff changeset
   225
	var shrinkage = laf.getInteger("tab.corner", 3);
cawthron
parents:
diff changeset
   226
	var drawRect = new Rectangle(rect.x, rect.y, rect.width, rect.height);
cawthron
parents:
diff changeset
   227
	shrinkRect(drawRect, shrinkage, shrinkage);
cawthron
parents:
diff changeset
   228
	renderTabImage(viewRef, isOneTab, isActiveMulti, laf, graphics, drawRect, color);
cawthron
parents:
diff changeset
   229
}
cawthron
parents:
diff changeset
   230
cawthron
parents:
diff changeset
   231
function drawOneTabContents(instance, rect, font, laf, graphics, index) {
cawthron
parents:
diff changeset
   232
	var hasImage = hasTabImage(instance, index);
cawthron
parents:
diff changeset
   233
	var hasText = hasTabText(instance, index);
cawthron
parents:
diff changeset
   234
/*	
cawthron
parents:
diff changeset
   235
NOT TRYING TO RENDER IMAGE AND TEXT, BECAUSE EXCEPT FOR VERY FEW CASES, IT LOOKS HOORIBLE ON THE EMULATOR!
cawthron
parents:
diff changeset
   236
	if (hasImage && hasText) {
cawthron
parents:
diff changeset
   237
		var imageRect = new Rectangle(rect.x, rect.y, rect.width / 2, rect.height);
cawthron
parents:
diff changeset
   238
		drawTabImage(true, false, imageRect, instance, laf, graphics, index);
cawthron
parents:
diff changeset
   239
		var text = getText(instance, index);
cawthron
parents:
diff changeset
   240
		var textRect = new Rectangle(rect.x + (rect.width / 2), rect.y, rect.width / 2, rect.height);
cawthron
parents:
diff changeset
   241
		drawText(instance, textRect, font, graphics, index);
cawthron
parents:
diff changeset
   242
	}
cawthron
parents:
diff changeset
   243
*/	
cawthron
parents:
diff changeset
   244
	if (hasText) {
cawthron
parents:
diff changeset
   245
		var text = getText(instance, index);
cawthron
parents:
diff changeset
   246
		drawText(instance, rect, font, graphics, index);
cawthron
parents:
diff changeset
   247
	}
cawthron
parents:
diff changeset
   248
	else if (hasImage) {
cawthron
parents:
diff changeset
   249
		drawTabImage(true, false, rect, instance, laf, graphics, index);
cawthron
parents:
diff changeset
   250
	}
cawthron
parents:
diff changeset
   251
}
cawthron
parents:
diff changeset
   252
cawthron
parents:
diff changeset
   253
function drawOneTab(instance, rect, laf, graphics, index) {
cawthron
parents:
diff changeset
   254
	var color = getTextColor(true, false, laf);
cawthron
parents:
diff changeset
   255
		
cawthron
parents:
diff changeset
   256
	var font = laf.getFont("navi.text.font");
cawthron
parents:
diff changeset
   257
	graphics.setFont(font);
cawthron
parents:
diff changeset
   258
	graphics.setForeground(color);
cawthron
parents:
diff changeset
   259
cawthron
parents:
diff changeset
   260
	drawOneTabContents(instance, rect, font, laf, graphics, index);
cawthron
parents:
diff changeset
   261
}
cawthron
parents:
diff changeset
   262
cawthron
parents:
diff changeset
   263
function getTextColor(isOneTab, isActiveMulti, laf) {
cawthron
parents:
diff changeset
   264
	if (isOneTab)
cawthron
parents:
diff changeset
   265
		return laf.getColor("navi.pane.text");
cawthron
parents:
diff changeset
   266
	else if (isActiveMulti)
cawthron
parents:
diff changeset
   267
		return laf.getColor("navi.tab.text")
cawthron
parents:
diff changeset
   268
	else
cawthron
parents:
diff changeset
   269
		return laf.getColor("navi.tab.backText");
cawthron
parents:
diff changeset
   270
}
cawthron
parents:
diff changeset
   271
cawthron
parents:
diff changeset
   272
function drawTabText(instance, rect, laf, graphics, isActive, index) {
cawthron
parents:
diff changeset
   273
	var color = getTextColor(false, isActive, laf);
cawthron
parents:
diff changeset
   274
	var font = laf.getFont("navi.tab.font");
cawthron
parents:
diff changeset
   275
	graphics.setFont(font);
cawthron
parents:
diff changeset
   276
	graphics.setForeground(color);
cawthron
parents:
diff changeset
   277
	
cawthron
parents:
diff changeset
   278
	drawText(instance, rect, font, graphics, index);
cawthron
parents:
diff changeset
   279
}
cawthron
parents:
diff changeset
   280
cawthron
parents:
diff changeset
   281
function drawTabContents(instance, rect, laf, graphics, isActive, index) {
cawthron
parents:
diff changeset
   282
	var hasImage = hasTabImage(instance, index);
cawthron
parents:
diff changeset
   283
	var hasText = hasTabText(instance, index);
cawthron
parents:
diff changeset
   284
/*	
cawthron
parents:
diff changeset
   285
NOT TRYING TO RENDER IMAGE AND TEXT, BECAUSE EXCEPT FOR VERY FEW CASES, IT LOOKS HOORIBLE ON THE EMULATOR!
cawthron
parents:
diff changeset
   286
	if (hasImage && hasText) {
cawthron
parents:
diff changeset
   287
		var text = getText(instance, index);
cawthron
parents:
diff changeset
   288
		var textRect = new Rectangle(rect.x, rect.y, rect.width / 2, rect.height);new Rectangle(rect.x, rect.y, rect.width / 2, rect.height);
cawthron
parents:
diff changeset
   289
		drawTabText(instance, textRect, laf, graphics, isActive, index);
cawthron
parents:
diff changeset
   290
		var imageRect = new Rectangle(rect.x + (rect.width / 2), rect.y, rect.width / 2, rect.height);
cawthron
parents:
diff changeset
   291
		drawTabImage(false, isActive, imageRect, instance, laf, graphics, index);
cawthron
parents:
diff changeset
   292
	}
cawthron
parents:
diff changeset
   293
*/
cawthron
parents:
diff changeset
   294
	if (hasText) {
cawthron
parents:
diff changeset
   295
		var text = getText(instance, index);
cawthron
parents:
diff changeset
   296
		drawTabText(instance, rect, laf, graphics, isActive, index);
cawthron
parents:
diff changeset
   297
	}
cawthron
parents:
diff changeset
   298
	else if (hasImage) {
cawthron
parents:
diff changeset
   299
		drawTabImage(false, isActive, rect, instance, laf, graphics, index);
cawthron
parents:
diff changeset
   300
	}
cawthron
parents:
diff changeset
   301
}
cawthron
parents:
diff changeset
   302
cawthron
parents:
diff changeset
   303
function drawMultipleTabs(instance, rect, laf, graphics, active) {
cawthron
parents:
diff changeset
   304
	var numVisualTabs = getNumVisualTabs(instance.properties.tabWidth);
cawthron
parents:
diff changeset
   305
	var longTabs = isLongTabs(instance);
cawthron
parents:
diff changeset
   306
	var hInset = getHorizontalInset(laf);
cawthron
parents:
diff changeset
   307
	var tabOffset = getTabOffset(rect.width, longTabs, numVisualTabs, laf);
cawthron
parents:
diff changeset
   308
	var tabWidth = getTabWidth(rect.width, numVisualTabs, longTabs, laf);
cawthron
parents:
diff changeset
   309
	
cawthron
parents:
diff changeset
   310
	var firstTab = 0;
cawthron
parents:
diff changeset
   311
	var numTabs = getNumTabs(instance);
cawthron
parents:
diff changeset
   312
	if (active >= numVisualTabs)
cawthron
parents:
diff changeset
   313
		firstTab = active;
cawthron
parents:
diff changeset
   314
	if (firstTab + numVisualTabs >= numTabs)
cawthron
parents:
diff changeset
   315
		firstTab = numTabs - numVisualTabs;
cawthron
parents:
diff changeset
   316
	if (firstTab < 0)
cawthron
parents:
diff changeset
   317
		firstTab = 0;
cawthron
parents:
diff changeset
   318
	
cawthron
parents:
diff changeset
   319
	// first draw the inactive tabs
cawthron
parents:
diff changeset
   320
	for (var i = firstTab + numVisualTabs - 1; i > active; i--) {
cawthron
parents:
diff changeset
   321
		var left = rect.x + hInset + ((i - firstTab) * tabOffset);
cawthron
parents:
diff changeset
   322
		var drawRect = new Rectangle(left, rect.y, tabWidth, rect.height);
cawthron
parents:
diff changeset
   323
		drawTab(drawRect, laf, graphics, false);
cawthron
parents:
diff changeset
   324
		if (!longTabs) {
cawthron
parents:
diff changeset
   325
			drawTabContents(instance, drawRect, laf, graphics, false, i);
cawthron
parents:
diff changeset
   326
		}
cawthron
parents:
diff changeset
   327
	}
cawthron
parents:
diff changeset
   328
	for (var i = firstTab; i < active; i++) {
cawthron
parents:
diff changeset
   329
		var left = rect.x + hInset + ((i - firstTab) * tabOffset);
cawthron
parents:
diff changeset
   330
		var drawRect = new Rectangle(left, rect.y, tabWidth, rect.height);
cawthron
parents:
diff changeset
   331
		drawTab(drawRect, laf, graphics, false);
cawthron
parents:
diff changeset
   332
		if (!longTabs) {
cawthron
parents:
diff changeset
   333
			drawTabContents(instance, drawRect, laf, graphics, false, i);
cawthron
parents:
diff changeset
   334
		}
cawthron
parents:
diff changeset
   335
	}
cawthron
parents:
diff changeset
   336
	
cawthron
parents:
diff changeset
   337
	// then draw the active tab
cawthron
parents:
diff changeset
   338
	{
cawthron
parents:
diff changeset
   339
		var left = rect.x + hInset + ((active - firstTab) * tabOffset);
cawthron
parents:
diff changeset
   340
		var drawRect = new Rectangle(left, rect.y, tabWidth, rect.height);
cawthron
parents:
diff changeset
   341
		drawTab(drawRect, laf, graphics, true);
cawthron
parents:
diff changeset
   342
		drawTabContents(instance, drawRect, laf, graphics, true, active);
cawthron
parents:
diff changeset
   343
	}
cawthron
parents:
diff changeset
   344
}
cawthron
parents:
diff changeset
   345
cawthron
parents:
diff changeset
   346
function drawArrow(onRight, rect, laf, graphics) {
cawthron
parents:
diff changeset
   347
	var arrowHeight = rect.height / 3;
cawthron
parents:
diff changeset
   348
	graphics.setForeground(laf.getColor("navi.tab.arrow"));
cawthron
parents:
diff changeset
   349
	var arrowTop = (rect.height - arrowHeight) / 2;
cawthron
parents:
diff changeset
   350
	var hInset = getHorizontalInset(laf);
cawthron
parents:
diff changeset
   351
	var arrowWidth = ((arrowHeight % 2) == 0) ? arrowHeight / 2 + 1 : arrowHeight / 2;
cawthron
parents:
diff changeset
   352
	
cawthron
parents:
diff changeset
   353
	for (var i = 0; i < arrowWidth; i++) {
cawthron
parents:
diff changeset
   354
		var x;
cawthron
parents:
diff changeset
   355
		if (onRight)
cawthron
parents:
diff changeset
   356
			x = rect.x + rect.width - hInset + i;
cawthron
parents:
diff changeset
   357
		else
cawthron
parents:
diff changeset
   358
			x = rect.x + hInset - i;
cawthron
parents:
diff changeset
   359
		var y0 = arrowTop + i;
cawthron
parents:
diff changeset
   360
		var y1 = arrowTop + arrowHeight - i;
cawthron
parents:
diff changeset
   361
		graphics.drawLine(x, y0, x, y1);
cawthron
parents:
diff changeset
   362
	}
cawthron
parents:
diff changeset
   363
}
cawthron
parents:
diff changeset
   364
cawthron
parents:
diff changeset
   365
NaviTabsVisual.prototype.draw = function(instance, laf, graphics) {
cawthron
parents:
diff changeset
   366
	var properties = instance.properties;
cawthron
parents:
diff changeset
   367
	var active = instance.properties.active;
cawthron
parents:
diff changeset
   368
	var numTabs = getNumTabs(instance);
cawthron
parents:
diff changeset
   369
	
cawthron
parents:
diff changeset
   370
	if (active > (numTabs - 1))
cawthron
parents:
diff changeset
   371
		active = numTabs - 1;
cawthron
parents:
diff changeset
   372
cawthron
parents:
diff changeset
   373
	if (active < 0)
cawthron
parents:
diff changeset
   374
		active = 0;
cawthron
parents:
diff changeset
   375
		
cawthron
parents:
diff changeset
   376
	var size = getNaviSize(instance, laf);
cawthron
parents:
diff changeset
   377
	var rect = new Rectangle(0, 0, size.x, size.y);
cawthron
parents:
diff changeset
   378
	if (!isOneTab(properties.tabWidth)) {
cawthron
parents:
diff changeset
   379
		drawMultipleTabs(instance, rect, laf, graphics, active);
cawthron
parents:
diff changeset
   380
	}
cawthron
parents:
diff changeset
   381
	else {
cawthron
parents:
diff changeset
   382
		drawOneTab(instance, rect, laf, graphics, active);
cawthron
parents:
diff changeset
   383
	}
cawthron
parents:
diff changeset
   384
cawthron
parents:
diff changeset
   385
	if (active > 0)
cawthron
parents:
diff changeset
   386
		drawArrow(false, rect, laf, graphics);
cawthron
parents:
diff changeset
   387
	
cawthron
parents:
diff changeset
   388
	if (active < (numTabs - 1))
cawthron
parents:
diff changeset
   389
		drawArrow(true, rect, laf, graphics);
cawthron
parents:
diff changeset
   390
}
cawthron
parents:
diff changeset
   391
cawthron
parents:
diff changeset
   392
NaviTabsVisual.prototype.getPreferredSize = function(instance, laf, wHint, hHint) {
cawthron
parents:
diff changeset
   393
	return null; // needs implementation	
cawthron
parents:
diff changeset
   394
}
cawthron
parents:
diff changeset
   395