Friday, October 28, 2016

How’d They Do It? PHPSnake: Detecting Keypresses

Vector image of an old school joystick

At a recent conference in Bulgaria, there was a hackathon for which Andrew Carter created a PHP console version of the popular "snake" game.

I thought it was a really interesting concept, and since Andrew has a history of using PHP for weird things, I figured I'd demystify and explain how it was done.

The original repository is here, but we'll build a version of it from scratch in this series so no need to clone it.

Screenshot of the game

Prerequisites and Rules

As usual, I'll be using my Homestead Improved box to get up and running instantly. You can use your own environment, just make sure it has a decent version of PHP runnable from the command line.

The snake game we're replicating has the following features:

  • a snake starts as a single on-screen character, and gets longer by one character every time it eats a piece of food.
  • food is spawned randomly anywhere on the map.
  • in single player mode, the snake is controlled by the arrow keys.
  • in two player mode, one snake is controlled with the WSAD keys, while the other is controlled with the arrow keys.
  • in single player mode, the walls are obstacles and cause a collision. Running into a wall or into yourself ends the game.
  • in multi player mode, only your own snake or the enemy's snake is an obstacle - the walls wrap around the world. Colliding will reset your snake's length to 0. The player with the longest snake after 100 seconds have elapsed is the winner.
  • it's CLI, so does not run in the browser - it runs in the terminal window

Note that the game doesn't work in native Windows - to run it on a Windows platform, use a good VM like Homestead Improved.

Bootstrapping

To launch a CLI (console) game, we need something similar to an index.php file in traditional websites - a "front controller" which reads our command line input, parses it, and then launches the required classes, just like in a traditional web app. We'll call this file play.php.

Continue reading %How’d They Do It? PHPSnake: Detecting Keypresses%


by Bruno Skvorc via SitePoint

How I Made $2,000 in 1.5 Months Starting with a Google Form-Based MVP

10 years ago, I taught myself Ruby on Rails and spent six months developing a local job board. I seeded the site with jobs from Craigslist and paid my local news station $3,000 to run a month-long ad. Unfortunately, all that time and money only brought in 50 visitors a day. I ended up selling just one job post, becoming discouraged, and shutting the site down after a few months.

Needless to say, I didn’t know what I was doing, but you’d be surprised how many well-capitalized startups proceed along those same lines today and do even worse than I did back then. It’s because the answer isn’t in spending large sums of time and money. It’s in running cheap and measurable tests that provide the market feedback you need to keep cranking on your ideas. Here’s how my latest project Old Geek Jobs made $2,000 in a month and a half by running cheap experiments.

Old Geek Job’s Stripe dashboard

Age Discrimination Led Me to My First MVP

On September 15th, I read Tim Bray’s "Old Geek" post about ageism in tech. It struck a chord because I experienced what I felt was age discrimination interviewing with a startup run by 20 year olds. I registered the domain name OldGeekJobs.com for $9, fired up a $10 Digital Ocean instance, and uploaded a Google form embedded in a static site.

Old Geek Jobs before

Getting Eyeballs After Launch

My site was posted to HackerNews and collected over 500 upvotes. The next day, Quartz wrote a piece followed with another from Evil HR Lady. Employers started submitting jobs, and I copied and pasted them from the Google form to the static site. I wasn’t making any money because the job posts were free, but in less than a few days, I had the feedback I needed to move forward on my idea.

Over the next few weeks, I began developing a more robust version of the site using jQuery, Python, Flask, and Postgresql. I broke out jobs by city and state, added real-time keyword search, and added an innovative quick preview feature. Here’s what the site looks like now with that quick preview feature activated:

Old Geek jobs now

The Elephant in the Room — Will It Make Money?

I also made it $50 to post a job. In exchange for the $50, jobs are posted for 45 days, highlighted in green, and display above other jobs aggregated from StackOverflow. I bring in jobs from them so there’s enough good jobs on the site to keep bringing visitors back. I also put a notice on the site that explains how it all works:

Continue reading %How I Made $2,000 in 1.5 Months Starting with a Google Form-Based MVP%


by John Wheeler via SitePoint

AtoZ CSS Quick Tip: How to Use Unicode Characters

U is for Unicode Characters

Unicode characters can be really handy for adding little symbols and icons to your HTML or in your CSS via pseudo elements' content property. Here are a handful of tips for using unicode characters.

[author_more]

Set the character set in your CSS

If you want to use unicode characters in your CSS file, ensure to set the character set for your CSS in addition to setting the charset meta tag in your HTML document.

[code language="html"]
<!-- in your HTML <head> -->
<meta charset="utf-8"/>
[/code]

[code language="css"]
/* in your CSS at the top of the file*/
@charset 'utf-8';
[/code]

Use the Trigram for Heaven symbol as a simple hamburger icon

When needing to knock together a quick demo site or a video screencast for a responsive tutorial, I often use the love-it-or-hate-it hamburger icon for a mobile menu. There are lots of icon solutions out there and there are many non-raster approaches to the hamburger icon but often the quickest and easiest for me is to use the unicode character called "The Trigram for Heaven" which looks like this: .

.

Continue reading %AtoZ CSS Quick Tip: How to Use Unicode Characters%


by Guy Routledge via SitePoint

AlphaPod

AlphaPod

Visually rich, interactive One Pager by Julian Damy previewing his latest drawing and illustration project, AlphaPod. Awesome to see the hype for the upcoming children's book start with a Single Page website - showcasing the first 4 letters. The illustrations are truly stunning - all the best Julian!

by Rob Hope via One Page Love

New Coffee Break Course: First Look at Slim PHP

360 Video for Marketers: What You Need to Know

ms-podcast221-ryan-anderson-bell-600

Have you tried producing 360 video? Want to discover how to create immersive, sharable 360 video? To explore how marketers can use 360 video, I interview Ryan Anderson Bell. More About This Show The Social Media Marketing podcast is an on-demand talk radio show from Social Media Examiner. It’s designed to help busy marketers and [...]

This post 360 Video for Marketers: What You Need to Know first appeared on .
- Your Guide to the Social Media Jungle


by Michael Stelzner via

Bring Your Android App to Chromebooks