Hill Station
About This Attraction
Penang Hill, located in the Malaysian state of Penang, is a popular tourist destination known for its cool climate and panoramic views of George Town. To reach the top, visitors can take the Penang Hill Railway, a funicular train that offers a scenic ride through lush greenery. The hill stands at 833 meters above sea level, providing breathtaking views, especially at sunrise and sunset. Penang Hill opening hours are generally from early morning until late evening, allowing visitors plenty of time to explore.
On the summit, several attractions await, including The Habitat Penang Hill, which features a canopy walk and beautiful gardens showcasing local flora and fauna. Visitors can also enjoy dining options with stunning views at several restaurants or visit historical sites like the David Browns Restaurant and Tea Terraces. With its mix of nature and history, Penang Hill offers an enjoyable experience for all ages. Always check the latest information on opening hours before planning your visit.
Location Details
Address
Penang Hill, Air Itam, 11500 George Town, Penang, Malaysia
Visitor Information
Pricing & Ratings
Ticket Prices
Adult
RM 30
Child
RM 15
Student
RM 15
Senior
RM 15
Opening Hours & Booking
Open
Days
Monday to Sunday
Hours
6:30 AM to 11:00 PM
Seasonality
Open all year
Booking
Booking Required?
No
Nearby Attractions
Kek Lok Si Temple, located in Penang, Malaysia, is one of the largest and most…
Learn More
George Town, the capital of Penang Island in Malaysia, is a UNESCO World Heritage site…
Learn More
Batu Ferringhi Beach is a popular tourist destination on the northern coast of Penang Island,…
Learn More
Penang National Park, located in Malaysia, is known for its rich biodiversity and offers visitors…
Learn More
The Perak Museum in Taiping is the oldest museum in Malaysia, established in 1883. It…
Learn More
Taiping Zoo, located in Taiping, Malaysia, is one of the oldest zoos in the country,…
Learn More
Taiping Lake Gardens, located in the town of Taiping in Perak, Malaysia, is one of…
Learn More
Pantai Cenang is a popular beach destination located on the island of Langkawi, Malaysia. Known…
Learn More
Kilim Geoforest Park in Langkawi is known for its unique geological formations and rich biodiversity.…
Learn More
The Langkawi Sky Bridge is a remarkable curved pedestrian bridge located in Langkawi, Malaysia. It…
Learn More
";
}
// Initialize modal controls
const initModalControls = function() {
console.log('Initializing modal controls');
const modal = document.getElementById('attraction-modal');
const closeBtn = document.querySelector('.attraction-modal-close');
if (closeBtn) {
closeBtn.addEventListener('click', function() {
modal.style.display = 'none';
document.body.style.overflow = '';
});
}
window.addEventListener('click', function(event) {
if (event.target === modal) {
modal.style.display = 'none';
document.body.style.overflow = '';
}
});
// Make attraction cards clickable
const attractionCards = document.querySelectorAll('.attraction-card');
console.log('Found ' + attractionCards.length + ' attraction cards');
attractionCards.forEach(card => {
card.addEventListener('click', function(e) {
openModalWithCardData(this);
});
});
};
// Function to open modal with card data
const openModalWithCardData = function(card) {
// Get data from hidden div
const data = card.querySelector('.attraction-full-data');
if (!data) {
console.error('No attraction data found in card');
return;
}
const modal = document.getElementById('attraction-modal');
if (!modal) {
console.error('Modal element still not found after creation attempt');
return;
}
// Helper function to safely get element text
function getElementText(selector) {
const element = data.querySelector(selector);
return element ? element.textContent : '';
}
try {
// Basic Info
document.getElementById('attraction-modal-title').textContent = getElementText('.attraction-name');
document.getElementById('attraction-modal-type').textContent = getElementText('.attraction-type-full');
document.getElementById('attraction-modal-description').textContent = getElementText('.attraction-description-full');
// Reset all containers to hidden
['attraction-modal-hours-container', 'attraction-modal-price-container',
'attraction-modal-address-container', 'attraction-modal-image-container'].forEach(id => {
const container = document.getElementById(id);
if (container) container.style.display = 'none';
});
// Rating
const ratingText = getElementText('.attraction-rating-full');
if (ratingText) {
const ratingValue = parseFloat(ratingText);
if (!isNaN(ratingValue)) {
const ratingValueEl = document.getElementById('attraction-modal-rating-value');
const ratingFillEl = document.getElementById('attraction-modal-rating-fill');
if (ratingValueEl) ratingValueEl.textContent = ratingValue.toFixed(1) + '/10';
if (ratingFillEl) ratingFillEl.style.width = (ratingValue * 10) + '%';
}
}
// Show the modal
modal.style.display = 'block';
document.body.style.overflow = 'hidden'; // Prevent background scrolling
console.log('Modal opened successfully');
} catch (error) {
console.error('Error opening modal:', error);
}
};
// Try to create the modal
const created = createModal();
console.log('Modal created:', created);
// If not created (already exists), initialize the controls
if (!created) {
initModalControls();
}
// Also initialize distance toggle
const distanceToggle = document.getElementById('distance-unit-toggle');
if (distanceToggle) {
distanceToggle.addEventListener('change', function() {
const showKm = this.checked;
// Update toggle labels
const labels = document.querySelectorAll('.toggle-label');
if (labels.length >= 2) {
labels[0].style.opacity = showKm ? '0.5' : '1';
labels[1].style.opacity = showKm ? '1' : '0.5';
}
// Update all distance displays
document.querySelectorAll('.nearby-attraction-card').forEach(card => {
const kmEl = card.querySelector('.distance-km');
const miEl = card.querySelector('.distance-mi');
if (kmEl && miEl) {
kmEl.style.display = showKm ? 'inline' : 'none';
miEl.style.display = showKm ? 'none' : 'inline';
}
});
});
}
});