SharePoint позволяет добавлять свои шаблоны страниц. Рассмотрим создание своей master page в VisualStudio 2010 в виде модуля, который можно подключить к SharePoint серверу.
воскресенье, 1 апреля 2012 г.
SharePoint: Авторизация на site collection с localhost
По умолчанию нельзя залогиниться на SharePoint site collection с той же машины где установлена коллекция. Для исправления этого нужно внести изменения в LSA (local security authority) policy. Разрешить авторизацию с localhost.
Запускаем
В ветке
Источник
Запускаем
regedit.exe
с администраторскими правами.В ветке
HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Control\Lsa
создаём новое поле типа DWORD (32-bit) с именем DisableLoopbackCheck
. И устанавливаем его значение в 1.Источник
пятница, 24 февраля 2012 г.
Android: использование NDK
При разработке приложений под Android можно использовать C/C++. Это даёт возможность использовать существующие наработки и библиотеки написанные на C. Создавать свой, более быстрый чем Java, код. Далее рассмотрим использование C++ кода в Android проекте, на примере простейшего приложения, с применением Eclipse под Windows.
суббота, 11 февраля 2012 г.
XNA: динамическое создание шейдеров
В четвёртой версии XNA Microsoft предлагает создание шейдеров только на стадии компиляции, путём помещения fx-файлов в директорию ресурсов и последующей загрузки уже скомпилированного шейдера в эффекте из ресурсов.
Если есть потребность создания шейдеров в рантайме придётся прибегнуть к громоздкой и медленной процедуре. Поэтому лучше использовать обычный способ загрузки шейдеров из ресурсов.
Далее описание динамического создания шейдера.
var effect = Content.Load<Effect>( Path.Combine(Directories.ContentDirectory, "ShaderFileName"));
Если есть потребность создания шейдеров в рантайме придётся прибегнуть к громоздкой и медленной процедуре. Поэтому лучше использовать обычный способ загрузки шейдеров из ресурсов.
Далее описание динамического создания шейдера.
вторник, 31 января 2012 г.
Android: скрываем адресную строку у WebView
По умолчанию у WebView всегда присутствует адресная строка. Для того чтоб убрать её нужно так же, как и при перехвате ошибки загрузки страницы, заменить WebViewClientна свой.
Использование:
private class MyWebViewClient extends WebViewClient { /** Remove address bar */ @Override public boolean shouldOverrideUrlLoading( WebView view, String url ) { view.loadUrl(url); return true; } }
Использование:
this.webView.setWebViewClient( new MyWebViewClient() );
воскресенье, 29 января 2012 г.
Визуальное представление SQL запросов с JOIN
Использование JOIN в SQL запросах гораздо проще понять если отобразить их в диаграммах Эйлера-Венна. Когда я изучал SQL мне попались только англоязычные материалы. Ligaya Turmelle и Jeff Atwood. Надеюсь этот материал поможет русскоязычным коллегам.
Для экспериментов используется две таблицы.
Таблица А:
Таблица B:
Выбираются строки из таблицы A и B, в которых есть одинаковые ключевые значения и в таблице A и в таблице B.
Для экспериментов используется две таблицы.
Таблица А:
create table `tableA` ( `id` int, `name` varchar(30) ); insert into `tableA` ( `id`, `name` ) values ( 1, 'Pirate' ), ( 2, 'Monkey' ), ( 3, 'Ninja' ), ( 4, 'Spaghetti' );
+------+-----------+
| id | name |
+------+-----------+
| 1 | Pirate |
| 2 | Monkey |
| 3 | Ninja |
| 4 | Spaghetti |
+------+-----------+
Таблица B:
create table `tableB` ( `id` int, `name` varchar(30) ); insert into `tableB` ( `id`, `name` ) values ( 1, 'Rutabaga' ), ( 2, 'Pirate' ), ( 3, 'Darth Vader' ), ( 4, 'Ninja' );
+------+-------------+
| id | name |
+------+-------------+
| 1 | Rutabaga |
| 2 | Pirate |
| 3 | Darth Vader |
| 4 | Ninja |
+------+-------------+
1. INNER JOIN
select * from tableA inner join tableB on tableA.name = tableB.name;
+------+--------+------+--------+
| id | name | id | name |
+------+--------+------+--------+
| 1 | Pirate | 2 | Pirate |
| 3 | Ninja | 4 | Ninja |
+------+--------+------+--------+
Выбираются строки из таблицы A и B, в которых есть одинаковые ключевые значения и в таблице A и в таблице B.
Media Queries для определения iOS устройства
Используя Media queries по размеру экрана можно определить на какое iOS устройство загружена страница.
/* Desktop large × large */ @media all and (min-device-width: 1025px){ body:before{ content:"Desktop"; } } /* iPad 1024 × 768 */ @media all and (max-device-width:1024px) and (min-device-width:481px) and (orientation:landscape){ .ipad:before{ content:"iPad landscape"; } } @media all and (max-device-width:768px) and (min-device-width:321px) and (orientation:portrait){ .ipad:after{ content:"iPad portrait"; } } /* iPhone retina 640 × 960 */ @media all and (-webkit-min-device-pixel-ratio: 2) and (max-device-width:480px) and (orientation:landscape){ .iphone-retina:before{ content:"IPhone Retina landscape"; } } @media all and (-webkit-min-device-pixel-ratio: 2) and (max-device-width:320px) and (orientation:portrait){ .iphone-retina:after{ content:"IPhone Retina portrait"; } } /* iPhone 320 × 480 */ @media all and (max-device-width:480px) and (-webkit-max-device-pixel-ratio: 1) and (orientation:landscape){ .iphone-tft:before{ content:"IPhone TFT landscape"; } } @media all and (max-device-width:320px) and (-webkit-max-device-pixel-ratio: 1) and (orientation:portrait){ .iphone-tft:after{ content:"IPhone TFT portrait"; } }Источник
Подписаться на:
Сообщения (Atom)