-
Notifications
You must be signed in to change notification settings - Fork 8
/
Copy pathqwiic_oled_custom.h
130 lines (112 loc) · 5.09 KB
/
qwiic_oled_custom.h
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
// qwiic_oled_custom.h
//
// This is a library written for SparkFun Qwiic OLED boards that use the SSD1306.
//
// SparkFun sells these at its website: www.sparkfun.com
//
// Do you like this library? Help support SparkFun. Buy a board!
//
// Micro OLED https://www.sparkfun.com/products/14532
// Transparent OLED https://www.sparkfun.com/products/15173
// "Narrow" OLED https://www.sparkfun.com/products/17153
// 1.3" OLED https://www.sparkfun.com/products/23453
//
//
// Written by Kirk Benell @ SparkFun Electronics, March 2022
//
// This library configures and draws graphics to OLED boards that use the
// SSD1306 display hardware. The library only supports I2C.
//
// Repository:
// https://github.com/sparkfun/SparkFun_Qwiic_OLED_Arduino_Library
//
// Documentation:
// https://sparkfun.github.io/SparkFun_Qwiic_OLED_Arduino_Library/
//
//
// SparkFun code, firmware, and software is released under the MIT License(http://opensource.org/licenses/MIT).
//
// SPDX-License-Identifier: MIT
//
// The MIT License (MIT)
//
// Copyright (c) 2022 SparkFun Electronics
// Permission is hereby granted, free of charge, to any person obtaining a copy of this software and
// associated documentation files (the "Software"), to deal in the Software without restriction,
// including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense,
// and/or sell copies of the Software, and to permit persons to whom the Software is furnished to
// do so, subject to the following conditions:
// The above copyright notice and this permission notice shall be included in all copies or substantial
// portions of the Software.
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT
// NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.
// IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY,
// WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE
// SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
// Implementation for the 1.3" OLED device
#pragma once
#include "qwiic_grssd1306.h"
//////////////////////////////////////////////////////////////////
// Set the defaults for the SparkFun Qwiic MicroOLED
#define kOLEDCustomDefaultWidth 128
#define kOLEDCustomDefaultHeight 64
#define kOLEDCustomDefaultXOffset 0
#define kOLEDCustomDefaultYOffset 0
// Parameters for this device
#define kOLEDCustomDefaultPinConfig 0x12
#define kOLEDCustomDefaultPreCharge 0xF1
#define kOLEDCustomDefaultVCOM 0x40
#define kOLEDCustomDefaultContrast 0xCF
#define kOLEDCustomDefaultDefaultAddress 0x3D
#define kOLEDCustomDefaultAltAddress 0x3C
class QwOLEDCustom : public QwGrSSD1306 {
public:
// Constructor - setup the viewport and default address for this device.
QwOLEDCustom()
: QwGrSSD1306(kOLEDCustomDefaultXOffset, kOLEDCustomDefaultYOffset, kOLEDCustomDefaultWidth, kOLEDCustomDefaultHeight)
{
default_address = kOLEDCustomDefaultDefaultAddress;
};
~QwOLEDCustom()
{
if (m_graphicsBuffer != nullptr)
{
delete[] m_graphicsBuffer;
m_graphicsBuffer = nullptr;
}
};
// set up the specific device settings
bool init(void)
{
this->QwGrSSD1306::setViewport(m_xOffset, m_yOffset, m_displayWidth, m_displayHeight);
this->QwGrSSD1306::setCommPins(m_pinConfig);
this->QwGrSSD1306::setPreCharge(m_preCharge);
this->QwGrSSD1306::setVcomDeselect(m_vcomDeselect);
this->QwGrSSD1306::setContrast(m_contrast);
if (m_graphicsBuffer != nullptr)
delete[] m_graphicsBuffer;
m_graphicsBuffer = new uint8_t[(uint16_t)m_displayWidth * (uint16_t)m_displayHeight / 8];
this->QwGrSSD1306::setBuffer(m_graphicsBuffer); // The buffer to use
// Call the super class to do all the work
return this->QwGrSSD1306::init();
};
void setXOffset(uint8_t xOffset){ m_xOffset = xOffset; }
void setYOffset(uint8_t yOffset){ m_yOffset = yOffset; }
void setDisplayWidth(uint8_t displayWidth){ m_displayWidth = displayWidth; }
void setDisplayHeight(uint8_t displayHeight){ m_displayHeight = displayHeight; }
void setPinConfig(uint8_t pinConfig){ m_pinConfig = pinConfig; }
void setPreCharge(uint8_t preCharge){ m_preCharge = preCharge; }
void setVcomDeselect(uint8_t vcomDeselect){ m_vcomDeselect = vcomDeselect; }
void setContrast(uint8_t contrast){ m_contrast = contrast; }
private:
uint8_t m_xOffset = kOLEDCustomDefaultXOffset;
uint8_t m_yOffset = kOLEDCustomDefaultYOffset;
uint8_t m_displayWidth = kOLEDCustomDefaultWidth;
uint8_t m_displayHeight = kOLEDCustomDefaultHeight;
uint8_t m_pinConfig = kOLEDCustomDefaultPinConfig;
uint8_t m_preCharge = kOLEDCustomDefaultPreCharge;
uint8_t m_vcomDeselect = kOLEDCustomDefaultVCOM;
uint8_t m_contrast = kOLEDCustomDefaultContrast;
// Graphics buffer for this device.
uint8_t *m_graphicsBuffer = nullptr;
};