<?xml version="1.0" encoding="UTF-8"?>
<rss version="2.0"
	xmlns:content="http://purl.org/rss/1.0/modules/content/"
	xmlns:wfw="http://wellformedweb.org/CommentAPI/"
	xmlns:dc="http://purl.org/dc/elements/1.1/"
	xmlns:atom="http://www.w3.org/2005/Atom"
	xmlns:sy="http://purl.org/rss/1.0/modules/syndication/"
	xmlns:slash="http://purl.org/rss/1.0/modules/slash/"
	>

<channel>
	<title>Codec &#187; Cursor</title>
	<atom:link href="http://www.trembl.org/codec/tag/cursor/feed/" rel="self" type="application/rss+xml" />
	<link>http://www.trembl.org/codec</link>
	<description>A Personal Polylogic Code/Decode &#039;Zettelkasten&#039;</description>
	<lastBuildDate>Thu, 02 Feb 2012 03:38:01 +0000</lastBuildDate>
	<language>en</language>
	<sy:updatePeriod>hourly</sy:updatePeriod>
	<sy:updateFrequency>1</sy:updateFrequency>
	<generator>http://wordpress.org/?v=3.3.1</generator>
		<item>
		<title>Changing the Cursor with Events when dragging an HTML5 canvas</title>
		<link>http://www.trembl.org/codec/693/</link>
		<comments>http://www.trembl.org/codec/693/#comments</comments>
		<pubDate>Tue, 25 Jan 2011 09:50:01 +0000</pubDate>
		<dc:creator>Georg Tremmel</dc:creator>
				<category><![CDATA[Raw]]></category>
		<category><![CDATA[canvas]]></category>
		<category><![CDATA[caret]]></category>
		<category><![CDATA[Cursor]]></category>
		<category><![CDATA[hand]]></category>
		<category><![CDATA[html5]]></category>
		<category><![CDATA[javascript]]></category>
		<category><![CDATA[jQuery]]></category>

		<guid isPermaLink="false">http://www.trembl.org/codec/?p=693</guid>
		<description><![CDATA[With jQuery document ready: $&#40;function&#40;&#41;&#123; var canvas = $&#40;'#testCanvas'&#41;&#91;0&#93;; canvas.addEventListener&#40;'mousedown', function&#40;e&#41;&#123; e.preventDefault&#40;&#41;; e.stopPropagation&#40;&#41;; e.target.style.cursor = 'move'; &#125;, false&#41;; canvas.addEventListener&#40;'mouseup', function&#40;e&#41;&#123; e.target.style.cursor = 'default'; &#125;, false&#41;; &#125;&#41;; And without&#8230; $&#40;'#testCanvas'&#41;&#91;0&#93;.addEventListener&#40;'mousedown', function&#40;e&#41;&#123; e.preventDefault&#40;&#41;; e.stopPropagation&#40;&#41;; e.target.style.cursor = 'move'; &#125;, false&#41;; &#160; $&#40;'#testCanvas'&#41;&#91;0&#93;.addEventListener&#40;'mouseup', function&#40;e&#41; &#123; e.target.style.cursor = 'default'; &#125;, false&#41;; Based on this: http://stackoverflow.com/questions/2659999/html5-canvas-hand-cursor-problems]]></description>
			<content:encoded><![CDATA[<p>With jQuery document ready:</p>

<div class="wp_syntax"><div class="code"><pre class="javascript" style="font-family:monospace;">$<span style="color: #009900;">&#40;</span><span style="color: #003366; font-weight: bold;">function</span><span style="color: #009900;">&#40;</span><span style="color: #009900;">&#41;</span><span style="color: #009900;">&#123;</span>
	<span style="color: #003366; font-weight: bold;">var</span> canvas <span style="color: #339933;">=</span> $<span style="color: #009900;">&#40;</span><span style="color: #3366CC;">'#testCanvas'</span><span style="color: #009900;">&#41;</span><span style="color: #009900;">&#91;</span><span style="color: #CC0000;">0</span><span style="color: #009900;">&#93;</span><span style="color: #339933;">;</span>
	canvas.<span style="color: #660066;">addEventListener</span><span style="color: #009900;">&#40;</span><span style="color: #3366CC;">'mousedown'</span><span style="color: #339933;">,</span> <span style="color: #003366; font-weight: bold;">function</span><span style="color: #009900;">&#40;</span>e<span style="color: #009900;">&#41;</span><span style="color: #009900;">&#123;</span>
		e.<span style="color: #660066;">preventDefault</span><span style="color: #009900;">&#40;</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span>
		e.<span style="color: #660066;">stopPropagation</span><span style="color: #009900;">&#40;</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span>
		e.<span style="color: #660066;">target</span>.<span style="color: #660066;">style</span>.<span style="color: #660066;">cursor</span> <span style="color: #339933;">=</span> <span style="color: #3366CC;">'move'</span><span style="color: #339933;">;</span>
	<span style="color: #009900;">&#125;</span><span style="color: #339933;">,</span> <span style="color: #003366; font-weight: bold;">false</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span>
	canvas.<span style="color: #660066;">addEventListener</span><span style="color: #009900;">&#40;</span><span style="color: #3366CC;">'mouseup'</span><span style="color: #339933;">,</span> <span style="color: #003366; font-weight: bold;">function</span><span style="color: #009900;">&#40;</span>e<span style="color: #009900;">&#41;</span><span style="color: #009900;">&#123;</span>
		e.<span style="color: #660066;">target</span>.<span style="color: #660066;">style</span>.<span style="color: #660066;">cursor</span> <span style="color: #339933;">=</span> <span style="color: #3366CC;">'default'</span><span style="color: #339933;">;</span>
	<span style="color: #009900;">&#125;</span><span style="color: #339933;">,</span> <span style="color: #003366; font-weight: bold;">false</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span>
<span style="color: #009900;">&#125;</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span></pre></div></div>

<p>And without&#8230;</p>

<div class="wp_syntax"><div class="code"><pre class="javascript" style="font-family:monospace;">$<span style="color: #009900;">&#40;</span><span style="color: #3366CC;">'#testCanvas'</span><span style="color: #009900;">&#41;</span><span style="color: #009900;">&#91;</span><span style="color: #CC0000;">0</span><span style="color: #009900;">&#93;</span>.<span style="color: #660066;">addEventListener</span><span style="color: #009900;">&#40;</span><span style="color: #3366CC;">'mousedown'</span><span style="color: #339933;">,</span> <span style="color: #003366; font-weight: bold;">function</span><span style="color: #009900;">&#40;</span>e<span style="color: #009900;">&#41;</span><span style="color: #009900;">&#123;</span>
	e.<span style="color: #660066;">preventDefault</span><span style="color: #009900;">&#40;</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span>
	e.<span style="color: #660066;">stopPropagation</span><span style="color: #009900;">&#40;</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span>
	e.<span style="color: #660066;">target</span>.<span style="color: #660066;">style</span>.<span style="color: #660066;">cursor</span> <span style="color: #339933;">=</span> <span style="color: #3366CC;">'move'</span><span style="color: #339933;">;</span>
<span style="color: #009900;">&#125;</span><span style="color: #339933;">,</span> <span style="color: #003366; font-weight: bold;">false</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span>
&nbsp;
$<span style="color: #009900;">&#40;</span><span style="color: #3366CC;">'#testCanvas'</span><span style="color: #009900;">&#41;</span><span style="color: #009900;">&#91;</span><span style="color: #CC0000;">0</span><span style="color: #009900;">&#93;</span>.<span style="color: #660066;">addEventListener</span><span style="color: #009900;">&#40;</span><span style="color: #3366CC;">'mouseup'</span><span style="color: #339933;">,</span> <span style="color: #003366; font-weight: bold;">function</span><span style="color: #009900;">&#40;</span>e<span style="color: #009900;">&#41;</span> <span style="color: #009900;">&#123;</span>
	e.<span style="color: #660066;">target</span>.<span style="color: #660066;">style</span>.<span style="color: #660066;">cursor</span> <span style="color: #339933;">=</span> <span style="color: #3366CC;">'default'</span><span style="color: #339933;">;</span>
<span style="color: #009900;">&#125;</span><span style="color: #339933;">,</span> <span style="color: #003366; font-weight: bold;">false</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span></pre></div></div>

<p>Based on this: <a href="http://stackoverflow.com/questions/2659999/html5-canvas-hand-cursor-problems">http://stackoverflow.com/questions/2659999/html5-canvas-hand-cursor-problems</a></p>
]]></content:encoded>
			<wfw:commentRss>http://www.trembl.org/codec/693/feed/</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
		<item>
		<title>Simulating Keyboard &amp; Mouse Events. And Key-Modifier Events</title>
		<link>http://www.trembl.org/codec/289/</link>
		<comments>http://www.trembl.org/codec/289/#comments</comments>
		<pubDate>Tue, 01 Dec 2009 09:21:56 +0000</pubDate>
		<dc:creator>Georg Tremmel</dc:creator>
				<category><![CDATA[Raw]]></category>
		<category><![CDATA[10.5]]></category>
		<category><![CDATA[10.6]]></category>
		<category><![CDATA[alt]]></category>
		<category><![CDATA[Cursor]]></category>
		<category><![CDATA[key]]></category>
		<category><![CDATA[Keyboard]]></category>
		<category><![CDATA[Mouse]]></category>
		<category><![CDATA[NSEvent]]></category>
		<category><![CDATA[Objective-C]]></category>
		<category><![CDATA[Position]]></category>
		<category><![CDATA[shift]]></category>

		<guid isPermaLink="false">http://www.trembl.org/codec/?p=289</guid>
		<description><![CDATA[Creating and Posting a Keyboard Event: CGEventRef sDown, sUp; sDown = CGEventCreateKeyboardEvent &#40; NULL, &#40;CGKeyCode&#41;1, &#60;strong&#62;true&#60;/strong&#62; &#41;; &#60;strong class=&#34;red&#34;&#62;CGEventSetFlags&#40;sDown, kCGEventFlagMaskShift&#41;;&#60;/strong&#62; &#160; // setting flags with special function. &#60;em&#62;// Setting it via CGCreateKeyboardEvent // would work only for the first time it's run&#60;/em&#62; &#160; CGEventPost&#40;kCGHIDEventTap, sDown&#41;; &#160; sUp = CGEventCreateKeyboardEvent &#40; NULL, &#40;CGKeyCode&#41;1, &#60;strong&#62;false&#60;/strong&#62; &#41;; CGEventPost&#40;kCGHIDEventTap, [...]]]></description>
			<content:encoded><![CDATA[<p>Creating and Posting a Keyboard Event:</p>

<div class="wp_syntax"><div class="code"><pre class="objc" style="font-family:monospace;">CGEventRef sDown, sUp;
sDown <span style="color: #002200;">=</span> CGEventCreateKeyboardEvent <span style="color: #002200;">&#40;</span>
			<span style="color: #a61390;">NULL</span>,
			<span style="color: #002200;">&#40;</span>CGKeyCode<span style="color: #002200;">&#41;</span><span style="color: #2400d9;">1</span>,
			&lt;strong&gt;true&lt;<span style="color: #002200;">/</span>strong&gt;
<span style="color: #002200;">&#41;</span>;
&lt;strong class<span style="color: #002200;">=</span><span style="color: #bf1d1a;">&quot;red&quot;</span>&gt;CGEventSetFlags<span style="color: #002200;">&#40;</span>sDown, kCGEventFlagMaskShift<span style="color: #002200;">&#41;</span>;&lt;<span style="color: #002200;">/</span>strong&gt;  
&nbsp;
<span style="color: #11740a; font-style: italic;">// setting flags with special function. </span>
&lt;em&gt;<span style="color: #11740a; font-style: italic;">// Setting it via CGCreateKeyboardEvent</span>
<span style="color: #11740a; font-style: italic;">// would work only for the first time it's run&lt;/em&gt;</span>
&nbsp;
CGEventPost<span style="color: #002200;">&#40;</span>kCGHIDEventTap, sDown<span style="color: #002200;">&#41;</span>;
&nbsp;
sUp <span style="color: #002200;">=</span> CGEventCreateKeyboardEvent <span style="color: #002200;">&#40;</span>
			<span style="color: #a61390;">NULL</span>,
			<span style="color: #002200;">&#40;</span>CGKeyCode<span style="color: #002200;">&#41;</span><span style="color: #2400d9;">1</span>,
			&lt;strong&gt;false&lt;<span style="color: #002200;">/</span>strong&gt;
<span style="color: #002200;">&#41;</span>;
CGEventPost<span style="color: #002200;">&#40;</span>kCGHIDEventTap, sUp<span style="color: #002200;">&#41;</span>;
&nbsp;
CFRelease<span style="color: #002200;">&#40;</span>sDown<span style="color: #002200;">&#41;</span>;
CFRelease<span style="color: #002200;">&#40;</span>sUp<span style="color: #002200;">&#41;</span>;</pre></div></div>

<p>That leaves the door open for applying the same to mouse events:</p>

<div class="wp_syntax"><div class="code"><pre class="objc" style="font-family:monospace;">CGEventRef mouseEvent;
mouseEvent <span style="color: #002200;">=</span> CGEventCreateMouseEvent <span style="color: #002200;">&#40;</span>
			<span style="color: #a61390;">NULL</span>,
			kCGEventMouseMoved,
			CGPointMake<span style="color: #002200;">&#40;</span><span style="color: #2400d9;">100</span>, <span style="color: #2400d9;">100</span><span style="color: #002200;">&#41;</span>,
			kCGMouseButtonLeft
<span style="color: #002200;">&#41;</span>;
CGEventPost<span style="color: #002200;">&#40;</span>kCGHIDEventTap, mouseEvent <span style="color: #002200;">&#41;</span>;</pre></div></div>

<p>Magical. Isn&#8217;t it.</p>
<p><em>Of course, in pre-10.6 days it would have looked like that:</em></p>

<div class="wp_syntax"><div class="code"><pre class="objc" style="font-family:monospace;">CGPostKeyboardEvent <span style="color: #002200;">&#40;</span><span style="color: #2400d9;">0</span>,<span style="color: #2400d9;">5</span>,<span style="color: #a61390;">true</span><span style="color: #002200;">&#41;</span>;
CGPostKeyboardEvent <span style="color: #002200;">&#40;</span><span style="color: #2400d9;">0</span>,<span style="color: #2400d9;">5</span>,<span style="color: #a61390;">false</span><span style="color: #002200;">&#41;</span>;</pre></div></div>

]]></content:encoded>
			<wfw:commentRss>http://www.trembl.org/codec/289/feed/</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
	</channel>
</rss>

