Kol. DM pisze sobie bloga używając WordPressa. Trochę go to kosztuje więc pojawiła się koncepcja żeby przeszedł na bezpłatnego Bloggera. Początkiem tej koncepcji jest oczywiście konwersja WP do formatu Bloggera.
Wpisy kol. DM zawierają tekst i dużo zdjęć oraz innych rysunków. Nie mam bladego pojęcia nt. WordPressa, ale dość szybko ustaliłem, że można wyeksportować treść posługując się stosowną funkcją dostępną z Kokpit→Narzędzia→Eksport (powstaje plik w formacie WordPress eXtended RSS -- WXR).
Plik WXR zapisujemy na dysku. Można go zamienić do formatu Bloggera korzystując z konwertera dostępnego tutaj. Jest wprawdzie napisane, że konwerter obsługuje pliki nie większe niż 1Mb, ale mój miał 4Mb i też poszło.
Plik kolegi DM zawiera tekst oraz prawidłowe linki do niektórych rysunków. Inne rysunki są wstawiane sprytnym czymś co nazywane jest shortcode (cf Shortcode API.) Nie wchodząc w szczegóły, zamiast rysunków w treści postu jest umieszczone np. coś takiego:
[nggallery id=506]
506 z kolei jest identyfikatorem zbioru rysunków, które fizycznie są przechowywane w katalogu:
wp-content/gallery
Każda galeria jest w oddzielnym katalogu, ale nazwami katalogów nie
są identyfikatory typu 506
ale coś innego. Logując się
do phpMyAdmin
byłem w stanie ściągnąć całą bazę (w formacie SQL),
w której siedzi WordPress.
W jednej z tabel bazy znalazłem
przypisanie id_galerii
→nazwa-katalogu-z-plikami
INSERT INTO `wp_ngg_gallery` (`gid`, `name`, `slug`, `path`, `title`, `galdesc`, `pageid`, `previewpic`, `author`) VALUES (17, 'gottardo_2', '', 'wp-content/gallery/gottardo_2', '', '', 0, 0, 1), (16, 'gottardo_1', '', 'wp-content/gallery/gottardo_1', '', '', 0, 0, 1), (15, 'nufenen', '', 'wp-content/gallery/nufenen', NULL, NULL, 0, 0, 1), ... itd ...
Czyli zawartość czegoś, co w treści wygląda jak:
[nggallery id=15]
Znajduje się w katalogu wp-content/gallery/nufenen
.
Teraz ściągnąłem cały katalog wp-content
na dysk lokalny
wykorzystując ncftp
ncftp -u USER -p PASS HOST get -R -T wp-content
Następnie zamieniłem nazwy plików w następujący sposób:
nr_galerii__nazwa_pliku
Pliki wysłałem na google za pomocą skryptu. Istotne jest to, że skrypt po załadowaniu, zwraca URL zdjęcia pod którym jest ono dostępne na koncie googla:
100__fra_07063.jpg http://lh5.ggpht.com/-26SgLqsS1vM/UhdwT-Q62CI/AAAAAAAAABQ/k_ipaT4SNsE/100__fra_07063.jpg 100__fra_07064.jpg http://lh4.ggpht.com/-1kWivWwiZW4/UhdwU4vZWPI/AAAAAAAAABY/XxuIGrIPj8Q/100__fra_07064.jpg itd...
Czyli zdjęcie 100__fra_07063.jpg (oryginalnie należące go galerii o identyfikatorze równym '100') jest dostępne pod adresem:
http://lh5.ggpht.com/-26SgLqsS1vM/UhdwT-Q62CI/AAAAAAAAABQ/k_ipaT4SNsE/100__fra_07063.jpg
Uwaga: Album ze zdjęciami na koncie googla może zawierać maksymalnie 1000 zdjęć. Jeżeli zdjęć jest więcej trzeba utworzyć więcej albumów.
Skryptem Perla (wyrażenia regularne/regułowe) zamieniam każde [nggallery id=506] na stosowny ekwiwalent. Przykładowo:
<div id='gid_g509'> <span>< a href="http://lh5.ggpht.com/-NZ_dEAq8qZI/Uhf_OPG9jiI/AAAAAAAADp8/BtBx9DwVgs4/509__1106_016.jpg" imageanchor="1" style="margin-bottom: 1em; margin-right: .1em;"> <img border="0" src="http://lh5.ggpht.com/-NZ_dEAq8qZI/Uhf_OPG9jiI/AAAAAAAADp8/BtBx9DwVgs4/s128/509__1106_016.jpg" height='85' /></a> </span> ... itd ...
Pozostałe zdjęcia mają `prawdziwe URLe' (a nie jakieś
shortcody
), ale oczywiście URLe te są złe bo wskazują na
starego hosta.
Zdjęcia te (z `prawdziwymi URLami') są przechowywane
w katalogu
./wp-content/uploads
.
Ze zdjeciami postępuję, tak jak
w przypadku zdjęć z galerii: 1) wysyłam na konto google skryptem;
2) zmieniam oryginalne
URLe na URLe z konta google (skryptem Perla).
Przed importem do Bloggera warto sprawdzić czy plik, który ma być zaimportowany jest well-formed:
xmllint plik-do-zaimportowania.xml
Uwaga: w tym wpisie przykłady ilustrujące działanie Lightboksa NIE DZIAŁAJĄ, bo
na blogu pinkaccordions.homelinux.org
nie ma zainstalowanego Lightboksa.
(Działają tutaj).
Kliknięcie zdjęcia lub obrazu zamieszczonego na blogu powoduje wyświetlenie go w nakładce na stronie. Jest to tzw. widok Lightbox. (cf. Widok Lightbox w Bloggerze):
<div> <span> <a href="https://lh4.googleusercontent.com/-cKBvbosMsII/Ua4zYPs99kI/AAAAAAAAB90/NLTG1cMbI88/epl313_6040342.jpg" imageanchor="1" style="margin-bottom: 1em; margin-right: .1em;"><img border="0" src="https://lh4.googleusercontent.com/-cKBvbosMsII/Ua4zYPs99kI/AAAAAAAAB90/NLTG1cMbI88/s128/epl313_6040342.jpg" /></a> </span> <span> <a href="http://lh3.ggpht.com/-3POvL9Uv478/UhXICIpp_3I/AAAAAAAAB-w/K1rRrCU2D9c/epl313_6040338.jpg" imageanchor="1" style="margin-bottom: 1em; margin-right: .1em;"><img border="0" src="http://lh3.ggpht.com/-3POvL9Uv478/UhXICIpp_3I/AAAAAAAAB-w/K1rRrCU2D9c/s128/epl313_6040338.jpg" /></a> </span> <span> <a href="http://lh6.ggpht.com/-nmAnV2_TD8U/UhXIIoYKraI/AAAAAAAAB-4/mWAJWpsOUZU/epl313_6040339.jpg" imageanchor="1" style="margin-bottom: 1em; margin-right: .1em;"><img border="0" src="http://lh6.ggpht.com/-nmAnV2_TD8U/UhXIIoYKraI/AAAAAAAAB-4/mWAJWpsOUZU/s128/epl313_6040339.jpg" /></a> </span> <span> <a href="http://lh5.ggpht.com/-wO5_E5_jK14/UhXG7Rd-bSI/AAAAAAAAB-c/x76Ee7I9tgU/epl313_6040332.jpg" imageanchor="1" style="margin-bottom: 1em; margin-right: .1em;"><img border="0" src="http://lh5.ggpht.com/-wO5_E5_jK14/UhXG7Rd-bSI/AAAAAAAAB-c/x76Ee7I9tgU/s128/epl313_6040332.jpg" /></a> </span> </div>
Wynik jest następujący (kliknij w zdjęcie aby przejść do widoku Lightboksa):
W powyższym przykładzie zawartość atrybutów href
i src
jest prawie identyczna, bo różni się wyłącznie
fragmentem s128/
.
Jest to przykład zastosowania sprytnego URLa, który spowoduje automagiczne przeskalowanie
zdjęcia, tak aby dłuższy wymiar miał maksymalnie 128 pikseli. Jeżeli zamiast s128/
wstawimy
s128-c/
albo s128-p/
, to
spowoduje to automagiczne wycięcie kwadratu o wymiarach maksymalnych 128 pikseli (crop).
Przykład:
<div> <span> <a href="http://lh3.ggpht.com/.../epl313_6040338.jpg" imageanchor="1" style="margin-bottom: 1em; margin-right: .1em;"><img border="0" src="http://lh3.ggpht.com/.../s128-c/epl313_6040338.jpg" /></a> </span> <span> <a href="http://lh3.ggpht.com/.../epl313_6040338.jpg" imageanchor="1" style="margin-bottom: 1em; margin-right: .1em;"><img border="0" src="http://lh3.ggpht.com/.../s128-p/epl313_6040338.jpg" /></a> </span>
Symbolem ...
oznaczono pominiętą część URLa (żeby nie wystawał na margines).
Wynik (kliknięcie w zdjęcie nie powoduje przejścia do widoku Lightboksa):
BTW: Liczba 128 nie jest magiczna, można przeskalować obrazek na inny wymiar.
Jeżeli zdjęcia są różnych wymiarów (portret/pejzaż),
to s128-c/
(albo s128-p/
) jest lepsze niż zwykłe s128
,
bo minaturki są jednakowej wielkości,
tyle że Lightbox takie zdjęcia ignoruje. Czemu -- nie wiem... Nie wiem też jak to zmienić
Jako obejście problemu można przeskalować miniaturkę do jednakowej wysokości. Przykład:
<div> <span> <a href="https://lh4.googleusercontent.com/.../epl313_6040342.jpg" imageanchor="1" style="margin-bottom: 1em;"><img border="0" height='85' src="https://lh4.googleusercontent.com/.../s128/epl313_6040342.jpg" /></a> </span> <span> <a href="http://lh3.ggpht.com/.../epl313_6040338.jpg" imageanchor="1" style="margin-bottom: 1em;"><img border="0" height='85' src="http://lh3.ggpht.com/.../s128/epl313_6040338.jpg" /></a> </span> <span> <a href="http://lh6.ggpht.com/.../epl313_6040339.jpg" imageanchor="1" style="margin-bottom: 1em;"><img border="0" height='85' src="http://lh6.ggpht.com/.../s128/epl313_6040339.jpg" /></a> </span> <span> <a href="http://lh5.ggpht.com/.../epl313_6040332.jpg" imageanchor="1" style="margin-bottom: 1em;"><img border="0" height='85' src="http://lh5.ggpht.com/.../s128/epl313_6040332.jpg" /></a> </span> </div>
Symbolem ...
oznaczono pominiętą część URLa (żeby nie wystawał na margines).
Wynik jest następujący:
Kliknięcie w zdjęcie powoduje przejście do widoku Lightboksa.
Być może za czas jakiś problem zniknie. Wyświetlanie dla tego wpisu 10 zamiast 8 obrazków w widoku Lightboksa będzie tego dowodem:-)