All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.eclipse.swt.widgets.Canvas Maven / Gradle / Ivy

Go to download

The osx x86_64 swt jar as available in the Eclipse 4.6 (Neon) release for OSX. It is suitable for use with jface and other dependencies available from maven central in the org.eclipse.scout.sdk.deps group. The sources is copied from swt-4.6-cocoa-macosx-x86_64.zip from http://download.eclipse.org/eclipse/downloads/drops4/R-4.6-201606061100/ and javadoc is generated from sources.

The newest version!
/*******************************************************************************
 * Copyright (c) 2000, 2012 IBM Corporation and others.
 * All rights reserved. This program and the accompanying materials
 * are made available under the terms of the Eclipse Public License v1.0
 * which accompanies this distribution, and is available at
 * http://www.eclipse.org/legal/epl-v10.html
 *
 * Contributors:
 *     IBM Corporation - initial API and implementation
 *******************************************************************************/
package org.eclipse.swt.widgets;


import org.eclipse.swt.*;
import org.eclipse.swt.accessibility.*;
import org.eclipse.swt.graphics.*;
import org.eclipse.swt.internal.cocoa.*;

/**
 * Instances of this class provide a surface for drawing
 * arbitrary graphics.
 * 
*
Styles:
*
(none)
*
Events:
*
(none)
*
*

* This class may be subclassed by custom control implementors * who are building controls that are not constructed * from aggregates of other controls. That is, they are either * painted using SWT graphics calls or are handled by native * methods. *

* * @see Composite * @see Canvas snippets * @see SWT Example: ControlExample * @see Sample code and further information */ public class Canvas extends Composite { Caret caret; IME ime; NSOpenGLContext glcontext; NSBezierPath visiblePath; static NSMutableArray supportedPboardTypes; static { // This array is leaked. supportedPboardTypes = NSMutableArray.arrayWithCapacity(1); supportedPboardTypes.retain(); supportedPboardTypes.addObject(OS.NSStringPboardType); //supportedPboardTypes.addObject(OS.NSRTFPboardType); }; Canvas () { /* Do nothing */ } @Override long /*int*/ attributedSubstringFromRange (long /*int*/ id, long /*int*/ sel, long /*int*/ range) { if (ime != null) return ime.attributedSubstringFromRange (id, sel, range); return super.attributedSubstringFromRange(id, sel, range); } @Override void sendFocusEvent(int type) { if (caret != null) { if (type == SWT.FocusIn) { caret.setFocus(); } else { caret.killFocus(); } } super.sendFocusEvent(type); } /** * Constructs a new instance of this class given its parent * and a style value describing its behavior and appearance. *

* The style value is either one of the style constants defined in * class SWT which is applicable to instances of this * class, or must be built by bitwise OR'ing together * (that is, using the int "|" operator) two or more * of those SWT style constants. The class description * lists the style constants that are applicable to the class. * Style bits are also inherited from superclasses. *

* * @param parent a composite control which will be the parent of the new instance (cannot be null) * @param style the style of control to construct * * @exception IllegalArgumentException
    *
  • ERROR_NULL_ARGUMENT - if the parent is null
  • *
* @exception SWTException
    *
  • ERROR_THREAD_INVALID_ACCESS - if not called from the thread that created the parent
  • *
* * @see SWT * @see Widget#getStyle */ public Canvas (Composite parent, int style) { super (parent, style); } @Override long /*int*/ characterIndexForPoint (long /*int*/ id, long /*int*/ sel, long /*int*/ point) { if (ime != null) return ime.characterIndexForPoint (id, sel, point); return super.characterIndexForPoint (id, sel, point); } /** * Fills the interior of the rectangle specified by the arguments, * with the receiver's background. * * @param gc the gc where the rectangle is to be filled * @param x the x coordinate of the rectangle to be filled * @param y the y coordinate of the rectangle to be filled * @param width the width of the rectangle to be filled * @param height the height of the rectangle to be filled * * @exception IllegalArgumentException
    *
  • ERROR_NULL_ARGUMENT - if the gc is null
  • *
  • ERROR_INVALID_ARGUMENT - if the gc has been disposed
  • *
* @exception SWTException
    *
  • ERROR_WIDGET_DISPOSED - if the receiver has been disposed
  • *
  • ERROR_THREAD_INVALID_ACCESS - if not called from the thread that created the receiver
  • *
* * @since 3.2 */ public void drawBackground (GC gc, int x, int y, int width, int height) { drawBackground(gc, x, y, width, height, 0, 0); } @Override void drawBackground (long /*int*/ id, NSGraphicsContext context, NSRect rect) { super.drawBackground(id, context, rect); if (glcontext != null) { if (isObscured()) { glcontext.setValues(new int[]{-1}, OS.NSOpenGLCPSurfaceOrder); context.saveGraphicsState(); context.setCompositingOperation(OS.NSCompositeClear); if (visiblePath == null) { long /*int*/ visibleRegion = getVisibleRegion(); visiblePath = getPath(visibleRegion); OS.DisposeRgn(visibleRegion); } visiblePath.addClip(); NSBezierPath.fillRect(rect); context.restoreGraphicsState(); } else { glcontext.setValues(new int[]{1}, OS.NSOpenGLCPSurfaceOrder); } } } @Override void drawRect (long /*int*/ id, long /*int*/ sel, NSRect rect) { if (glcontext != null && glcontext.view() == null) glcontext.setView(view); super.drawRect(id, sel, rect); } @Override void drawWidget (long /*int*/ id, NSGraphicsContext context, NSRect rect) { if (id != view.id) return; super.drawWidget (id, context, rect); if (caret == null) return; if (caret.isShowing) { long /*int*/ ctx = context.graphicsPort(); OS.CGContextSaveGState (ctx); OS.CGContextSetBlendMode (ctx, OS.kCGBlendModeDifference); Image image = caret.image; if (image != null) { NSImage imageHandle = image.handle; NSImageRep imageRep = imageHandle.bestRepresentationForDevice(null); if (!imageRep.isKindOfClass(OS.class_NSBitmapImageRep)) return; NSBitmapImageRep rep = new NSBitmapImageRep(imageRep); CGRect destRect = new CGRect (); destRect.origin.x = caret.x; destRect.origin.y = caret.y; NSSize size = imageHandle.size(); destRect.size.width = size.width; destRect.size.height = size.height; long /*int*/ data = rep.bitmapData(); long /*int*/ format = rep.bitmapFormat(); long /*int*/ bpr = rep.bytesPerRow(); int alphaInfo; if (rep.hasAlpha()) { alphaInfo = (format & OS.NSAlphaFirstBitmapFormat) != 0 ? OS.kCGImageAlphaFirst : OS.kCGImageAlphaLast; } else { alphaInfo = (format & OS.NSAlphaFirstBitmapFormat) != 0 ? OS.kCGImageAlphaNoneSkipFirst : OS.kCGImageAlphaNoneSkipLast; } long /*int*/ provider = OS.CGDataProviderCreateWithData(0, data, bpr * (int)size.height, 0); long /*int*/ colorspace = OS.CGColorSpaceCreateDeviceRGB(); long /*int*/ cgImage = OS.CGImageCreate((int)size.width, (int)size.height, rep.bitsPerSample(), rep.bitsPerPixel(), bpr, colorspace, alphaInfo, provider, 0, true, 0); OS.CGColorSpaceRelease(colorspace); OS.CGDataProviderRelease(provider); OS.CGContextScaleCTM (ctx, 1, -1); OS.CGContextTranslateCTM (ctx, 0, -(size.height + 2 * destRect.origin.y)); OS.CGContextSetBlendMode (ctx, OS.kCGBlendModeDifference); OS.CGContextDrawImage (ctx, destRect, cgImage); OS.CGImageRelease(cgImage); } else { CGRect drawRect = new CGRect(); drawRect.origin.x = caret.x; drawRect.origin.y = caret.y; drawRect.size.width = caret.width != 0 ? caret.width : Caret.DEFAULT_WIDTH; drawRect.size.height = caret.height; long /*int*/ colorspace = OS.CGColorSpaceCreateDeviceRGB(); OS.CGContextSetFillColorSpace(ctx, colorspace); OS.CGColorSpaceRelease(colorspace); OS.CGContextSetFillColor(ctx, new double /*float*/ [] {1, 1, 1, 1}); OS.CGContextFillRect(ctx, drawRect); } OS.CGContextRestoreGState(ctx); } } @Override NSRect firstRectForCharacterRange (long /*int*/ id, long /*int*/ sel, long /*int*/ range) { if (ime != null) return ime.firstRectForCharacterRange (id, sel, range); return super.firstRectForCharacterRange (id, sel, range); } /** * Returns the caret. *

* The caret for the control is automatically hidden * and shown when the control is painted or resized, * when focus is gained or lost and when an the control * is scrolled. To avoid drawing on top of the caret, * the programmer must hide and show the caret when * drawing in the window any other time. *

* * @return the caret for the receiver, may be null * * @exception SWTException
    *
  • ERROR_WIDGET_DISPOSED - if the receiver has been disposed
  • *
  • ERROR_THREAD_INVALID_ACCESS - if not called from the thread that created the receiver
  • *
*/ public Caret getCaret () { checkWidget(); return caret; } /** * Returns the IME. * * @return the IME * * @exception SWTException
    *
  • ERROR_WIDGET_DISPOSED - if the receiver has been disposed
  • *
  • ERROR_THREAD_INVALID_ACCESS - if not called from the thread that created the receiver
  • *
* * @since 3.4 */ public IME getIME () { checkWidget(); return ime; } @Override boolean hasMarkedText (long /*int*/ id, long /*int*/ sel) { if (ime != null) return ime.hasMarkedText (id, sel); return super.hasMarkedText (id, sel); } @Override boolean imeInComposition () { return ime != null && ime.isInlineEnabled () && ime.startOffset != -1; } @Override boolean insertText (long /*int*/ id, long /*int*/ sel, long /*int*/ string) { if (ime != null) { if (!ime.insertText (id, sel, string)) return false; } return super.insertText (id, sel, string); } @Override boolean isOpaque (long /*int*/ id, long /*int*/ sel) { if (glcontext != null) return true; return super.isOpaque(id, sel); } @Override NSRange markedRange (long /*int*/ id, long /*int*/ sel) { if (ime != null) return ime.markedRange (id, sel); return super.markedRange (id, sel); } @Override boolean readSelectionFromPasteboard(long /*int*/ id, long /*int*/ sel, long /*int*/ pasteboard) { boolean result = false; NSPasteboard pboard = new NSPasteboard(pasteboard); NSArray availableTypes = pboard.types(); NSString type; for (long /*int*/ i = 0; i < supportedPboardTypes.count(); i++) { if (result) break; type = new NSString(supportedPboardTypes.objectAtIndex(i)); if (availableTypes.containsObject(type)) { result = readSelectionFromPasteboard(pboard, type); } } return result; } boolean readSelectionFromPasteboard(NSPasteboard pboard, NSString type) { boolean result = false; NSString newSelection = null; if (type.isEqualToString(OS.NSStringPboardType)) { NSString string = pboard.stringForType(OS.NSStringPboardType); if (string != null && string.length() > 0) { newSelection = string; } } if (newSelection != null) { Accessible acc = getAccessible(); acc.internal_accessibilitySetValue_forAttribute(newSelection, OS.NSAccessibilitySelectedTextAttribute, ACC.CHILDID_SELF); result = true; } return result; } @Override void releaseChildren (boolean destroy) { if (caret != null) { caret.release (false); caret = null; } if (ime != null) { ime.release (false); ime = null; } super.releaseChildren (destroy); } @Override void reskinChildren (int flags) { if (caret != null) caret.reskin (flags); if (ime != null) ime.reskin (flags); super.reskinChildren (flags); } @Override void releaseWidget () { super.releaseWidget(); if (visiblePath != null) visiblePath.release(); visiblePath = null; } @Override void resetVisibleRegion () { super.resetVisibleRegion (); if (visiblePath != null) visiblePath.release(); visiblePath = null; } /** * Scrolls a rectangular area of the receiver by first copying * the source area to the destination and then causing the area * of the source which is not covered by the destination to * be repainted. Children that intersect the rectangle are * optionally moved during the operation. In addition, all outstanding * paint events are flushed before the source area is copied to * ensure that the contents of the canvas are drawn correctly. * * @param destX the x coordinate of the destination * @param destY the y coordinate of the destination * @param x the x coordinate of the source * @param y the y coordinate of the source * @param width the width of the area * @param height the height of the area * @param all trueif children should be scrolled, and false otherwise * * @exception SWTException
    *
  • ERROR_WIDGET_DISPOSED - if the receiver has been disposed
  • *
  • ERROR_THREAD_INVALID_ACCESS - if not called from the thread that created the receiver
  • *
*/ public void scroll (int destX, int destY, int x, int y, int width, int height, boolean all) { checkWidget(); if (width <= 0 || height <= 0) return; int deltaX = destX - x, deltaY = destY - y; if (deltaX == 0 && deltaY == 0) return; if (!isDrawing ()) return; NSRect visibleRect = view.visibleRect(); if (visibleRect.width <= 0 || visibleRect.height <= 0) return; boolean isFocus = caret != null && caret.isFocusCaret (); if (isFocus) caret.killFocus (); Rectangle clientRect = getClientArea (); Rectangle sourceRect = new Rectangle (x, y, width, height); if (sourceRect.intersects (clientRect)) { getShell().setScrolling(); update (all); } Control control = findBackgroundControl (); boolean redraw = control != null && control.backgroundImage != null; if (!redraw) redraw = hasRegion (); if (!redraw) redraw = isObscured (); if (redraw) { redrawWidget (view, x, y, width, height, false); redrawWidget (view, destX, destY, width, height, false); } else { NSRect damage = new NSRect(); damage.x = x; damage.y = y; damage.width = width; damage.height = height; NSPoint dest = new NSPoint(); dest.x = destX; dest.y = destY; view.lockFocus(); OS.NSCopyBits(0, damage , dest); view.unlockFocus(); boolean disjoint = (destX + width < x) || (x + width < destX) || (destY + height < y) || (y + height < destY); if (disjoint) { view.setNeedsDisplayInRect(damage); } else { if (deltaX != 0) { int newX = destX - deltaX; if (deltaX < 0) newX = destX + width; damage.x = newX; damage.width = Math.abs(deltaX); view.setNeedsDisplayInRect(damage); } if (deltaY != 0) { int newY = destY - deltaY; if (deltaY < 0) newY = destY + height; damage.x = x; damage.y = newY; damage.width = width; damage.height = Math.abs (deltaY); view.setNeedsDisplayInRect(damage); } } NSRect srcRect = new NSRect(); srcRect.x = sourceRect.x; srcRect.y = sourceRect.y; srcRect.width = sourceRect.width; srcRect.height = sourceRect.height; OS.NSIntersectionRect(visibleRect, visibleRect, srcRect); if (!OS.NSEqualRects(visibleRect, srcRect)) { if (srcRect.x != visibleRect.x) { damage.x = srcRect.x + deltaX; damage.y = srcRect.y + deltaY; damage.width = visibleRect.x - srcRect.x; damage.height = srcRect.height; view.setNeedsDisplayInRect(damage); } if (visibleRect.x + visibleRect.width != srcRect.x + srcRect.width) { damage.x = srcRect.x + visibleRect.width + deltaX; damage.y = srcRect.y + deltaY; damage.width = srcRect.width - visibleRect.width; damage.height = srcRect.height; view.setNeedsDisplayInRect(damage); } if (visibleRect.y != srcRect.y) { damage.x = visibleRect.x + deltaX; damage.y = srcRect.y + deltaY; damage.width = visibleRect.width; damage.height = visibleRect.y - srcRect.y; view.setNeedsDisplayInRect(damage); } if (visibleRect.y + visibleRect.height != srcRect.y + srcRect.height) { damage.x = visibleRect.x + deltaX; damage.y = visibleRect.y + visibleRect.height + deltaY; damage.width = visibleRect.width; damage.height = srcRect.y + srcRect.height - (visibleRect.y + visibleRect.height); view.setNeedsDisplayInRect(damage); } } } if (all) { Control [] children = _getChildren (); for (int i=0; i= Math.max (x, rect.x) && Math.min(y + height, rect.y + rect.height) >= Math.max (y, rect.y)) { child.setLocation (rect.x + deltaX, rect.y + deltaY); } } } if (isFocus) caret.setFocus (); } @Override NSRange selectedRange (long /*int*/ id, long /*int*/ sel) { if (ime != null) return ime.selectedRange (id, sel); return super.selectedRange (id, sel); } @Override boolean sendKeyEvent (NSEvent nsEvent, int type) { if (caret != null) NSCursor.setHiddenUntilMouseMoves (true); return super.sendKeyEvent (nsEvent, type); } /** * Sets the receiver's caret. *

* The caret for the control is automatically hidden * and shown when the control is painted or resized, * when focus is gained or lost and when an the control * is scrolled. To avoid drawing on top of the caret, * the programmer must hide and show the caret when * drawing in the window any other time. *

* @param caret the new caret for the receiver, may be null * * @exception IllegalArgumentException
    *
  • ERROR_INVALID_ARGUMENT - if the caret has been disposed
  • *
* @exception SWTException
    *
  • ERROR_WIDGET_DISPOSED - if the receiver has been disposed
  • *
  • ERROR_THREAD_INVALID_ACCESS - if not called from the thread that created the receiver
  • *
*/ public void setCaret (Caret caret) { checkWidget(); Caret newCaret = caret; Caret oldCaret = this.caret; this.caret = newCaret; if (hasFocus ()) { if (oldCaret != null) oldCaret.killFocus (); if (newCaret != null) { if (newCaret.isDisposed()) error(SWT.ERROR_INVALID_ARGUMENT); newCaret.setFocus (); } } } @Override public void setFont (Font font) { checkWidget (); if (caret != null) caret.setFont (font); super.setFont (font); } @Override void setOpenGLContext(Object value) { glcontext = (NSOpenGLContext)value; Shell shell = getShell (); if (glcontext != null) { shell.glContextCount++; } else { shell.glContextCount--; } shell.updateOpaque (); } /** * Sets the receiver's IME. * * @param ime the new IME for the receiver, may be null * * @exception IllegalArgumentException
    *
  • ERROR_INVALID_ARGUMENT - if the IME has been disposed
  • *
* @exception SWTException
    *
  • ERROR_WIDGET_DISPOSED - if the receiver has been disposed
  • *
  • ERROR_THREAD_INVALID_ACCESS - if not called from the thread that created the receiver
  • *
* * @since 3.4 */ public void setIME (IME ime) { checkWidget (); if (ime != null && ime.isDisposed()) error(SWT.ERROR_INVALID_ARGUMENT); this.ime = ime; } @Override boolean setMarkedText_selectedRange (long /*int*/ id, long /*int*/ sel, long /*int*/ string, long /*int*/ range) { if (ime != null) { if (!ime.setMarkedText_selectedRange (id, sel, string, range)) return false; } return super.setMarkedText_selectedRange (id, sel, string, range); } @Override long /*int*/ validAttributesForMarkedText (long /*int*/ id, long /*int*/ sel) { if (ime != null) return ime.validAttributesForMarkedText (id, sel); return super.validAttributesForMarkedText(id, sel); } @Override long /*int*/ validRequestorForSendType(long /*int*/ id, long /*int*/ sel, long /*int*/ sendType, long /*int*/ returnType) { if (id == view.id) { Accessible acc = getAccessible(); if (acc != null) { // This returns null if there are no additional overrides. Since this is only checked to see if there is // a StyledText or other control that supports reading and writing of the selection there's no need to bother // with checking the default values. They will be picked up in the default implementation. NSArray attributes = acc.internal_accessibilityAttributeNames(ACC.CHILDID_SELF); if (attributes != null) { boolean canReturn = attributes.containsObject(OS.NSAccessibilitySelectedTextAttribute); boolean canSend = acc.internal_accessibilityIsAttributeSettable(OS.NSAccessibilitySelectedTextAttribute, ACC.CHILDID_SELF); boolean canHandlePBoardType = supportedPboardTypes.containsObject(new id(sendType)) && supportedPboardTypes.containsObject(new id(returnType)); if (canReturn && canSend && canHandlePBoardType) { id selection = acc.internal_accessibilityAttributeValue(OS.NSAccessibilitySelectedTextAttribute, ACC.CHILDID_SELF); if (selection != null) { NSString selectionString = new NSString(selection); if (selectionString.length() > 0) return view.id; } } } } } return super.validRequestorForSendType(id, sel, sendType, returnType); } @Override void updateOpenGLContext(long /*int*/ id, long /*int*/ sel, long /*int*/ notification) { if (glcontext != null) ((NSOpenGLContext)glcontext).update(); } @Override void viewWillMoveToWindow(long /*int*/ id, long /*int*/ sel, long /*int*/ arg0) { super.viewWillMoveToWindow(id, sel, arg0); if (glcontext != null && id == view.id && arg0 != 0) { Widget newShell = display.getWidget(new NSWindow(arg0).contentView()); if (newShell instanceof Shell) { ((Shell) newShell).glContextCount++; ((Shell) newShell).updateOpaque(); } Shell shell = getShell(); shell.glContextCount--; shell.updateOpaque(); } } @Override boolean writeSelectionToPasteboard(long /*int*/ id, long /*int*/ sel, long /*int*/ pasteboardObj, long /*int*/ typesObj) { boolean result = false; NSPasteboard pboard = new NSPasteboard(pasteboardObj); NSArray types = new NSArray(typesObj); NSMutableArray typesToDeclare = NSMutableArray.arrayWithCapacity(2); NSString type; for (long /*int*/ i = 0; i < supportedPboardTypes.count(); i++) { type = new NSString(supportedPboardTypes.objectAtIndex(i)); if (types.containsObject(type)) typesToDeclare.addObject(type); } if (typesToDeclare.count() > 0) { pboard.declareTypes(typesToDeclare, view); for (long /*int*/ i = 0; i < typesToDeclare.count(); i++) { type = new NSString(typesToDeclare.objectAtIndex(i)); if (writeSelectionToPasteboard(pboard, type)) result = true; } } return result; } boolean writeSelectionToPasteboard(NSPasteboard pboard, NSString type) { boolean result = false; if (type.isEqualToString(OS.NSStringPboardType)) { Accessible acc = getAccessible(); id selection = acc.internal_accessibilityAttributeValue(OS.NSAccessibilitySelectedTextAttribute, ACC.CHILDID_SELF); if (selection != null) { NSString selectionString = new NSString(selection); if (selectionString.length() > 0) result = pboard.setString(selectionString, OS.NSStringPboardType); } } return result; } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy