add a real article and keep messing with CSS/HTML

This commit is contained in:
Andrew Cassidy 2017-12-18 21:15:35 -08:00 committed by Andrew Cassidy
parent 670a2fa8be
commit 2d83591e6b
10 changed files with 97 additions and 70 deletions

View File

@ -6,44 +6,32 @@ permalink: Blog/
{% assign char-count = 500 %}
<ul id="post-list">
{% for post in site.posts %}
<li class="post-entry">
<a class="post-title" href="{{ post.url | prepend: site.baseurl }}">
{{ post.title }}
{% for post in site.posts %}
<article class="post-entry">
<a class="post-title" href="{{ post.url | prepend: site.baseurl }}">
{{ post.title }}
</a>
<table>
<tr>
<td class="post-tags">
{% include taglist.html %}
<td class="post-date">
<i>{{ post.date | date: "%b %-d, %Y" }}</i>
</td>
</tr>
</table>
<hr>
<div class="post-excerpt">
{% assign excerpt-text = post.content | markdownify %}
{% assign excerpt-length = excerpt-text | number_of_words %}
{{post.content | markdownify| truncate: char-count}}
<a class="post-see-more" href="{{ post.url | prepend: site.baseurl }}">
<i>See&nbsp;More</i>
</a>
<table>
<tr>
<td class="post-tags">
tags:
<i>
{% if post.tags %}
{% for tag in post.tags limit: 6%}
{{ tag }}
{% endfor %}
{% else %}
none
{% endif %}
</i>
</td>
<td class="post-date">
<i>{{ post.date | date: "%b %-d, %Y" }}</i>
</td>
</tr>
</table>
<hr>
<div class="post-excerpt">
{% assign excerpt-text = post.content | markdownify %}
{% assign excerpt-length = excerpt-text | number_of_words %}
{{post.content | markdownify| truncate: char-count}}
<a class="post-see-more" href="{{ post.url | prepend: site.baseurl }}">
<i>See&nbsp;More</i>
</a>
</div>
</li>
{% endfor %}
</ul>
</div>
</article>
{% endfor %}

View File

@ -12,4 +12,12 @@ exclude:
collections:
- projects
defaults:
-
scope:
paths: _posts
values:
layout: post
mobile-width: "600px"

10
_includes/taglist.html Normal file
View File

@ -0,0 +1,10 @@
Tags:
{% if post.tags.size > 0 %}
<i>
{% for tag in post.tags limit: 6%}
{{ tag }}
{% endfor %}
</i>
{% else %}
none
{% endif %}

View File

@ -13,13 +13,13 @@
<span class="slash">/</span>
</header>
<main>
<div id="box">
{% include sidebar.html %}
<article id="content">
<main id="content">
{{ content }}
</article>
</main>
</main>
</div>
<!--{% include footer.html %}-->
</body>

View File

@ -11,13 +11,13 @@
<span class="slash">/</span> {{ page.title }}
</header>
<main>
<div id="box">
{% include sidebar.html %}
<article id="content">
<main id="content">
{{ content }}
</article>
</main>
</main>
</div>
<!--{% include footer.html %}-->
</body>

View File

@ -11,13 +11,13 @@
<span class="slash">/</span> {{ page.title }}
</header>
<main>
<div id="box">
{% include sidebar.html %}
<article id="content">
<main id="content">
{{ content }}
</article>
</main>
</main>
</div>
<!--{% include footer.html %}-->
</body>

View File

@ -10,16 +10,17 @@
<a href="/" id="name"><b>Andrew Cassidy</b></a>
<span class="slash">/</span>
<a href="/Blog" class="dir">Blog</a>
<span class="slash">/</span> {{ page.title }}
<span class="slash">/</span>
</header>
<main>
<div id="box">
{% include sidebar.html %}
<article id="content">
<main id="content">
<h1> {{page.title}} </h1>
{{ content }}
</article>
</main>
</main>
</div>
<!--{% include footer.html %}-->
</body>

View File

@ -0,0 +1,28 @@
---
title: Hacking a 1986 computer mouse into the 21st century
---
While looking through a pile of computer hardware I found an original Apple ADB mouse, the one that shipped with the Apple II<span style="font-variant: small-caps;">gs</span> and several models of mac. Its an extremely simple piece of hardware, with only a single button on top and a mechanical ball on the bottom. Interestingly, the cable on the mouse is very short, since it was designed to be daisy-chained with an ADB keyboard.
My idea was to transplant the internals from a cheap bluetooth mouse (one I have kept in my backpack for use at school) into the ADB mouse, making it into something I could use daily. I needed to add several things to the hardware:
* Two buttons on top
* A scroll wheel that also clicks
* a power switch and pair button
* An internal battery, since I couldnt find any way to make a door for AAAs, plus a way of charging it
* optionally, a button for activating Siri on my laptop so I can recreate [that scene from Star Trek IV](https://youtu.be/xaVgRj2e5_s?t=2m51s)
## Day 1: The Mouse Buttons
The first step was to split the existing single button into two. After grinding off the plastic welding on the pins holding the button in, I used a hacksaw guided by a block of wood to saw the button in half all the way down to the center part of the hinge. After sanding I think the cut looked pretty good! Something like a laser, or a better suited saw would probably have gotten a cleaner cut, but I was happy with this
## Day 2: The Board
Since i wanted the optical sensor to peer through where the ball went, I needed it to be centered, but the bluetooth mouses board was slightly too wide to do this. Luckily the only thing on that part was the right mouse button, which I had to move anyways, and the connector for the batteries, which i was already replacing with a Lithium battery.
I unfortunately had to scrape away some of the solder mask from the underside of the board to solder on a wire for the power connection, since all the plated holes were on the cutoff part (I couldnt trace it to any of the pins on the sensor, I suspect there was some voltage conversioning happening). I also had to solder a piece of 30AWG wire directly to the surface mounted bluetooth module for right click, since that trace went all the way around the outside edge of the board.
I also cut down the plastic lens to fit inside the ball door of the original mouse. miraculously the distance between the sensor and the desk was exactly the same as the thickness of the ball hatch.
## Day 3: Assembly
The final major component of the mouse were the left and right click buttons. I used some strip-board cut into a C-shape to accommodate the charging port in the center, which had its middle pin (shorted to ground while disconnected) soldered to it for mechanical support. This was connected to the 5V input on the [charging module](https://www.adafruit.com/product/1904), as well as to the button and common pins of the logic board. Once I had cleaned up the wiring I had a somewhat useful bluetooth mouse (only clicking required pressing the microswitches directly)
Next came the part of the project I was putting off: the scroll wheel. there isnt enough room for the scroll wheel to go between the click buttons, both vertically due to the charge port placement and because the buttons were small enough already. I decided to cut a slot in the side for a mouse wheel to fit that would be operated with the thumb, with a separate button for the middle mouse click (I decided the mechanism for a clicking scroll wheel was too complicated. I also cut a hole for the status LED and a power switch, which I had accidentally neglected before
After this, I did the final assembly by glueing each part in using hot glue, since hot glue can easily be removed by peeling it off or heating with a soldering iron if necessary. I needed to shim the mouse buttons with a bit of wood so they would hit the microswitches correctly (Ill likely print some nicer looking shims later).
I think the final result looks pretty good, and the modifications dont look to out of place compared to the original apple hardware. If I were to repeat the project I think I would have taken greater care with cutting the case, and perhaps found a way to make a scroll wheel that matches the shade of beige used at the time. The plastic is yellowed, but I think I like it like that, it adds a bit of authenticity.

View File

@ -4,11 +4,6 @@
@import 'colors';
@import 'fonts';
#post-list {
list-style-type: none;
padding: {
left: 0px;
}
.post-entry {
.post-title {
@ -33,7 +28,6 @@
}
.post-see-more {
font-style: italic;
color: $body-text-subtle;
}
.post-see-more:hover {
@ -48,4 +42,3 @@
margin: 5px;
}
}
}

View File

@ -103,16 +103,15 @@ header {
}
}
main {
display: flex;
}
hr {
border-width: 0;
height: 1px;
background-color: $body-text-subtle;
background-color: $body-text;
}
#box {
display: flex;
}
#content {
padding: {
@ -158,7 +157,7 @@ hr {
}
}
}
main {
#box {
flex-direction: column;
}
}